commsprocess/commsrootserverconfig/TE_rootserver/src/RootServerTestSection7.cpp
author hgs
Mon, 06 Sep 2010 13:49:23 +0100
changeset 72 ae47d0499bee
permissions -rw-r--r--
201033_02

// Copyright (c) 2003-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:
// This contains RootServer Test cases from section 8
// 
//

// EPOC includes
#include <e32base.h>
#include <es_mbman.h>

// Test system includes
//#include <networking/log.h>
//#include <networking/teststep.h>
//#include <networking/testsuite.h>

#include "TestStepRootServer.h"
#include "TestAsynchHandler.h"
#include "RootServerTestSection7.h"
#include "RootServerTest.h"

// Test step 7.1 - OOM loop Test1 - Load, Enumerate, GetInfo
CRootServerTest7_1::CRootServerTest7_1(CTE_RootServerServer *aSuite) : CTestStepRootServer(aSuite)
{
	// store the name of this test case
	SetTestStepName(_L("Test7.1"));
}

TVerdict CRootServerTest7_1::doTestStepL( void )
	{
	INFO_PRINTF1(_L("Test Purpose: OOM loop test 1: Load, Enumerate, GetInfo"));
										SetTestStepResult(EPass);

	// Create scheduler/active object framework 
	CSelfPopScheduler* scheduler = CSelfPopScheduler::CreateLC();
    CTestAsynchHandler* asynchHandler = CTestAsynchHandler::NewLC(&iRootServerSuite->RootSess());


	TInt failure = 1000;
							
		while(TestStepResult() == EPass)
		{
		iRootServerSuite->RootSess().__DbgFailNext(failure);
		failure++;

		TRSStartModuleParams startParams;
		TTestModuleIniData iniData;
		DefaultStartParams(startParams, iniData);
		startParams.iParams.iName = KModule1;
		
		asynchHandler->TryLoad(startParams, iniData);
    	CActiveScheduler::Start();

		if (asynchHandler->iStatus != KErrNone)
			{
			INFO_PRINTF3(_L("TryLoad: %d with FailNext(%d)"), asynchHandler->iStatus.Int(), failure);
if(asynchHandler->iStatus == KErrRSModuleAlreadyExist)
	User::Leave(KErrRSModuleAlreadyExist);
			continue;
			}

		TCFModuleName moduleName;
		TRSIter position;
		TInt ret = iRootServerSuite->RootSess().EnumerateModules(position, moduleName);
		if(ret != KErrNone)
			{
			INFO_PRINTF3(_L("EnumerateModules: %d with FailNext(%d)"), asynchHandler->iStatus.Int(), failure);
			continue;
			}

		if(moduleName != KModule1)
			{
			INFO_PRINTF2(_L("EnumerateModules() returned KErrNone but wrong name: %S"), &moduleName);
			SetTestStepResult(EFail);

			break;
			}

		TRSModuleInfo info;
		ret = iRootServerSuite->RootSess().GetModuleInfo(KModule1(), info);
		if(ret != KErrNone)
			{
			INFO_PRINTF3(_L("GetModuleInfo: %d with FailNext(%d)"), asynchHandler->iStatus.Int(), failure);
			continue;
			}

		if(info.iParams.iState != ERunning)
			{
			INFO_PRINTF2(_L("GetModuleInfo() returned KErrNone but wrong state: %d"), info.iParams.iState);
			SetTestStepResult(EFail);

			}
		// everything worked;
		INFO_PRINTF1(_L("OOM loop complete"));
		break;
		}


	INFO_PRINTF1(_L("Resetting heap"));
	iRootServerSuite->RootSess().__DbgFailNext(-1);
	// uninstall and destroy active scheduler
	CleanupStack::PopAndDestroy(asynchHandler);
	CleanupStack::PopAndDestroy(scheduler);
	return TestStepResult();
	}

// Test step 7.2 - OOM loop Test2 - Unload, GetInfo
CRootServerTest7_2::CRootServerTest7_2(CTE_RootServerServer *aSuite) : CTestStepRootServer(aSuite)
{
	// store the name of this test case
	SetTestStepName(_L("Test7.2"));
}

TVerdict CRootServerTest7_2::doTestStepL( void )
	{
	INFO_PRINTF1(_L("Test Purpose: Heap loop Test2 - Unload, GetInfo"));
										SetTestStepResult(EPass);

	// Create scheduler/active object framework 
	CSelfPopScheduler* scheduler = CSelfPopScheduler::CreateLC();
    CTestAsynchHandler* asynchHandler = CTestAsynchHandler::NewLC(&iRootServerSuite->RootSess());

	INFO_PRINTF2(_L("01 Loading cpm: %S"), &KModule1());
	LoadNormalModuleL(asynchHandler, KModule1);

	TInt failure = 1;
						
	while(TestStepResult() == EPass)
		{
		iRootServerSuite->RootSess().__DbgFailNext(failure);
		failure++;

		asynchHandler->TryUnLoad(KModule1(), EUnGraceful);
    	CActiveScheduler::Start();

		if (asynchHandler->iStatus != KErrNone)
			{
			INFO_PRINTF3(_L("TryUnload: %d with FailNext(%d)"), asynchHandler->iStatus.Int(), failure);
			if(asynchHandler->iStatus != KErrRSModuleNotLoaded)
				{
				continue;
				}
			}

		TRSModuleInfo info;
		TInt ret = iRootServerSuite->RootSess().GetModuleInfo(KModule1(), info);
		if(ret == KErrRSModuleUnknown)
			{
			// everything worked;
			INFO_PRINTF1(_L("OOM loop complete"));
			break;
			}
		else if(ret == KErrNone)
			{
			INFO_PRINTF1(_L("GetModuleInfo() returned KErrNone for unloaded module"));
			SetTestStepResult(EFail);

			}
		else 
			{
			INFO_PRINTF3(_L("GetModuleInfo: %d with FailNext(%d)"), ret, failure);
			continue;
			}
		}

	INFO_PRINTF1(_L("Resetting heap"));
	iRootServerSuite->RootSess().__DbgFailNext(-1);
	// uninstall and destroy active scheduler
	CleanupStack::PopAndDestroy(asynchHandler);
	CleanupStack::PopAndDestroy(scheduler);
	return TestStepResult();
	}
	

