diff -r 000000000000 -r 4e1aa6a622a0 systemhealthmanagement/systemhealthmgr/test/testprocgood/shmatestprocgood.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/systemhealthmanagement/systemhealthmgr/test/testprocgood/shmatestprocgood.cpp Tue Feb 02 00:53:00 2010 +0200 @@ -0,0 +1,224 @@ +// Copyright (c) 2007-2009 Nokia Corporation and/or its subsidiary(-ies). +// All rights reserved. +// This component and the accompanying materials are made available +// under the terms of "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: +// testprocgood.cpp +// +// + +/** + @file + @test + @internalComponent - Internal Symbian test code +*/ + +#include +#include +#include +#include +#include "testprocgoodsession.h" +#include "shmatestprocgood.h" +#include "testapps.h" + +// +// Launch code +// + +/** Check if a aSwitch was given in the commandline when starting this process */ +static TBool CmdLineOptionL(const TDesC& aSwitch) + { + const TInt KMaxCommandLength = 256; + TBuf commandLine; + if(User::CommandLineLength() > commandLine.MaxLength()) + User::Leave(KErrTooBig); + + User::CommandLine(commandLine); + + TLex flagLex(commandLine); + while(!flagLex.Eos()) + { + TPtrC token(flagLex.NextToken()); + if(token == aSwitch) + { + return ETrue; + } + } + return EFalse; + } + +static void RunL() + { + User::LeaveIfError(RThread::RenameMe(KTestProcGood)); + + CActiveScheduler* s=new(ELeave) CActiveScheduler; + CleanupStack::PushL(s); + CActiveScheduler::Install(s); + + if(CmdLineOptionL(KLaunchServerCommandLineOption)) + { + CTestServerGood::NewLC(); + } + + if(!CmdLineOptionL(KTestProcGoodNoRendevouz)) + { + RProcess::Rendezvous(KErrNone); + } + + if(CmdLineOptionL(KFailAfterRendevouzCommandLineOption)) + { + User::Leave(KErrAbort); + } + + _LIT(KTestGoodProcPanic, "Panic"); + if(CmdLineOptionL(KPanicCommandLineOption1)) + { + User::Panic(KTestGoodProcPanic, KProcPanic); + } + + if(CmdLineOptionL(KPanicCommandLineOption2)) + { + User::Panic(KTestGoodProcPanic, KErrNone); + } + + RSemaphore sem; + TInt err = sem.OpenGlobal(KStartShmaTestProcGood); + if(err == KErrNone) + { + sem.Signal(); + sem.Close(); + } + + CActiveScheduler::Start(); + + CleanupStack::PopAndDestroy(2); + } + +TInt E32Main() + { + __UHEAP_MARK; + + CTrapCleanup* cleanup=CTrapCleanup::New(); + TInt r=KErrNoMemory; + if (cleanup) + { + TRAP(r,RunL()); + delete cleanup; + } + + __UHEAP_MARKEND; + return r; + } //lint -e714 Suppress 'not referenced' + +// +// Server +// + +CTestServerGood::CTestServerGood() : CServer2(0) + { + } + +CTestServerGood::~CTestServerGood() + { + } + +CServer2* CTestServerGood::NewLC() + { + CTestServerGood * self=new(ELeave) CTestServerGood; + CleanupStack::PushL(self); + self->ConstructL(); + return self; + } + +void CTestServerGood::ConstructL() + { + StartL(KTestProcGood); + + //Signalling the start of the application + } + +static CStartupProperties* StartupPropertiesLC(TInt aRecoveryMethod) + { + CStartupProperties* prop = CStartupProperties::NewLC(KTestProcGood, KLaunchServerCommandLineOption); + prop->SetMonitored(ETrue); + prop->SetStartMethod(EWaitForStart); + prop->SetRecoveryParams((TRecoveryMethod)aRecoveryMethod, 0); + prop->SetNoOfRetries(1); + prop->SetTimeout(0); + return prop; + } +static CSsmStartupProperties* SsmStartupPropertiesLC(TInt aRecoveryMethod) + { + CSsmStartupProperties* prop = CSsmStartupProperties::NewLC(KTestProcGood, KLaunchServerCommandLineOption); + prop->SetExecutionBehaviour(ESsmWaitForSignal); + TSsmMonitorInfo monitorInfo; + monitorInfo.iRestartPolicy = (TSsmRecoveryMethod)aRecoveryMethod; + monitorInfo.iRestartMode = 0; + monitorInfo.iTimeout = 0; + monitorInfo.iRetries = 1; + prop->SetMonitorInfoL(monitorInfo); + return prop; + } + +void CTestServerGoodSession::ServiceL(const RMessage2& aMessage) + { + TInt err = KErrNone; + switch (aMessage.Function()) + { + case EMonitorSelfWithStartupProp: + { + RSysMonSession sysmons; + sysmons.OpenL(); + CleanupClosePushL(sysmons); + CStartupProperties* prop = StartupPropertiesLC(aMessage.Int0()); + TRAP(err, sysmons.MonitorSelfL(*prop)); + CleanupStack::PopAndDestroy(prop); + CleanupStack::PopAndDestroy(&sysmons); + break; + } + case EMonitorSelfWithSsmStartupProp: + { + RSysMonSession sysmons; + sysmons.OpenL(); + CleanupClosePushL(sysmons); + CSsmStartupProperties* prop = SsmStartupPropertiesLC(aMessage.Int0()); + TRAP(err, sysmons.MonitorSelfL(*prop)); + CleanupStack::PopAndDestroy(prop); + CleanupStack::PopAndDestroy(&sysmons); + break; + } + case ECancelMonitor: + { + RSysMonSession sysmons; + sysmons.OpenL(); + CleanupClosePushL(sysmons); + TRAP(err, sysmons.CancelMonitorSelfL()); + CleanupStack::PopAndDestroy(&sysmons); + break; + } + case EShutDown: + CActiveScheduler::Stop(); + break; + default: + break; + } + aMessage.Complete(err); + } + +// +// Session +// + +CSession2* CTestServerGood::NewSessionL(const TVersion&,const RMessage2&) const + { + return new(ELeave) CTestServerGoodSession(); + } +