commsprocess/commsrootserverconfig/TE_rootserver/src/RootServerTestSection6.cpp
author hgs
Mon, 06 Sep 2010 13:49:23 +0100
changeset 72 ae47d0499bee
permissions -rw-r--r--
201033_02
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
72
ae47d0499bee 201033_02
hgs
parents:
diff changeset
     1
// Copyright (c) 2003-2009 Nokia Corporation and/or its subsidiary(-ies).
ae47d0499bee 201033_02
hgs
parents:
diff changeset
     2
// All rights reserved.
ae47d0499bee 201033_02
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
ae47d0499bee 201033_02
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
ae47d0499bee 201033_02
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
ae47d0499bee 201033_02
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
ae47d0499bee 201033_02
hgs
parents:
diff changeset
     7
//
ae47d0499bee 201033_02
hgs
parents:
diff changeset
     8
// Initial Contributors:
ae47d0499bee 201033_02
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    10
//
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    11
// Contributors:
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    12
//
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    13
// Description:
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    14
// This contains RootServer Test cases from section 6
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    15
// 
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    16
//
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    17
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    18
// EPOC includes
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    19
#include <e32base.h>
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    20
#include <es_mbman.h>
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    21
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    22
// Test system includes
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    23
//#include <networking/log.h>
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    24
//#include <networking/teststep.h>
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    25
//#include <networking/testsuite.h>
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    26
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    27
#include "TestStepRootServer.h"
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    28
#include "TestAsynchHandler.h"
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    29
#include "RootServerTestSection6.h"
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    30
#include <cfshared.h>
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    31
#include "RootServerTest.h"
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    32
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    33
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    34
// Test step 6.1 - Bind without loading
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    35
CRootServerTest6_1::CRootServerTest6_1(CTE_RootServerServer *aSuite) : CTestStepRootServer(aSuite)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    36
{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    37
	// store the name of this test case
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    38
	SetTestStepName(_L("Test6.1"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    39
}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    40
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    41
TVerdict CRootServerTest6_1::doTestStepL( void )
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    42
	{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    43
	INFO_PRINTF1(_L("Test Purpose: Bind without loading"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    44
										SetTestStepResult(EPass);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    45
	// Create scheduler/active object framework 
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    46
	CSelfPopScheduler* scheduler = CSelfPopScheduler::CreateLC();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    47
    CTestAsynchHandler* asynchHandler = CTestAsynchHandler::NewLC(&iRootServerSuite->RootSess());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    48
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    49
	//*****************step 2************************
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    50
	INFO_PRINTF1(_L("02 Attempting bind"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    51
	TInt ret = TryHierachicalBind(asynchHandler, KModule1, KSubModule1, KModule1, KSubModule2);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    52
	if (ret != KErrRSModuleNotLoaded)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    53
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    54
		INFO_PRINTF2(_L("LoadProvider returned error: <%d> "), asynchHandler->iStatus.Int());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    55
		SetTestStepResult(EFail);		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    56
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    57
	// uninstall and destroy active scheduler
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    58
	CleanupStack::PopAndDestroy(asynchHandler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    59
	CleanupStack::PopAndDestroy(scheduler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    60
	return TestStepResult();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    61
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    62
	}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    63
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    64
	// Test step 6.2 - Bind loaded to unloaded
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    65
CRootServerTest6_2::CRootServerTest6_2(CTE_RootServerServer *aSuite) : CTestStepRootServer(aSuite)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    66
{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    67
	// store the name of this test case
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    68
	SetTestStepName(_L("Test6.2"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    69
}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    70
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    71
TVerdict CRootServerTest6_2::doTestStepL( void )
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    72
	{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    73
	INFO_PRINTF1(_L("Test Purpose: Bind loaded to unloaded"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    74
										SetTestStepResult(EPass);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    75
	// Create scheduler/active object framework 
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    76
	CSelfPopScheduler* scheduler = CSelfPopScheduler::CreateLC();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    77
    CTestAsynchHandler* asynchHandler = CTestAsynchHandler::NewLC(&iRootServerSuite->RootSess());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    78
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    79
	//*****************step 02*************************//
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    80
	INFO_PRINTF1(_L("02 Load Test Module"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    81
	LoadNormalModuleL(asynchHandler, KModule1);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    82
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    83
	//*****************step 3************************
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    84
	INFO_PRINTF1(_L("03 Attempting bind"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    85
	TInt ret = TryHierachicalBind(asynchHandler, KModule1, KSubModule1, KModule2, KSubModule1);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    86
	if (ret != KErrRSModuleNotLoaded)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    87
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    88
		INFO_PRINTF2(_L("Bind returned error: <%d> "), ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    89
		SetTestStepResult(EFail);		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    90
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    91
	// uninstall and destroy active scheduler
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    92
	CleanupStack::PopAndDestroy(asynchHandler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    93
	CleanupStack::PopAndDestroy(scheduler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    94
	return TestStepResult();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    95
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    96
	}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    97
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    98
CRootServerTest6_BindWithinModule::CRootServerTest6_BindWithinModule(CTE_RootServerServer *aSuite) : CTestStepRootServer(aSuite)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
    99
	{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   100
	}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   101
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   102
TVerdict CRootServerTest6_BindWithinModule::BindWithinModuleL(TThreadPriority aPriority)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   103
	{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   104
										SetTestStepResult(EPass);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   105
	// Create scheduler/active object framework 
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   106
	CSelfPopScheduler* scheduler = CSelfPopScheduler::CreateLC();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   107
    CTestAsynchHandler* asynchHandler = CTestAsynchHandler::NewLC(&iRootServerSuite->RootSess());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   108
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   109
	//*****************step 01*************************//
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   110
	INFO_PRINTF1(_L("01 Load Test Module"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   111
	LoadNormalModuleL(asynchHandler, KModule1, aPriority);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   112
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   113
	//*****************step 2***********************
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   114
	INFO_PRINTF1(_L("02 Attempting Bind"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   115
	TInt ret = TryHierachicalBind(asynchHandler, KModule1, KSubModule1, KModule1, KSubModule2);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   116
	if (ret != KErrNone)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   117
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   118
		INFO_PRINTF2(_L("Bind returned error: <%d> "), ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   119
		SetTestStepResult(EFail);		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   120
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   121
	// uninstall and destroy active scheduler
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   122
	CleanupStack::PopAndDestroy(asynchHandler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   123
	CleanupStack::PopAndDestroy(scheduler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   124
	return TestStepResult();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   125
	}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   126
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   127
// Test step 6.3 - Bind within a module (normal priority)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   128
CRootServerTest6_3::CRootServerTest6_3(CTE_RootServerServer *aSuite) : CRootServerTest6_BindWithinModule(aSuite)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   129
{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   130
	// store the name of this test case
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   131
	SetTestStepName(_L("Test6.3"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   132
}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   133
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   134
TVerdict CRootServerTest6_3::doTestStepL( void )
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   135
	{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   136
	INFO_PRINTF1(_L("Test Purpose: Bind within module (normal priority)"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   137
	return BindWithinModuleL(EPriorityNormal);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   138
	}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   139
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   140
// Test step 6.4 - Bind within a module (elevated priority)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   141
CRootServerTest6_4::CRootServerTest6_4(CTE_RootServerServer *aSuite) : CRootServerTest6_BindWithinModule(aSuite)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   142
{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   143
	// store the name of this test case
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   144
	SetTestStepName(_L("Test6.4"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   145
}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   146
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   147
TVerdict CRootServerTest6_4::doTestStepL( void )
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   148
	{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   149
	INFO_PRINTF1(_L("Test Purpose: Bind within module (elevated priority)"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   150
	return BindWithinModuleL(EPriorityRealTime);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   151
	}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   152
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   153
// Test step 6.5 - Bind submodule to itself
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   154
CRootServerTest6_5::CRootServerTest6_5(CTE_RootServerServer *aSuite) : CTestStepRootServer(aSuite)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   155
{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   156
	// store the name of this test case
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   157
	SetTestStepName(_L("Test6.5"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   158
}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   159
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   160
TVerdict CRootServerTest6_5::doTestStepL( void )
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   161
	{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   162
	INFO_PRINTF1(_L("Test Purpose: Bind submodule to itself"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   163
										SetTestStepResult(EPass);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   164
	// Create scheduler/active object framework 
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   165
	CSelfPopScheduler* scheduler = CSelfPopScheduler::CreateLC();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   166
    CTestAsynchHandler* asynchHandler = CTestAsynchHandler::NewLC(&iRootServerSuite->RootSess());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   167
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   168
	//*****************step 01*************************//
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   169
	INFO_PRINTF1(_L("01 Load Test Module"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   170
	LoadNormalModuleL(asynchHandler, KModule1);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   171
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   172
	//*****************step 2***********************
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   173
	INFO_PRINTF1(_L("02 Attempting Bind"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   174
	TInt ret = TryHierachicalBind(asynchHandler, KModule1, KSubModule1, KModule1, KSubModule1);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   175
	if (ret != KErrNone)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   176
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   177
		INFO_PRINTF2(_L("Bind returned error: <%d> "), ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   178
		SetTestStepResult(EFail);		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   179
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   180
	// uninstall and destroy active scheduler
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   181
	CleanupStack::PopAndDestroy(asynchHandler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   182
	CleanupStack::PopAndDestroy(scheduler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   183
	return TestStepResult();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   184
	}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   185
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   186
// Test step 6.6 - Bind already bound
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   187
CRootServerTest6_6::CRootServerTest6_6(CTE_RootServerServer *aSuite) : CTestStepRootServer(aSuite)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   188
{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   189
	// store the name of this test case
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   190
	SetTestStepName(_L("Test6.6"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   191
}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   192
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   193
TVerdict CRootServerTest6_6::doTestStepL( void )
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   194
	{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   195
	INFO_PRINTF1(_L("Test Purpose: Bind again"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   196
										SetTestStepResult(EPass);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   197
	// Create scheduler/active object framework 
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   198
	CSelfPopScheduler* scheduler = CSelfPopScheduler::CreateLC();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   199
    CTestAsynchHandler* asynchHandler = CTestAsynchHandler::NewLC(&iRootServerSuite->RootSess());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   200
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   201
	//*****************step 01*************************//
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   202
	INFO_PRINTF1(_L("01 Load Test Module"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   203
	LoadNormalModuleL(asynchHandler, KModule1);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   204
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   205
	//*****************step 2************************
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   206
	INFO_PRINTF1(_L("02 Bind internally"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   207
	TInt ret = TryHierachicalBind(asynchHandler, KModule1, KSubModule1, KModule1, KSubModule2);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   208
	if (ret != KErrNone)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   209
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   210
		INFO_PRINTF2(_L("Bind returned error: <%d> "), ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   211
		User::Leave(ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   212
		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   213
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   214
	//*****************step 3************************
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   215
	INFO_PRINTF1(_L("03 Bind Again"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   216
	ret = TryHierachicalBind(asynchHandler, KModule1, KSubModule1, KModule1, KSubModule2);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   217
	if (ret != KErrRSAlreadyBound)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   218
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   219
		INFO_PRINTF2(_L("Bind returned error: <%d> "), ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   220
		User::Leave(KErrGeneral);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   221
		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   222
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   223
	// uninstall and destroy active scheduler
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   224
	CleanupStack::PopAndDestroy(asynchHandler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   225
	CleanupStack::PopAndDestroy(scheduler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   226
	return TestStepResult();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   227
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   228
	}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   229
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   230
// Test step 6.7 - Enumerate BindInfo
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   231
CRootServerTest6_7::CRootServerTest6_7(CTE_RootServerServer *aSuite) : CTestStepRootServer(aSuite)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   232
{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   233
	// store the name of this test case
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   234
	SetTestStepName(_L("Test6.7"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   235
}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   236
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   237
TVerdict CRootServerTest6_7::doTestStepL( void )
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   238
	{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   239
	TCFSubModuleAddress fullName1;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   240
	fullName1.SetModule(KModule1());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   241
	fullName1.SetSubModule(KSubModule1());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   242
	TCFSubModuleAddress fullName2;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   243
	fullName2.SetModule(KModule1());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   244
	fullName2.SetSubModule(KSubModule2());	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   245
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   246
	INFO_PRINTF1(_L("Test Purpose: Enumerate BindInfo"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   247
										SetTestStepResult(EPass);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   248
	// Create scheduler/active object framework 
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   249
	CSelfPopScheduler* scheduler = CSelfPopScheduler::CreateLC();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   250
    CTestAsynchHandler* asynchHandler = CTestAsynchHandler::NewLC(&iRootServerSuite->RootSess());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   251
	//*****************step 01*************************//
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   252
	INFO_PRINTF1(_L("01 Load Test Module"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   253
	LoadNormalModuleL(asynchHandler, KModule1);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   254
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   255
	//*****************step 2************************
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   256
	INFO_PRINTF1(_L("02 Bind internally"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   257
	TInt ret = TryHierachicalBind(asynchHandler, KModule1, KSubModule1, KModule1, KSubModule2);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   258
	if (ret != KErrNone)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   259
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   260
		INFO_PRINTF2(_L("Bind returned error: <%d> "), ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   261
		User::Leave(ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   262
		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   263
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   264
	TRSBindingInfo bindInfo;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   265
	TRSIter position;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   266
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   267
	//*****************step 2************************
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   268
	INFO_PRINTF1(_L("02 Enumerate bindings"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   269
	ret = iRootServerSuite->RootSess().EnumerateBindings(fullName1, position, bindInfo);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   270
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   271
	INFO_PRINTF2(_L("Enumerate returned %d"), ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   272
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   273
	if (KErrNone != ret)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   274
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   275
		SetTestStepResult(EFail);		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   276
	else
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   277
		{		
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   278
		if ( (bindInfo.iParams.iAddress1 == fullName1) && (bindInfo.iParams.iAddress2 == fullName2) )
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   279
			{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   280
			INFO_PRINTF1(_L("Binding Found") );
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   281
			}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   282
		else if ( (bindInfo.iParams.iAddress1 == fullName2) && (bindInfo.iParams.iAddress2 == fullName1) )
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   283
			{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   284
			INFO_PRINTF1(_L("Binding Found") );
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   285
			}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   286
		else
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   287
			{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   288
			INFO_PRINTF1(_L("Binding not found"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   289
			SetTestStepResult(EFail);			}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   290
		ret = iRootServerSuite->RootSess().EnumerateBindings(fullName1, position, bindInfo);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   291
		INFO_PRINTF2(_L("Follow-up Enumerate returned %d"), ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   292
		if(KErrEof != ret)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   293
			{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   294
			INFO_PRINTF1(_L("(should have returned KErrEof"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   295
			SetTestStepResult(EFail);			}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   296
		ret = iRootServerSuite->RootSess().EnumerateBindings(fullName1, position, bindInfo);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   297
		INFO_PRINTF2(_L("Further Enumerate returned %d"), ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   298
		if(KErrEof != ret)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   299
			{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   300
			INFO_PRINTF1(_L("(should have returned KErrEof"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   301
			SetTestStepResult(EFail);			}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   302
		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   303
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   304
	// uninstall and destroy active scheduler
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   305
	CleanupStack::PopAndDestroy(asynchHandler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   306
	CleanupStack::PopAndDestroy(scheduler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   307
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   308
	return TestStepResult();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   309
	}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   310
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   311
CRootServerTest6_UnbindWithinModule::CRootServerTest6_UnbindWithinModule(CTE_RootServerServer *aSuite) : CTestStepRootServer(aSuite)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   312
	{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   313
	}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   314
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   315
TVerdict CRootServerTest6_UnbindWithinModule::UnbindWithinModuleL(TThreadPriority aPriority)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   316
	{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   317
										SetTestStepResult(EPass);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   318
	// Create scheduler/active object framework 
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   319
	CSelfPopScheduler* scheduler = CSelfPopScheduler::CreateLC();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   320
    CTestAsynchHandler* asynchHandler = CTestAsynchHandler::NewLC(&iRootServerSuite->RootSess());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   321
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   322
	//*****************step 01*************************//
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   323
	INFO_PRINTF1(_L("01 Load Test Module"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   324
	LoadNormalModuleL(asynchHandler, KModule1, aPriority);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   325
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   326
	//*****************step 2************************
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   327
	INFO_PRINTF1(_L("02 Bind internally"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   328
	TInt ret = TryHierachicalBind(asynchHandler, KModule1, KSubModule1, KModule1, KSubModule2);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   329
	if (ret != KErrNone)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   330
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   331
		INFO_PRINTF2(_L("Bind returned error: <%d> "), ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   332
		User::Leave(ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   333
		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   334
	//*****************step 3************************
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   335
	INFO_PRINTF1(_L("03 Unbind"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   336
	TRSUnBindingInfo unbindInfo;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   337
	unbindInfo.iParams.iAddress1.SetModule(KModule1());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   338
	unbindInfo.iParams.iAddress1.SetSubModule(KSubModule1());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   339
	unbindInfo.iParams.iAddress2.SetModule(KModule1());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   340
	unbindInfo.iParams.iAddress2.SetSubModule(KSubModule2());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   341
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   342
    asynchHandler->TryUnBind( unbindInfo );
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   343
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   344
	CActiveScheduler::Start();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   345
	if (asynchHandler->iStatus != KErrNone)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   346
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   347
		INFO_PRINTF2(_L("Unbind returned error: <%d> "), asynchHandler->iStatus.Int());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   348
		SetTestStepResult(EFail);		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   349
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   350
	INFO_PRINTF1(_L("04 Duplicate Unbind"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   351
    asynchHandler->TryUnBind( unbindInfo );
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   352
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   353
	CActiveScheduler::Start();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   354
	if (asynchHandler->iStatus != KErrRSBindingUnknown)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   355
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   356
		INFO_PRINTF2(_L("Duplicate Unbind returned error: <%d> "), asynchHandler->iStatus.Int());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   357
		SetTestStepResult(EFail);		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   358
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   359
	// uninstall and destroy active scheduler
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   360
	CleanupStack::PopAndDestroy(asynchHandler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   361
	CleanupStack::PopAndDestroy(scheduler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   362
	return TestStepResult();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   363
	}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   364
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   365
// Test step 6.8 - Unbind within Module (normal priority)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   366
CRootServerTest6_8::CRootServerTest6_8(CTE_RootServerServer *aSuite) : CRootServerTest6_UnbindWithinModule(aSuite)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   367
{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   368
	// store the name of this test case
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   369
	SetTestStepName(_L("Test6.8"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   370
}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   371
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   372
TVerdict CRootServerTest6_8::doTestStepL( void )
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   373
	{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   374
	INFO_PRINTF1(_L("Test Purpose: UnBind within Module (elevated priority)"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   375
	return UnbindWithinModuleL(EPriorityNormal);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   376
	}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   377
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   378
// Test step 6.9 - Unbind within Module (normal priority)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   379
CRootServerTest6_9::CRootServerTest6_9(CTE_RootServerServer *aSuite) : CRootServerTest6_UnbindWithinModule(aSuite)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   380
{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   381
	// store the name of this test case
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   382
	SetTestStepName(_L("Test6.9"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   383
}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   384
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   385
TVerdict CRootServerTest6_9::doTestStepL( void )
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   386
	{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   387
	INFO_PRINTF1(_L("Test Purpose: UnBind within Module (elevated priority)"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   388
	return UnbindWithinModuleL(EPriorityRealTime);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   389
	}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   390
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   391
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   392
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   393
// Test step 6.10 - Cancel Bind
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   394
CRootServerTest6_10::CRootServerTest6_10(CTE_RootServerServer *aSuite) : CTestStepRootServer(aSuite)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   395
{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   396
	// store the name of this test case
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   397
	SetTestStepName(_L("Test6.10"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   398
}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   399
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   400
TVerdict CRootServerTest6_10::doTestStepL( void )
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   401
	{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   402
	INFO_PRINTF1(_L("Test Purpose: Cancel bind"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   403
										SetTestStepResult(EPass);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   404
	// Create scheduler/active object framework 
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   405
	CSelfPopScheduler* scheduler = CSelfPopScheduler::CreateLC();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   406
    CTestAsynchHandler* asynchHandler = CTestAsynchHandler::NewLC(&iRootServerSuite->RootSess());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   407
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   408
	//*****************step 01*************************//
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   409
	INFO_PRINTF1(_L("01 Load Test Module"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   410
	LoadNormalModuleL(asynchHandler, KModule1);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   411
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   412
	//*****************step 2************************
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   413
	INFO_PRINTF1(_L("02 Attempting bind"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   414
	TRSBindingInfo bindInfo;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   415
	bindInfo.iParams.iType = EHierarchical;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   416
	bindInfo.iParams.iAddress1.SetModule(KModule1());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   417
	bindInfo.iParams.iAddress1.SetSubModule(KSubModule1());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   418
	bindInfo.iParams.iAddress2.SetModule(KModule1());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   419
	bindInfo.iParams.iAddress2.SetSubModule(KSubModule2());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   420
	bindInfo.iParams.iState1 = KErrNone;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   421
	bindInfo.iParams.iState2 = KErrNone;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   422
	bindInfo.iParams.iForwardQLength = TRSBindingInfo::EMinQueueLength;	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   423
	bindInfo.iParams.iReverseQLength = TRSBindingInfo::EMinQueueLength;	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   424
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   425
	TRSSubModuleAddress name1(bindInfo.iParams.iAddress1);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   426
	TRSSubModuleAddress name2(bindInfo.iParams.iAddress2);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   427
		
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   428
	asynchHandler->TryBind( bindInfo );
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   429
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   430
	//*****************step 3************************
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   431
	INFO_PRINTF1(_L("04 Wait for bind to be completed"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   432
	User::After(1000000);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   433
	//*****************step 4************************
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   434
	INFO_PRINTF1(_L("04 Cancelling Bind"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   435
	iRootServerSuite->RootSess().CancelBind(name1, name2);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   436
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   437
	CActiveScheduler::Start();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   438
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   439
	if (asynchHandler->iStatus != KErrNone)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   440
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   441
		INFO_PRINTF2(_L("Bind returned error: <%d> "), asynchHandler->iStatus.Int());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   442
		SetTestStepResult(EFail);		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   443
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   444
	// uninstall and destroy active scheduler
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   445
	CleanupStack::PopAndDestroy(asynchHandler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   446
	CleanupStack::PopAndDestroy(scheduler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   447
	return TestStepResult();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   448
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   449
	}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   450
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   451
// Test step 6.11 - Cancel UnBind
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   452
CRootServerTest6_11::CRootServerTest6_11(CTE_RootServerServer *aSuite) : CTestStepRootServer(aSuite)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   453
{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   454
	// store the name of this test case
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   455
	SetTestStepName(_L("Test6.11"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   456
}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   457
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   458
TVerdict CRootServerTest6_11::doTestStepL( void )
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   459
	{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   460
	INFO_PRINTF1(_L("Test Purpose: Cancel Unbind"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   461
										SetTestStepResult(EPass);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   462
	// Create scheduler/active object framework 
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   463
	CSelfPopScheduler* scheduler = CSelfPopScheduler::CreateLC();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   464
    CTestAsynchHandler* asynchHandler = CTestAsynchHandler::NewLC(&iRootServerSuite->RootSess());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   465
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   466
	//*****************step 01*************************//
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   467
	INFO_PRINTF1(_L("01 Load Test Module"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   468
	LoadNormalModuleL(asynchHandler, KModule1);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   469
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   470
	//*****************step 2************************
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   471
	INFO_PRINTF1(_L("02 Bind internally"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   472
	TInt ret = TryHierachicalBind(asynchHandler, KModule1, KSubModule1, KModule1, KSubModule2);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   473
	if (ret != KErrNone)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   474
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   475
		INFO_PRINTF2(_L("Bind returned error: <%d> "), ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   476
		User::Leave(ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   477
		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   478
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   479
	//*****************step 3************************
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   480
	INFO_PRINTF1(_L("03 Unbind"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   481
	TRSUnBindingInfo unbindInfo;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   482
	unbindInfo.iParams.iAddress1.SetModule(KModule1());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   483
	unbindInfo.iParams.iAddress1.SetSubModule(KSubModule1());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   484
	unbindInfo.iParams.iAddress2.SetModule(KModule1());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   485
	unbindInfo.iParams.iAddress2.SetSubModule(KSubModule2());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   486
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   487
	TRSSubModuleAddress name1(unbindInfo.iParams.iAddress1);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   488
	TRSSubModuleAddress name2(unbindInfo.iParams.iAddress2);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   489
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   490
    asynchHandler->TryUnBind( unbindInfo );
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   491
    
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   492
    //*****************step 4************************
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   493
	INFO_PRINTF1(_L("04 Wait for unbind to be completed"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   494
 	User::After(1000000);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   495
	//*****************step 5************************
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   496
   INFO_PRINTF1(_L("05 Cancelling UnBind"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   497
	iRootServerSuite->RootSess().CancelUnbind(name1, name2);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   498
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   499
	CActiveScheduler::Start();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   500
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   501
	if (asynchHandler->iStatus != KErrNone)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   502
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   503
		INFO_PRINTF2(_L("Unbind returned error: <%d> "), asynchHandler->iStatus.Int());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   504
		SetTestStepResult(EFail);		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   505
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   506
	// uninstall and destroy active scheduler
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   507
	CleanupStack::PopAndDestroy(asynchHandler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   508
	CleanupStack::PopAndDestroy(scheduler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   509
	return TestStepResult();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   510
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   511
	}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   512
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   513
// Test step 6.12 - Bind sluggish cpm
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   514
CRootServerTest6_12::CRootServerTest6_12(CTE_RootServerServer *aSuite) : CTestStepRootServer(aSuite)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   515
{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   516
	// store the name of this test case
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   517
	SetTestStepName(_L("Test6.12"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   518
}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   519
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   520
TVerdict CRootServerTest6_12::doTestStepL( void )
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   521
	{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   522
	INFO_PRINTF1(_L("Test Purpose: Bind sluggish cpm"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   523
										SetTestStepResult(EPass);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   524
	// Create scheduler/active object framework 
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   525
	CSelfPopScheduler* scheduler = CSelfPopScheduler::CreateLC();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   526
    CTestAsynchHandler* asynchHandler = CTestAsynchHandler::NewLC(&iRootServerSuite->RootSess());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   527
    
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   528
	TRSStartModuleParams startParams;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   529
	TTestModuleIniData iniData;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   530
	DefaultStartParams(startParams, iniData);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   531
	startParams.iParams.iName = KModule1;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   532
	iniData.iParams.iDiscoveryDelay = 500;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   533
	iniData.iParams.iBindDelay = 500;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   534
	iniData.iParams.iUnbindDelay = 500;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   535
	iniData.iParams.iShutdownDelay = 500;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   536
	asynchHandler->TryLoad(startParams, iniData);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   537
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   538
    CActiveScheduler::Start();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   539
   	if (asynchHandler->iStatus != KErrNone)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   540
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   541
		INFO_PRINTF2(_L("LoadServer returned error: <%d> "), asynchHandler->iStatus.Int());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   542
		User::Leave(asynchHandler->iStatus.Int());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   543
		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   544
    //*****************step 02*************************//
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   545
	INFO_PRINTF1(_L("02 Attempting bind"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   546
	TInt ret = TryHierachicalBind(asynchHandler, KModule1, KSubModule1, KModule1, KSubModule2);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   547
	if (ret != KErrNone)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   548
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   549
		INFO_PRINTF2(_L("Bind returned error: <%d> "), ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   550
		SetTestStepResult(EFail);		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   551
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   552
	// uninstall and destroy active scheduler
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   553
	CleanupStack::PopAndDestroy(asynchHandler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   554
	CleanupStack::PopAndDestroy(scheduler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   555
	return TestStepResult();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   556
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   557
	}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   558
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   559
// Test step 6.13 - Bind dormant cpm
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   560
CRootServerTest6_13::CRootServerTest6_13(CTE_RootServerServer *aSuite) : CTestStepRootServer(aSuite)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   561
{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   562
	// store the name of this test case
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   563
	SetTestStepName(_L("Test6.13"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   564
}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   565
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   566
TVerdict CRootServerTest6_13::doTestStepL( void )
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   567
	{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   568
	INFO_PRINTF1(_L("Test Purpose: Bind dormant cpm"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   569
										SetTestStepResult(EPass);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   570
	// Create scheduler/active object framework 
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   571
	CSelfPopScheduler* scheduler = CSelfPopScheduler::CreateLC();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   572
    CTestAsynchHandler* asynchHandler = CTestAsynchHandler::NewLC(&iRootServerSuite->RootSess());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   573
    
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   574
       //*****************step 02*************************//
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   575
	INFO_PRINTF1(_L("02 Load Dormant Test CPM"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   576
	TRSStartModuleParams startParams;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   577
	TTestModuleIniData iniData;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   578
	DefaultStartParams(startParams, iniData);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   579
	startParams.iParams.iName = KModule1;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   580
	iniData.iParams.iDiscoveryDelay = 500;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   581
	iniData.iParams.iBindDelay = 30000;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   582
	iniData.iParams.iUnbindDelay = 30000;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   583
	iniData.iParams.iShutdownDelay = 1000;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   584
	asynchHandler->TryLoad(startParams, iniData);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   585
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   586
    CActiveScheduler::Start();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   587
   	if (asynchHandler->iStatus != KErrNone)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   588
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   589
		INFO_PRINTF2(_L("LoadServer returned error: <%d> "), asynchHandler->iStatus.Int());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   590
		User::Leave(asynchHandler->iStatus.Int());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   591
		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   592
    //*****************step 02*************************//
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   593
	INFO_PRINTF1(_L("02 Attempting bind"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   594
	TInt ret = TryHierachicalBind(asynchHandler, KModule1, KSubModule1, KModule1, KSubModule2);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   595
	if (ret != KErrRSRequestTimedOut)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   596
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   597
		INFO_PRINTF2(_L("Bind returned error: <%d> "), ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   598
		SetTestStepResult(EFail);		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   599
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   600
	// uninstall and destroy active scheduler
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   601
	CleanupStack::PopAndDestroy(asynchHandler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   602
	CleanupStack::PopAndDestroy(scheduler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   603
	return TestStepResult();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   604
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   605
	}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   606
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   607
// Test step 6.14 - UnBind sluggish test cpm
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   608
CRootServerTest6_14::CRootServerTest6_14(CTE_RootServerServer *aSuite) : CTestStepRootServer(aSuite)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   609
{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   610
	// store the name of this test case
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   611
	SetTestStepName(_L("Test6.14"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   612
}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   613
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   614
TVerdict CRootServerTest6_14::doTestStepL( void )
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   615
	{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   616
	INFO_PRINTF1(_L("Test Purpose: Unbind sluggish test cpm"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   617
										SetTestStepResult(EPass);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   618
	// Create scheduler/active object framework 
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   619
	CSelfPopScheduler* scheduler = CSelfPopScheduler::CreateLC();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   620
    CTestAsynchHandler* asynchHandler = CTestAsynchHandler::NewLC(&iRootServerSuite->RootSess());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   621
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   622
	TRSStartModuleParams startParams;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   623
	TTestModuleIniData iniData;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   624
	DefaultStartParams(startParams, iniData);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   625
	startParams.iParams.iName = KModule1;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   626
	iniData.iParams.iDiscoveryDelay = 500;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   627
	iniData.iParams.iBindDelay = 500;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   628
	iniData.iParams.iUnbindDelay = 500;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   629
	iniData.iParams.iShutdownDelay = 500;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   630
	asynchHandler->TryLoad(startParams, iniData);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   631
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   632
    CActiveScheduler::Start();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   633
   	if (asynchHandler->iStatus != KErrNone)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   634
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   635
		INFO_PRINTF2(_L("LoadServer returned error: <%d> "), asynchHandler->iStatus.Int());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   636
		User::Leave(asynchHandler->iStatus.Int());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   637
		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   638
    //*****************step 02*************************//
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   639
	INFO_PRINTF1(_L("02 Attempting bind"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   640
	TInt ret = TryHierachicalBind(asynchHandler, KModule1, KSubModule1, KModule1, KSubModule2);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   641
	if (ret != KErrNone)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   642
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   643
		INFO_PRINTF2(_L("Bind returned error: <%d> "), ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   644
		User::Leave(asynchHandler->iStatus.Int());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   645
		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   646
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   647
	INFO_PRINTF1(_L("03 Unbind"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   648
	TRSUnBindingInfo unbindInfo;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   649
	unbindInfo.iParams.iAddress1.SetModule(KModule1());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   650
	unbindInfo.iParams.iAddress1.SetSubModule(KSubModule1());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   651
	unbindInfo.iParams.iAddress2.SetModule(KModule1());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   652
	unbindInfo.iParams.iAddress2.SetSubModule(KSubModule2());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   653
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   654
    asynchHandler->TryUnBind( unbindInfo );
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   655
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   656
	CActiveScheduler::Start();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   657
	if (asynchHandler->iStatus != KErrNone)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   658
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   659
		INFO_PRINTF2(_L("Unbind returned error: <%d> "), asynchHandler->iStatus.Int());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   660
		SetTestStepResult(EFail);		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   661
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   662
	// uninstall and destroy active scheduler
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   663
	CleanupStack::PopAndDestroy(asynchHandler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   664
	CleanupStack::PopAndDestroy(scheduler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   665
	return TestStepResult();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   666
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   667
	}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   668
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   669
	
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   670
// Test step 6.15 - UnBind dormant test cpm
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   671
CRootServerTest6_15::CRootServerTest6_15(CTE_RootServerServer *aSuite) : CTestStepRootServer(aSuite)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   672
{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   673
	// store the name of this test case
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   674
	SetTestStepName(_L("Test6.15"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   675
}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   676
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   677
TVerdict CRootServerTest6_15::doTestStepL( void )
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   678
	{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   679
	INFO_PRINTF1(_L("Test Purpose: Unbind dormant test cpm"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   680
										SetTestStepResult(EPass);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   681
	// Create scheduler/active object framework 
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   682
	CSelfPopScheduler* scheduler = CSelfPopScheduler::CreateLC();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   683
    CTestAsynchHandler* asynchHandler = CTestAsynchHandler::NewLC(&iRootServerSuite->RootSess());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   684
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   685
	TRSStartModuleParams startParams;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   686
	TTestModuleIniData iniData;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   687
	DefaultStartParams(startParams, iniData);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   688
	startParams.iParams.iName = KModule1;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   689
	iniData.iParams.iDiscoveryDelay = 500;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   690
	iniData.iParams.iBindDelay = 500;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   691
	iniData.iParams.iUnbindDelay = 30000;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   692
	iniData.iParams.iShutdownDelay = 500;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   693
	asynchHandler->TryLoad(startParams, iniData);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   694
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   695
    CActiveScheduler::Start();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   696
   	if (asynchHandler->iStatus != KErrNone)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   697
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   698
		INFO_PRINTF2(_L("LoadServer returned error: <%d> "), asynchHandler->iStatus.Int());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   699
		User::Leave(asynchHandler->iStatus.Int());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   700
		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   701
    //*****************step 02*************************//
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   702
	INFO_PRINTF1(_L("02 Attempting bind"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   703
	TInt ret = TryHierachicalBind(asynchHandler, KModule1, KSubModule1, KModule1, KSubModule2);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   704
	if (ret != KErrNone)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   705
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   706
		INFO_PRINTF2(_L("Bind returned error: <%d> "), ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   707
		User::Leave(asynchHandler->iStatus.Int());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   708
		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   709
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   710
	INFO_PRINTF1(_L("03 Unbind"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   711
	TRSUnBindingInfo unbindInfo;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   712
	unbindInfo.iParams.iAddress1.SetModule(KModule1());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   713
	unbindInfo.iParams.iAddress1.SetSubModule(KSubModule1());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   714
	unbindInfo.iParams.iAddress2.SetModule(KModule1());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   715
	unbindInfo.iParams.iAddress2.SetSubModule(KSubModule2());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   716
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   717
    asynchHandler->TryUnBind( unbindInfo );
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   718
	CActiveScheduler::Start();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   719
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   720
	if (asynchHandler->iStatus != KErrRSRequestTimedOut)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   721
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   722
		INFO_PRINTF2(_L("Unbind returned error: <%d> "), asynchHandler->iStatus.Int());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   723
		SetTestStepResult(EFail);		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   724
	// uninstall and destroy active scheduler
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   725
	CleanupStack::PopAndDestroy(asynchHandler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   726
	CleanupStack::PopAndDestroy(scheduler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   727
	return TestStepResult();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   728
	}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   729
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   730
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   731
// Test step 6.16 - Bind between a server and a module
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   732
CRootServerTest6_16::CRootServerTest6_16(CTE_RootServerServer *aSuite) : CTestStepRootServer(aSuite)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   733
{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   734
	// store the name of this test case
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   735
	SetTestStepName(_L("Test6.16"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   736
}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   737
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   738
TVerdict CRootServerTest6_16::doTestStepL( void )
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   739
	{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   740
	INFO_PRINTF1(_L("Test Purpose: Bind between a server and a module"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   741
										SetTestStepResult(EPass);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   742
	// Create scheduler/active object framework 
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   743
	CSelfPopScheduler* scheduler = CSelfPopScheduler::CreateLC();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   744
    CTestAsynchHandler* asynchHandler = CTestAsynchHandler::NewLC(&iRootServerSuite->RootSess());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   745
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   746
	_LIT8(KPlainModule, "PlainCPM");
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   747
	_LIT8(KServerModule, "ServerCPM");
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   748
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   749
	//*****************step 01*************************//
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   750
	INFO_PRINTF1(_L("01 Load Plain Module"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   751
	LoadNormalModuleL(asynchHandler, KPlainModule);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   752
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   753
	//*****************step 02*************************//
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   754
	INFO_PRINTF1(_L("02 Load Server Module"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   755
	TRSStartModuleParams startParams;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   756
	TTestModuleIniData iniData;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   757
	DefaultStartParams(startParams, iniData);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   758
	startParams.iParams.iName = KServerModule;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   759
	startParams.iParams.iIsServer = ETrue;
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   760
	asynchHandler->TryLoad(startParams, iniData);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   761
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   762
    CActiveScheduler::Start();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   763
   	if (asynchHandler->iStatus != KErrNone)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   764
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   765
		INFO_PRINTF2(_L("LoadServer returned error: <%d> "), asynchHandler->iStatus.Int());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   766
		User::Leave(asynchHandler->iStatus.Int());
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   767
		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   768
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   769
    //*****************step 03*************************//
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   770
	INFO_PRINTF1(_L("03 Attempting bind of plain above server"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   771
	TInt ret = TryHierachicalBind(asynchHandler, KPlainModule, KSubModule1, KServerModule, KSubModule1);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   772
	if (ret != KErrRSInvalidBinding)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   773
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   774
		INFO_PRINTF2(_L("Bind returned error: <%d> "), ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   775
		User::Leave(ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   776
		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   777
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   778
	//*****************step 04***********************
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   779
	INFO_PRINTF1(_L("04 Attempting bind of server above plain"));
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   780
	ret = TryHierachicalBind(asynchHandler, KServerModule, KSubModule1, KPlainModule, KSubModule1);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   781
	if (ret != KErrNone)
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   782
		{
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   783
		INFO_PRINTF2(_L("Bind returned error: <%d> "), ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   784
		User::Leave(ret);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   785
		}
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   786
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   787
	// uninstall and destroy active scheduler
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   788
	CleanupStack::PopAndDestroy(asynchHandler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   789
	CleanupStack::PopAndDestroy(scheduler);
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   790
	return TestStepResult();
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   791
ae47d0499bee 201033_02
hgs
parents:
diff changeset
   792
	}