// Test step 7.3 - OOM loop Test 3 - Bind
CRootServerTest7_3::CRootServerTest7_3(CTE_RootServerServer *aSuite) : CTestStepRootServer(aSuite)
{
	// store the name of this test case
	SetTestStepName(_L("Test7.3"));
}

TVerdict CRootServerTest7_3::doTestStepL( void )
	{
	INFO_PRINTF1(_L("Test Purpose: Heap loop Test3 - Bind, EnumerateBindings"));
										SetTestStepResult(EPass);

	// Create scheduler/active object framework 
	CSelfPopScheduler* scheduler = CSelfPopScheduler::CreateLC();
    CTestAsynchHandler* asynchHandler = CTestAsynchHandler::NewLC(&iRootServerSuite->RootSess());

	INFO_PRINTF2(_L("01 Loading cpm: %S"), &KModule1());
	LoadNormalModuleL(asynchHandler, KModule1);

	TCFSubModuleAddress fullName1;
	fullName1.SetModule(KModule1());
	fullName1.SetSubModule(KSubModule1());
	TInt failure = 1;
						
	while(TestStepResult() == EPass)
		{
		INFO_PRINTF2(_L("Failing after %d Allocs"), failure);
		iRootServerSuite->RootSess().__DbgFailNext(failure);
		failure++;

		TInt ret = TryHierachicalBind(asynchHandler, KModule1, KSubModule1, KModule1, KSubModule2);
		if(ret != KErrNone)
			continue;

		INFO_PRINTF1(_L("02 Enumerate bindings"));
		TRSBindingInfo bindInfo;
		TRSIter position;
		ret = iRootServerSuite->RootSess().EnumerateBindings(fullName1, position, bindInfo);
		if(ret != KErrNone)
			continue;

		// everything worked;
		INFO_PRINTF1(_L("OOM loop complete"));
		break;
		}		

	CleanupStack::PopAndDestroy(asynchHandler);
	CleanupStack::PopAndDestroy(scheduler);
	return TestStepResult();
	}

// Test step 7.4 - OOM loop Test 4 - Unbind
CRootServerTest7_4::CRootServerTest7_4(CTE_RootServerServer *aSuite) : CTestStepRootServer(aSuite)
{
	// store the name of this test case
	SetTestStepName(_L("Test7.4"));
}

TVerdict CRootServerTest7_4::doTestStepL( void )
	{
	INFO_PRINTF1(_L("Test Purpose: Heap loop Test4 - Unbind, EnumerateBindings"));
										SetTestStepResult(EPass);

	// Create scheduler/active object framework 
	CSelfPopScheduler* scheduler = CSelfPopScheduler::CreateLC();
    CTestAsynchHandler* asynchHandler = CTestAsynchHandler::NewLC(&iRootServerSuite->RootSess());

	INFO_PRINTF2(_L("01 Loading and binding cpm: %S"), &KModule1());
	LoadNormalModuleL(asynchHandler, KModule1);
	TInt ret = TryHierachicalBind(asynchHandler, KModule1, KSubModule1, KModule1, KSubModule2);
	if(ret != KErrNone)
		{
		INFO_PRINTF2(_L("Binding CPM failed with %d"), ret);
		User::Leave(ret);
		}

	TCFSubModuleAddress fullName1;
	fullName1.SetModule(KModule1());
	fullName1.SetSubModule(KSubModule1());
	TInt failure = 1;
							
	while(TestStepResult() == EPass)
		{
		iRootServerSuite->RootSess().__DbgFailNext(failure);
		failure++;

		TRSUnBindingInfo unbindInfo;
		unbindInfo.iParams.iAddress1.SetModule(KModule1());
		unbindInfo.iParams.iAddress1.SetSubModule(KSubModule1());
		unbindInfo.iParams.iAddress2.SetModule(KModule1());
		unbindInfo.iParams.iAddress2.SetSubModule(KSubModule2());
		asynchHandler->TryUnBind( unbindInfo );
		
		CActiveScheduler::Start();

		if (asynchHandler->iStatus != KErrNone)
			{
			INFO_PRINTF3(_L("TryUnload: %d with FailNext(%d)"), asynchHandler->iStatus.Int(), failure);
			continue;
			}

		INFO_PRINTF1(_L("03 Enumerate bindings"));
		TRSBindingInfo bindInfo;
		TRSIter position;
		ret = iRootServerSuite->RootSess().EnumerateBindings(fullName1, position, bindInfo);
		if(ret == KErrEof)
			{
			INFO_PRINTF1(_L("OOM loop complete"));
			break;
			}
		else if(ret == KErrNone)
			{
			INFO_PRINTF1(_L("EnumerateBindings returned KErrNone for unbound submodules"));
			SetTestStepResult(EFail);

			}
		else 
			{
			INFO_PRINTF3(_L("EnumerateBindings: %d with FailNext(%d)"), ret, failure);
			continue;
			}
		}		

	CleanupStack::PopAndDestroy(asynchHandler);
	CleanupStack::PopAndDestroy(scheduler);
	return TestStepResult();
	}