diff -r 000000000000 -r 9cfd9a3ee49c lbstest/lbstestproduct/lbshybridcombined/src/ctlbshybridcombinedserver.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/lbstest/lbstestproduct/lbshybridcombined/src/ctlbshybridcombinedserver.cpp Tue Feb 02 01:50:39 2010 +0200 @@ -0,0 +1,212 @@ +// 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: +// @file CTLbsHybridMTLRServer.cpp +// This is the class implementation for the LBS Hybrid Combined Test Server +// +// + +// System includes +#include +#include + +// User includes +#include "ctlbshybridcombinedserver.h" +#include "ctlbsstepsetuproamselflocate.h" +#include "ctlbsstepconfighybridmodule.h" + +// i don't know why this isn't in the base class.... +#include "ctlbsstepsetupprotocolstub.h" + +#include "ctlbshybridcombinedstep_sequential01.h" +#include "ctlbshybridcombinedstep_sequential02.h" +#include "ctlbshybridcombinedstep_concurrent01.h" +#include "ctlbshybridcombinedstep_concurrent02.h" +#include "ctlbshybridcombinedstep_tracking01.h" +#include "ctlbshybridcombinedstep_tracking02.h" + +/** + MainL() + Description : This is the main function which installs the + active scheduler and creates a server + @internalTechnology + @param none + @return none + @pre None + @post None +*/ +LOCAL_C void MainL() + { + CActiveScheduler* sched = new (ELeave) CActiveScheduler; + CleanupStack::PushL(sched); + CActiveScheduler::Install(sched); + + __UHEAP_MARK; + // this registers the server with the active scheduler and calls SetActive + CT_LbsHybridCombinedServer* server = CT_LbsHybridCombinedServer::NewL(); + + // signal to the client that we are ready by + // rendevousing process + RProcess::Rendezvous(KErrNone); + + // run the active scheduler + sched->Start(); + + // clean up + delete server; + __UHEAP_MARKEND; + CleanupStack::PopAndDestroy(sched); + } + + + + +/** + E32Main() + Description : It is the entry point + @internalTechnology + @param none + @return Returns the error code + @pre None + @post None +*/ +GLDEF_C TInt E32Main() + { + __UHEAP_MARK; + CTrapCleanup* cleanup = CTrapCleanup::New(); + if(cleanup == NULL) + { + return KErrNoMemory; + } + + TRAPD(err, MainL()); + + delete cleanup; + __UHEAP_MARKEND; + + return err; + } + + +/** + NewL() + Constructs a CT_LbsHybridCombinedServer object. + Uses two phase construction and leaves nothing on the CleanupStack. + @internalTechnology + @param none + @return Created object of type CT_LbsHybridCombinedServer + @pre None + @post None +*/ +CT_LbsHybridCombinedServer* CT_LbsHybridCombinedServer::NewL() + { + CT_LbsHybridCombinedServer*server = new(ELeave) CT_LbsHybridCombinedServer(); + CleanupStack::PushL(server); + server->ConstructL(KLbsHybridCombinedTestServer); + CleanupStack::Pop(server); + return server; + } + + + +CT_LbsHybridCombinedServer::~CT_LbsHybridCombinedServer() + { + } + + +/** + Function : CT_LbsHybridCombinedServer + Description : Constructor + @internalTechnology + @param : + @return : N/A + @precondition : none + @postcondition : none +*/ +CT_LbsHybridCombinedServer::CT_LbsHybridCombinedServer() + { + } + +/** + Function : ConstructL + Description : + @internalTechnology + @param : + @return : N/A + @precondition : none + @postcondition : none +*/ +void CT_LbsHybridCombinedServer::ConstructL(const TDesC& aName) + { + CT_LbsServer::ConstructL(aName); + + iSharedData = CT_LbsHybridCombinedSharedData::NewL(); + } + + +/** + Function : CreateTestStep + Description : Creates a test step based on the step name read from the script file + @internalTechnology + @param : aStepName The step name which needs to be created + @return : Created object of type CTestStep + @precondition : none + @postcondition : none +*/ +CTestStep* CT_LbsHybridCombinedServer::CreateTestStep(const TDesC& aStepName) + { + // NULL if insufficient memory. This suits the API. + + // Test case test steps, each test step supports one or more test cases. + if (aStepName == KLbsStep_SetupRoamSelfLocate) + { + return CT_LbsStep_SetupRoamSelfLocate::New(*this); + } + else if(aStepName == KLbsStep_SetupProtocolStub) + { + return CT_LbsStep_SetupProtocolStub::New(*this); + } + else if(aStepName == KLbsStep_ConfigHybridModule) + { + return CT_LbsStep_ConfigHybridModule::New(*this); + } + + else if(aStepName == KLbsHybridCombinedStep_Sequential01) + { + return CT_LbsHybridCombinedStep_Sequential01::New(*this); + } + else if(aStepName == KLbsHybridCombinedStep_Sequential02) + { + return CT_LbsHybridCombinedStep_Sequential02::New(*this); + } + else if(aStepName == KLbsHybridCombinedStep_Concurrent01) + { + return CT_LbsHybridCombinedStep_Concurrent01::New(*this); + } + else if(aStepName == KLbsHybridCombinedStep_Concurrent02) + { + return CT_LbsHybridCombinedStep_Concurrent02::New(*this); + } + else if(aStepName == KLbsHybridCombinedStep_Tracking01) + { + return CT_LbsHybridCombinedStep_Tracking01::New(*this); + } + else if(aStepName == KLbsHybridCombinedStep_Tracking02) + { + return CT_LbsHybridCombinedStep_Tracking02::New(*this); + } + + // Let base class handle any common test steps - will return NULL if test step is not supported. + return CT_LbsServer::CreateTestStep(aStepName); + } +