installationservices/swi/test/tintegrityservices/tintegrityservicesserver.cpp
changeset 0 ba25891c3a9e
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/installationservices/swi/test/tintegrityservices/tintegrityservicesserver.cpp	Thu Dec 17 08:51:10 2009 +0200
@@ -0,0 +1,298 @@
+/*
+* Copyright (c) 2006-2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description: 
+*
+*/
+
+
+#include "tintegrityservicesserver.h"
+#include "tintegrityservicesclientserver.h"
+#include "integrityservices.h"
+#include "log.h"
+#include <e32debug.h>
+
+
+_LIT(KJournalPath, "\\IntegrityServices\\");
+
+using Swi::Test::CIntegrityServicesServer;
+using Swi::Test::CIntegrityServicesSession;
+using Swi::Test::CShutdownTimer;
+
+static void PanicClient(const RMessagePtr2& aMessage, 
+						Swi::Test::TIntegrityServicesServerPanic aPanic)
+	{
+	aMessage.Panic(Swi::Test::KIntegrityServicesServerName, aPanic);
+	}
+
+/////
+///// CIntegrityServicesServer
+/////
+
+CIntegrityServicesServer* CIntegrityServicesServer::NewLC()
+	{
+	CIntegrityServicesServer* self = new(ELeave) CIntegrityServicesServer();
+	CleanupStack::PushL(self);
+	self->ConstructL();
+	return self;
+	}
+	
+void CIntegrityServicesServer::AddSession()
+	{
+	++iSessionCount;
+	iShutdown->Cancel();
+	}
+	
+void CIntegrityServicesServer::DropSession()
+	{
+	if (--iSessionCount==0)
+		{
+		iShutdown->Start();
+		RDebug::Print(_L("Server shutting down"));
+		}
+	}
+
+CIntegrityServicesServer::~CIntegrityServicesServer()
+	{
+	delete iShutdown;
+	RDebug::Print(_L("Server destructor"));
+	}
+
+CIntegrityServicesServer::CIntegrityServicesServer() : CServer2(EPriorityNormal, ESharableSessions)
+	{
+	}
+
+void CIntegrityServicesServer::ConstructL()
+	{
+	StartL(Swi::Test::KIntegrityServicesServerName);
+	
+	iShutdown = CShutdownTimer::NewL();
+	
+	// Ensure that the server still exits even if the 1st client fails to
+	// connect
+	iShutdown->Start();
+	}
+
+CSession2* CIntegrityServicesServer::NewSessionL(const TVersion& /*aVersion*/, 
+						 const RMessage2& /*aMessage*/) const
+	{
+	  return CIntegrityServicesSession::NewL();
+	}
+
+CIntegrityServicesSession* CIntegrityServicesSession::NewL()
+	{
+	CIntegrityServicesSession* self = CIntegrityServicesSession::NewLC();
+	CleanupStack::Pop(self);
+	return self;
+	}
+	
+	
+CIntegrityServicesSession* CIntegrityServicesSession::NewLC()
+	{
+	CIntegrityServicesSession* self = new(ELeave) CIntegrityServicesSession();
+	CleanupStack::PushL(self);
+	self->ConstructL();
+	return self;
+	}
+
+CIntegrityServicesSession::CIntegrityServicesSession() : CSession2()
+	{
+	}
+	
+void CIntegrityServicesSession::ConstructL()
+	{
+	iIntegrityServices = CDummyIntegrityServices::NewL(0, KJournalPath);
+	}
+	
+void CIntegrityServicesSession::CreateL()
+	{
+	RDebug::Print(_L("Session CreateL"));
+	Server().AddSession();
+	}
+
+
+
+CIntegrityServicesSession::~CIntegrityServicesSession()
+	{
+	delete iIntegrityServices;
+	Server().DropSession();
+	}
+
+CIntegrityServicesServer& CIntegrityServicesSession::Server()
+	{
+	return *static_cast<CIntegrityServicesServer*>(
+		const_cast<CServer2*>(CSession2::Server()));
+	}
+
+/////
+///// CIntegrityServicesSession		
+/////
+	
+void CIntegrityServicesSession::ServiceL(const RMessage2& aMessage)
+	{
+	switch (aMessage.Function())
+		{
+		case EAdd:
+			{
+			RDebug::Print(_L("ServiceL EAdd"));
+			HBufC16* fileName = HBufC16::NewLC(aMessage.GetDesLength(0));
+		  	TPtr16 ptr(fileName->Des());
+		  	aMessage.Read(0, ptr);
+
+		  	TRAPD(err, iIntegrityServices->AddL(*fileName));
+
+			aMessage.Complete(err);
+			CleanupStack::PopAndDestroy(fileName);	
+			break;
+			}
+		case ERemove:
+			{
+			RDebug::Print(_L("ServiceL ERemove"));
+			HBufC16* fileName = HBufC16::NewLC(aMessage.GetDesLength(0));
+		  	TPtr16 ptr(fileName->Des());
+		  	aMessage.Read(0, ptr);
+
+		  	TRAPD(err, iIntegrityServices->RemoveL(*fileName));
+
+			aMessage.Complete(err);
+			CleanupStack::PopAndDestroy(fileName);	
+			
+			break;
+			}
+		case ETemporary:
+			{
+			RDebug::Print(_L("ServiceL ETemporary"));
+			HBufC16* fileName = HBufC16::NewLC(aMessage.GetDesLength(0));
+		  	TPtr16 ptr(fileName->Des());
+		  	aMessage.Read(0, ptr);
+
+		  	TRAPD(err, iIntegrityServices->TemporaryL(*fileName));
+
+			aMessage.Complete(err);
+			CleanupStack::PopAndDestroy(fileName);	
+			break;
+			}
+		case ECommit:
+			{
+			RDebug::Print(_L("ServiceL ECommit"));
+			TRAPD(err, iIntegrityServices->CommitL());
+			aMessage.Complete(err);
+			break;
+			}
+		case ERollBack:
+			{
+			RDebug::Print(_L("ServiceL ERollBack"));
+			TBool all;
+			TPckg<TBool> allTransactions(all);
+			aMessage.ReadL(0, allTransactions);
+			
+			TRAPD(err, iIntegrityServices->RollBackL(all));
+			
+			aMessage.Complete(err);
+			
+			break;
+			}
+			
+		case ESetSimulatedFailure:
+			{
+			HBufC16* aFailType = HBufC16::NewLC(256);
+			HBufC16* aPosition = HBufC16::NewLC(256);
+			HBufC16* aFailFileName = HBufC16::NewLC(256);
+			TPtr16 failType(aFailType->Des());
+			TPtr16 position(aPosition->Des());
+			TPtr16 failFileName(aFailFileName->Des());
+			
+			aMessage.ReadL(0, failType);
+			aMessage.ReadL(1, position);
+			aMessage.ReadL(2, failFileName);
+			RDebug::Print(_L("ServiceL ESetSimulatedFailure %S %S %S"), &aFailType, &aPosition, &aFailFileName);
+			TRAPD(err, iIntegrityServices->SetSimulatedFailure(failType, position, failFileName));
+			aMessage.Complete(err);
+			CleanupStack::PopAndDestroy(3, aFailType);
+			break;
+			}
+		case ECreateNewTestFile:
+			{
+			RDebug::Print(_L("ServiceL ECreateNewTestFile"));
+			HBufC16* fileName = HBufC16::NewLC(aMessage.GetDesLength(0));
+		  	TPtr16 ptr(fileName->Des());
+		  	aMessage.Read(0, ptr);
+
+		  	TRAPD(err, iIntegrityServices->CreateNewTestFileL(*fileName));
+
+			aMessage.Complete(err);
+			CleanupStack::PopAndDestroy(fileName);	
+			break;
+			}
+		case ECreateTempTestFile:
+			{
+			RDebug::Print(_L("ServiceL ECreateTempTestFile"));
+			HBufC16* fileName = HBufC16::NewLC(aMessage.GetDesLength(0));
+		  	TPtr16 ptr(fileName->Des());
+		  	aMessage.Read(0, ptr);
+
+		  	TRAPD(err, iIntegrityServices->CreateTempTestFileL(*fileName));
+
+			aMessage.Complete(err);
+			CleanupStack::PopAndDestroy(fileName);	
+			break;
+			}
+	default:
+		{
+		PanicClient(aMessage, Swi::Test::EPanicIntegrityServicesServerIllegalFunction);
+		break;
+		}
+		}
+	}
+
+void CIntegrityServicesSession::ServiceError(const RMessage2& aMessage, TInt aError)
+	{
+	if (aError==KErrBadDescriptor)
+		{
+		PanicClient(aMessage, Swi::Test::EPanicIntegrityServicesServerIllegalFunction);
+		}
+	CSession2::ServiceError(aMessage, aError);
+	}
+
+/////
+///// CShutdownTimer
+/////
+inline CShutdownTimer::CShutdownTimer() : CTimer(-1)
+	{
+	CActiveScheduler::Add(this);
+	}
+
+inline void CShutdownTimer::ConstructL()
+	{
+	CTimer::ConstructL();
+	}
+
+inline void CShutdownTimer::Start()
+	{
+	After(KShutdownDelay);
+	}
+
+CShutdownTimer* CShutdownTimer::NewL()
+	{
+	CShutdownTimer* self = new(ELeave) CShutdownTimer();
+	CleanupStack::PushL(self);
+	self->ConstructL();
+	CleanupStack::Pop(self);
+	return self;
+	}
+
+// Initiate server exit when the timer expires
+void CShutdownTimer::RunL()
+	{
+	CActiveScheduler::Stop();
+	}