kerneltest/e32test/domainmgr/t_domain.cpp
author hgs
Mon, 04 Oct 2010 12:03:52 +0100
changeset 279 957c583b417b
parent 269 d57b86b1867a
child 286 48e57fb1237e
permissions -rw-r--r--
201039_07
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
269
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
     1
// Copyright (c) 2002-2010 Nokia Corporation and/or its subsidiary(-ies).
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
     2
// All rights reserved.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
647ab20fee2e 201031_10
hgs
parents:
diff changeset
     4
// under the terms of the License "Eclipse Public License v1.0"
647ab20fee2e 201031_10
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
647ab20fee2e 201031_10
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
647ab20fee2e 201031_10
hgs
parents:
diff changeset
     7
//
647ab20fee2e 201031_10
hgs
parents:
diff changeset
     8
// Initial Contributors:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    10
//
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    11
// Contributors:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    12
//
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    13
// Description:
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
    14
// e32test/domainmgr/t_domain.cpp
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    15
// Overview:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    16
// Domain manager tests
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    17
// API Information:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    18
// RDmDomain, RDmDomainManager CDmDomain, CDmDomainManager
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    19
// Details:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    20
// - Test a variety of domain transitions, check the expected number of
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    21
// notifications and the first expected ordinal. Verify results are
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    22
// as expected.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    23
// - Test system standby, check the expected number of notifications and 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    24
// the first expected ordinal. Use a timer to request a wakeup event.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    25
// Verify results are as expected.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    26
// - Test domain related simple error situations, verify results are
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    27
// as expected.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    28
// - Perform platform security tests: launch a separate process with no 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    29
// capabilities, verify that results are as expected.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    30
// - Test domain transitions by connecting to two domain hierarchies 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    31
// simultaneously, add some test and power hierarchy members, verify
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    32
// the expected target state, notifications and leaf nodes. Verify results.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    33
// - Verify that the same hierarchy can not be connected to more than once.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    34
// - Request a positive transition and request that the test domain use 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    35
// ETraverseParentsFirst. Verify results are as expected and verify 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    36
// domains are in the correct state.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    37
// - Request a negative transition and request that the test domain use 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    38
// ETraverseChildrenFirst. Verify results are as expected.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    39
// - Request a positive transition with zero acknowledgements. Verify 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    40
// results are as expected.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    41
// - Request a positive transition with error acknowledgements. Verify 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    42
// results are as expected.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    43
// - Perform a variety of negative tests and verify results are as expected.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    44
// - Perform various tests on domain transitions with activated observer.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    45
// Verify results are as expected.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    46
// Platforms/Drives/Compatibility:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    47
// All.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    48
// Assumptions/Requirement/Pre-requisites:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    49
// Failures and causes:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    50
// Base Port information:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    51
// 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    52
//
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    53
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
    54
#define __E32TEST_EXTENSION__
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    55
#include <e32test.h>
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    56
#include <e32debug.h>
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    57
#include <e32ldr_private.h>
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
    58
#include <domainobserver.h>
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    59
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
    60
#include "domainpolicytest.h"
957c583b417b 201039_07
hgs
parents: 269
diff changeset
    61
#include "t_domain.h"
957c583b417b 201039_07
hgs
parents: 269
diff changeset
    62
957c583b417b 201039_07
hgs
parents: 269
diff changeset
    63
957c583b417b 201039_07
hgs
parents: 269
diff changeset
    64
RTest test(_L(" T_DOMAIN "));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    65
_LIT(KThreadName, "t_domain_panic_thread");
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    66
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
    67
TDmHierarchyId GHierarchyIdUnderTest = 0;
957c583b417b 201039_07
hgs
parents: 269
diff changeset
    68
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    69
#ifdef _DEBUG
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    70
#define __PRINT(x) {RDebug::Print x;}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    71
#else
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    72
#define __PRINT(x) 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    73
#endif
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    74
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    75
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    76
class CDmTest1 : public CActive, public MDmTest
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    77
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    78
public: // from CActive
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    79
	void RunL();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    80
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    81
	// from MDmTest
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    82
	void Perform();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    83
	void Release();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    84
	TInt TransitionNotification(MDmDomainMember& aDomainMember);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    85
	void TransitionRequestComplete() {};
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    86
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    87
	CDmTest1 (TDmDomainId aId, TDmDomainState aState) : CActive(CActive::EPriorityStandard), iDomainId(aId), iState((TPowerState) aState) {}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    88
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    89
protected:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    90
	// from CActive
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    91
	virtual void DoCancel();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    92
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    93
private:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    94
	enum { KMembersMax = 16 };
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    95
	CDmTestMember*		iMembers[KMembersMax]; 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    96
	RDmDomainManager	iManager;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    97
	TDmDomainId			iDomainId;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    98
	TPowerState			iState;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
    99
	TBool				iAcknowledge;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   100
	TInt				iMembersCount;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   101
	TInt				iCount;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   102
	TUint32				iOrdinal;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   103
	};
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   104
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   105
void CDmTest1::Perform()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   106
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   107
	//
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   108
	// Test domain transitions
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   109
	//
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   110
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   111
	test.Next(_L("Test 1"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   112
	test.Printf(_L("Domain id = 0x%x Target State = 0x%x\n"), iDomainId, iState);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   113
	iMembers[0] = new CDmTestMember(KDmHierarchyIdPower, KDmIdRoot, 0, this);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   114
	test(iMembers[0] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   115
	iMembers[1] = new CDmTestMember(KDmHierarchyIdPower, KDmIdRoot, 0, this);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   116
	test(iMembers[1] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   117
	iMembers[2] = new CDmTestMember(KDmHierarchyIdPower, KDmIdApps, 1, this);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   118
	test(iMembers[2] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   119
	iMembers[3] = new CDmTestMember(KDmHierarchyIdPower, KDmIdApps, 1, this);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   120
	test(iMembers[3] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   121
	iMembers[4] = new CDmTestMember(KDmHierarchyIdPower, KDmIdUiApps, 1, this);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   122
	test(iMembers[4] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   123
	iMembers[5] = new CDmTestMember(KDmHierarchyIdPower, KDmIdUiApps, 1, this);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   124
	test(iMembers[5] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   125
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   126
	// expected number of notifications
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   127
	iMembersCount = (iDomainId == KDmIdRoot) ? 6 : 2;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   128
	// first expected ordinal
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   129
	iOrdinal = (iState == EPwActive) ? 0 : 1;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   130
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   131
	TInt r = iManager.Connect();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   132
	test(r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   133
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   134
	CActiveScheduler::Add(this);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   135
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   136
	iManager.RequestDomainTransition(iDomainId, iState, CActive::iStatus);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   137
	CActive::SetActive();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   138
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   139
	CActiveScheduler::Start();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   140
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   141
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   142
TInt CDmTest1::TransitionNotification(MDmDomainMember& aDomainMember)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   143
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   144
	++iCount;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   145
	if (aDomainMember.State() == EPwActive)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   146
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   147
		if(aDomainMember.Ordinal() < iOrdinal)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   148
			{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   149
			// Making the test to fail in RunL function inorder to complete the cleanup from domain manager.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   150
			test.Printf(_L("Making test to fail as Ordinal Mismatch Expected : %d, Returned : %d"), aDomainMember.Ordinal(), iOrdinal);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   151
			iCount--;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   152
			}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   153
		}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   154
	else
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   155
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   156
		if(aDomainMember.Ordinal() > iOrdinal)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   157
			{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   158
			//Making the test to fail in RunL function inorder to complete the cleanup from domain manager.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   159
			test.Printf(_L("Making test to fail as Ordinal Mismatch Expected : %d, Returned : %d"), aDomainMember.Ordinal(), iOrdinal);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   160
			iCount--;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   161
			}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   162
		}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   163
	iOrdinal = aDomainMember.Ordinal();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   164
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   165
	// acknowledge one from two
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   166
	iAcknowledge = !iAcknowledge;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   167
	return iAcknowledge?KErrNone:KErrGeneral;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   168
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   169
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   170
void CDmTest1::RunL()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   171
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   172
	CActiveScheduler::Stop();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   173
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   174
	iManager.Close();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   175
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   176
	CDmTestMember** mp;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   177
	for (mp = iMembers; *mp; ++mp)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   178
		delete *mp;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   179
	test(iCount == iMembersCount);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   180
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   181
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   182
void CDmTest1::DoCancel()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   183
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   184
	test(0);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   185
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   186
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   187
void CDmTest1::Release()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   188
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   189
	delete this;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   190
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   191
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   192
class CDmTest2Timer : public CTimer
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   193
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   194
public: // fomr CTimer
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   195
   void RunL();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   196
public:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   197
	CDmTest2Timer() : CTimer(0) 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   198
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   199
		TRAPD(r,
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   200
			ConstructL());
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   201
		test(r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   202
		CActiveScheduler::Add(this);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   203
		}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   204
	};
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   205
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   206
void CDmTest2Timer::RunL()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   207
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   208
	test.Printf(_L("Tick count after CDmTest2Timer::RunL() = %d\n"), User::NTickCount());
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   209
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   210
	// kick the timer again in case power down hasn't happened yet
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   211
	TTime wakeup;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   212
	wakeup.HomeTime();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   213
	wakeup += TTimeIntervalSeconds(3);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   214
	At(wakeup);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   215
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   216
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   217
class CDmTest2 : public CActive, public MDmTest
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   218
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   219
public: // from CActive
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   220
	void RunL();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   221
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   222
	// from MDmTest
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   223
	void Perform();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   224
	void Release();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   225
	TInt TransitionNotification(MDmDomainMember& aDomainMember);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   226
	void TransitionRequestComplete() {};
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   227
	CDmTest2 (TDmDomainState aState) : CActive(CActive::EPriorityStandard), iState((TPowerState) aState) {}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   228
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   229
protected:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   230
	// from CActive
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   231
	virtual void DoCancel();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   232
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   233
private:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   234
	enum { KMembersMax = 16 };
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   235
	CDmTestMember*		iMembers[KMembersMax]; 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   236
	RDmDomainManager	iManager;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   237
	TPowerState			iState;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   238
	TBool				iAcknowledge;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   239
	TInt				iMembersCount;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   240
	TInt				iCount;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   241
	TUint32				iOrdinal;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   242
	CDmTest2Timer*		iTimer;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   243
	};
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   244
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   246
void CDmTest2::Perform()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   247
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   248
	//
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   249
	// Test system standby
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   250
	//
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   251
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   252
	test.Next(_L("Test 2"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   253
	test.Printf(_L("Target State = 0x%x\n"), iState);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   254
	iMembers[0] = new CDmTestMember(KDmHierarchyIdPower, KDmIdRoot, 0, this);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   255
	test(iMembers[0] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   256
	iMembers[1] = new CDmTestMember(KDmHierarchyIdPower, KDmIdRoot, 0, this);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   257
	test(iMembers[1] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   258
	iMembers[2] = new CDmTestMember(KDmHierarchyIdPower, KDmIdApps, 1, this);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   259
	test(iMembers[2] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   260
	iMembers[3] = new CDmTestMember(KDmHierarchyIdPower, KDmIdApps, 1, this);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   261
	test(iMembers[3] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   262
	iMembers[4] = new CDmTestMember(KDmHierarchyIdPower, KDmIdUiApps, 1, this);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   263
	test(iMembers[4] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   264
	iMembers[5] = new CDmTestMember(KDmHierarchyIdPower, KDmIdUiApps, 1, this);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   265
	test(iMembers[5] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   266
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   267
	// expected number of notifications
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   268
	iMembersCount = 12;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   269
	// first expected ordinal
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   270
	iOrdinal = (iState == EPwActive) ? 0 : 1;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   271
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   272
	TInt r = iManager.Connect();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   273
	test(r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   274
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   275
	CActiveScheduler::Add(this);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   276
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   277
	// Use an absolute timer to request a wakeup event
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   278
	iTimer = new CDmTest2Timer();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   279
	TTime wakeup;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   280
	wakeup.HomeTime();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   281
	wakeup += TTimeIntervalSeconds(5);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   282
	test.Printf(_L("Tick count before timer = %d\n"), User::NTickCount());
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   283
	iTimer->At(wakeup);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   284
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   285
	iManager.RequestSystemTransition(iState, CActive::iStatus);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   286
	CActive::SetActive();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   287
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   288
	CActiveScheduler::Start();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   289
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   290
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   291
TInt CDmTest2::TransitionNotification(MDmDomainMember& aDomainMember)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   292
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   293
	++iCount;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   294
	if (aDomainMember.State() == EPwActive)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   295
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   296
		if(aDomainMember.Ordinal() < iOrdinal)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   297
			{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   298
			// Making the test to fail in RunL function inorder to complete the cleanup from domain manager.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   299
			test.Printf(_L("Making test to fail as Ordinal Mismatch Expected : %d, Returned : %d, State : %d"), 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   300
																		aDomainMember.Ordinal(), iOrdinal, aDomainMember.State());
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   301
			iCount--;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   302
			}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   303
		}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   304
	else
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   305
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   306
		if(aDomainMember.Ordinal() > iOrdinal)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   307
			{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   308
			// Making the test to fail in RunL function inorder to complete the cleanup from domain manager.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   309
			test.Printf(_L("Making test to fail as Ordinal Mismatch Expected : %d, Returned : %d, State: %d"), 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   310
																		aDomainMember.Ordinal(), iOrdinal, aDomainMember.State());
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   311
			iCount--;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   312
			}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   313
		}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   314
	iOrdinal = aDomainMember.Ordinal();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   315
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   316
	// acknowledge one from two
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   317
	iAcknowledge = !iAcknowledge;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   318
	return iAcknowledge?KErrNone:KErrAbort;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   319
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   320
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   321
void CDmTest2::RunL()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   322
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   323
	test.Printf(_L("Tick count after CDmTest2::RunL() = %d\n"), User::NTickCount());
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   324
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   325
	iTimer->Cancel();	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   326
	CActiveScheduler::Stop();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   327
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   328
	iManager.Close();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   329
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   330
	CDmTestMember** mp;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   331
	for (mp = iMembers; *mp; ++mp)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   332
		delete *mp;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   333
	test(CActive::iStatus == KErrTimedOut);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   334
	test(iCount == iMembersCount);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   335
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   336
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   337
void CDmTest2::DoCancel()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   338
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   339
	test(0);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   340
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   341
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   342
void CDmTest2::Release()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   343
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   344
	if (iTimer)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   345
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   346
		iTimer->Cancel();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   347
		delete iTimer;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   348
		}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   349
	delete this;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   350
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   351
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   352
class CDmTest3 : public MDmTest
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   353
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   354
public: 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   355
	// from MDmTest
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   356
	void Perform();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   357
	void Release();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   358
	TInt TransitionNotification(MDmDomainMember& aDomainMember);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   359
	void TransitionRequestComplete() {};
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   360
	};
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   361
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   362
void CDmTest3::Perform()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   363
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   364
	//
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   365
	// Test simple error situation
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   366
	//
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   367
	RDmDomainManager manager;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   368
	TInt r = manager.Connect();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   369
	test(r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   370
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   371
	RDmDomainManager manager1;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   372
	r = manager1.Connect();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   373
	test(r == KErrInUse);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   374
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   375
	RDmDomain domain;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   376
	r = domain.Connect(KDmIdNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   377
	test(r == KDmErrBadDomainId);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   378
	CDmTestMember*		testMember;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   379
	testMember = new CDmTestMember(KDmHierarchyIdPower, KDmIdApps, 1, this);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   380
	test (testMember != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   381
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   382
	TRequestStatus status;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   383
	manager.RequestDomainTransition(KDmIdApps, EPwStandby, status);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   384
	test(status.Int() == KRequestPending);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   385
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   386
	TRequestStatus status1;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   387
	manager.RequestDomainTransition(KDmIdApps, EPwActive, status1);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   388
	User::WaitForRequest(status1);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   389
	test(status1.Int() == KDmErrBadSequence);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   390
	User::WaitForRequest(status);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   391
	test(status.Int() == KErrTimedOut);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   392
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   393
	// Since this test doesn't start the active scheduler, a domain member's RunL() will 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   394
	// not get called so we need to re-request a domain transition notification manually
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   395
	User::WaitForRequest(testMember->iStatus);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   396
	test(testMember->iStatus.Int() == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   397
	testMember->iDomain.RequestTransitionNotification(testMember->iStatus);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   398
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   399
	manager.RequestDomainTransition(KDmIdApps, EPwActive, status);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   400
	test(status.Int() == KRequestPending);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   401
	manager.CancelTransition();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   402
	test(status.Int() == KErrCancel);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   403
	manager.CancelTransition();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   404
	User::WaitForRequest(status);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   405
	test(status.Int() == KErrCancel);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   406
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   407
	testMember->iDomain.CancelTransitionNotification();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   408
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   409
	delete testMember;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   410
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   411
	domain.Close();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   412
	manager.Close();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   413
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   414
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   415
TInt CDmTest3::TransitionNotification(MDmDomainMember& /*aDomainMember*/)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   416
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   417
	test(0);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   418
	return KErrAbort;	// don't acknowledge
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   419
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   420
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   421
void CDmTest3::Release()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   422
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   423
	delete this;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   424
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   425
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   426
class CDmTest4 : public MDmTest
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   427
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   428
public: 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   429
	// from MDmTest
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   430
	void Perform();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   431
	void Release();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   432
	TInt TransitionNotification(MDmDomainMember& aDomainMember);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   433
	void TransitionRequestComplete() {};
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   434
private:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   435
	void ExecSlave(TUint arg);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   436
	};
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   437
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   438
_LIT(KSecuritySlavePath, "t_domain_slave.exe");
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   439
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   440
void CDmTest4::ExecSlave(TUint aArg)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   441
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   442
	RProcess proc;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   443
	TInt r = proc.Create(KSecuritySlavePath, TPtrC((TUint16*) &aArg, sizeof(aArg)/sizeof(TUint16)));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   444
	test(r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   445
	TRequestStatus status;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   446
	proc.Logon(status);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   447
	proc.Resume();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   448
	User::WaitForRequest(status);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   449
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   450
    RDebug::Printf("CDmTest4::ExecSlave(%d) ExitType %d", aArg, proc.ExitType() );
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   451
    RDebug::Printf("CDmTest4::ExecSlave(%d) ExitReason %d", aArg, proc.ExitReason() );
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   452
	test(proc.ExitType() == EExitKill);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   453
//	test(proc.ExitReason() == KErrPermissionDenied);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   454
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   455
	CLOSE_AND_WAIT(proc);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   456
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   457
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   458
//! @SYMTestCaseID PBASE-T_DOMAIN-4
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   459
//! @SYMTestType CT
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   460
//! @SYMTestCaseDesc Dmain manager security tests
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   461
//! @SYMREQ 3722
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   462
//! @SYMTestActions Launches a separate process with no capabilities
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   463
//! @SYMTestExpectedResults  DM APIs should fail with KErrPermissionDenied
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   464
//! @SYMTestPriority High
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   465
//! @SYMTestStatus Defined
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   466
void CDmTest4::Perform()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   467
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   468
	//
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   469
	// Security tests
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   470
	//
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   471
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   472
	ExecSlave(0);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   473
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   474
    ExecSlave(1);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   475
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   476
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   477
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   478
TInt CDmTest4::TransitionNotification(MDmDomainMember& /*aDomainMember*/)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   479
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   480
	test(0);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   481
	return KErrNone;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   482
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   483
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   484
void CDmTest4::Release()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   485
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   486
	delete this;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   487
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   488
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   489
// Test hierarchy tests
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   490
class CDmTestStartupMember : public CDmTestMember
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   491
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   492
public:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   493
	CDmTestStartupMember(TDmHierarchyId aHierarchy, TDmDomainId aId, TUint32 aOrdinal, MDmTest*);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   494
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   495
public:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   496
private:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   497
	};
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   498
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   499
CDmTestStartupMember::CDmTestStartupMember(TDmHierarchyId aHierarchy, TDmDomainId aId, TUint32 aOrdinal, MDmTest* aTest) 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   500
	: CDmTestMember(aHierarchy, aId, aOrdinal, aTest)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   501
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   502
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   503
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   504
// Simultaneously testing of test domain defined in DomainPolicy99.dll
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   505
// and the power domain defined in DomainPolicy.dll
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   506
class CDmTest5 : public CActive, public MDmTest
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   507
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   508
public: 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   509
	// from CActive
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   510
	void RunL();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   511
	// from MDmTest
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   512
	void Perform();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   513
	void Release();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   514
	TInt TransitionNotification(MDmDomainMember& aDomainMember);
269
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   515
	void TransitionRequestComplete();	
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   516
	void RunTestOnGetTransitionFailures(RArray<const TTransitionFailure>& aTransitionFailure);
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   517
	
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   518
	CDmTest5(TDmDomainId aPowerId, TDmDomainId aTestId, TDmDomainState aPowerState, TDmDomainState aTestState) : 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   519
		CActive(CActive::EPriorityStandard), 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   520
		iPowerDomainId(aPowerId), iTestDomainId(aTestId), iPowerState(aPowerState), iTestState(aTestState) {}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   521
protected:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   522
	// from CActive
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   523
	virtual void DoCancel();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   524
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   525
private:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   526
	enum { KMembersMax = 16 };
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   527
	enum TAckMode{ KAckAlways, KAckNever, KAckError, KAckOddDomainsOnly };
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   528
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   529
	CDmTestMember*		iTestMembers[KMembersMax]; 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   530
	CDomainMemberAo*	iPowerMembers[KMembersMax]; 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   531
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   532
	RDmDomainManager	iTestDomainManager;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   533
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   534
	TDmDomainId			iPowerDomainId;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   535
	TDmDomainId			iTestDomainId;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   536
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   537
	TDmDomainState		iPowerState;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   538
	TDmDomainState		iTestState;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   539
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   540
	// level number for iTestDomainId. E.g 1 for KDmIdRoot, 2 for KDmIdTestA, etc.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   541
	TInt				iTestDomainLevel;	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   542
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   543
	TDmTraverseDirection iTraverseDirection;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   544
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   545
	TAckMode			iAckMode;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   546
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   547
public:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   548
	TInt				iTestNotifications;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   549
	TInt				iPowerNotifications;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   550
	TInt				iTestNotificationsExpected;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   551
	TInt				iPowerNotificationsExpected;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   552
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   553
	TInt				iTransitionsCompleted;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   554
	TInt				iTransitionsExpected;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   555
	};
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   556
269
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   557
void CDmTest5::RunTestOnGetTransitionFailures(RArray<const TTransitionFailure>& aTransitionFailure)
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   558
	{
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   559
	//*************************************************
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   560
	// Test - OOM Testing on GetTransitionFailures()
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   561
	// Simulates heap failure in GetTransitionFailures()
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   562
	//*************************************************
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   563
	TInt error = 0;
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   564
	TInt count = 0;	
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   565
	do
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   566
		{		
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   567
		__UHEAP_SETFAIL(RHeap::EFailNext, ++count);
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   568
		error = iTestDomainManager.GetTransitionFailures(aTransitionFailure);						
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   569
		test.Printf( _L( "CDmTest5::RunTestOnGetTransitionFailures, simulating heap failure on GetTransitionFailures(), Error=%d, Run=%d\n" ), error, count );
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   570
		}while(error == KErrNoMemory);		
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   571
		
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   572
	__UHEAP_RESET;
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   573
	
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   574
	//Actual count of heap failure as the final iteration which terminates the loop would not return KErrNoMemory 
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   575
	--count;
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   576
	test(count > 0);
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   577
	test.Printf( _L( "Out of memory tests on GetTransitionFailures() succeeded at heap failure rate of %i\n" ), count );
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   578
	}
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   579
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   580
//! @SYMTestCaseID PBASE-T_DOMAIN-5
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   581
//! @SYMTestType CT
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   582
//! @SYMTestCaseDesc Connects to two domain hierarchies simulteneously and perform various tests
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   583
//! @SYMREQ 3704,3705,3706,3707,3708,3709,3710,3711,3720,3721,3724,3725,3726,3727
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   584
//! @SYMTestActions Open two hiearchies simultaneously and perform various actions.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   585
//! @SYMTestExpectedResults  All tests should pass
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   586
//! @SYMTestPriority High
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   587
//! @SYMTestStatus Defined
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   588
void CDmTest5::Perform()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   589
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   590
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   591
 	__UHEAP_MARK;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   592
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   593
	//
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   594
	// Test domain transitions
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   595
	//
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   596
	CActiveScheduler::Add(this);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   597
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
   598
	TInt r = RDmDomainManager::AddDomainHierarchy(GHierarchyIdUnderTest);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   599
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   600
    RDebug::Printf("RDmDomainManager::AddDomainHierarchy returns %d", r );
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   601
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   602
	test(r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   603
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   604
	CDomainManagerAo* powerDomainManager = NULL;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   605
	TRAP(r, powerDomainManager = CDomainManagerAo::NewL(KDmHierarchyIdPower, *this));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   606
	test (powerDomainManager != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   607
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   608
	r = CDomainManagerAo::AddDomainHierarchy(KDmHierarchyIdPower);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   609
	test(r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   610
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   611
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   612
	//	Test 5a - connect to two domain hierarchies simultaneously
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   613
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   614
	test.Next(_L("Test 5a - connect to two domain hierarchies simultaneously"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   615
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   616
	test.Printf(_L("Domain id = 0x%x, Target State = 0x%x\n"), iTestDomainId, iTestState);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   617
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   618
	TInt testMemberCount = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   619
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   620
	// Add some test hierarchy members - these use the RDmDomain API
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
   621
	iTestMembers[testMemberCount] = new CDmTestMember(GHierarchyIdUnderTest, KDmIdRoot, ORDINAL_FROM_DOMAINID0(KDmIdRoot), this);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   622
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
   623
	iTestMembers[testMemberCount] = new CDmTestMember(GHierarchyIdUnderTest, KDmIdRoot, ORDINAL_FROM_DOMAINID0(KDmIdRoot), this);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   624
	test(iTestMembers[testMemberCount++] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   625
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   626
	// row 1
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
   627
	iTestMembers[testMemberCount] = new CDmTestMember(GHierarchyIdUnderTest, KDmIdTestA, ORDINAL_FROM_DOMAINID1(KDmIdRoot, KDmIdTestA), this);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   628
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
   629
	iTestMembers[testMemberCount] = new CDmTestMember(GHierarchyIdUnderTest, KDmIdTestB, ORDINAL_FROM_DOMAINID1(KDmIdRoot, KDmIdTestB), this);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   630
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
   631
	iTestMembers[testMemberCount] = new CDmTestMember(GHierarchyIdUnderTest, KDmIdTestC, ORDINAL_FROM_DOMAINID1(KDmIdRoot, KDmIdTestC), this);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   632
	test(iTestMembers[testMemberCount++] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   633
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   634
	// row2
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
   635
	iTestMembers[testMemberCount] = new CDmTestMember(GHierarchyIdUnderTest, KDmIdTestAA, ORDINAL_FROM_DOMAINID2(KDmIdRoot, KDmIdTestA, KDmIdTestAA), this);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   636
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
   637
	iTestMembers[testMemberCount] = new CDmTestMember(GHierarchyIdUnderTest, KDmIdTestAB, ORDINAL_FROM_DOMAINID2(KDmIdRoot, KDmIdTestA, KDmIdTestAB), this);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   638
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
   639
	iTestMembers[testMemberCount] = new CDmTestMember(GHierarchyIdUnderTest, KDmIdTestBA, ORDINAL_FROM_DOMAINID2(KDmIdRoot, KDmIdTestB, KDmIdTestBA), this);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   640
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
   641
	iTestMembers[testMemberCount] = new CDmTestMember(GHierarchyIdUnderTest, KDmIdTestCA, ORDINAL_FROM_DOMAINID2(KDmIdRoot, KDmIdTestC, KDmIdTestCA), this);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   642
	test(iTestMembers[testMemberCount++] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   643
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   644
	// row 3
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
   645
	iTestMembers[testMemberCount] = new CDmTestMember(GHierarchyIdUnderTest, KDmIdTestABA, ORDINAL_FROM_DOMAINID3(KDmIdRoot, KDmIdTestA, KDmIdTestAB, KDmIdTestABA), this);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   646
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
   647
	iTestMembers[testMemberCount] = new CDmTestMember(GHierarchyIdUnderTest, KDmIdTestABB, ORDINAL_FROM_DOMAINID3(KDmIdRoot, KDmIdTestA, KDmIdTestAB, KDmIdTestABB), this);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   648
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
   649
	iTestMembers[testMemberCount] = new CDmTestMember(GHierarchyIdUnderTest, KDmIdTestCAA, ORDINAL_FROM_DOMAINID3(KDmIdRoot, KDmIdTestC, KDmIdTestCA, KDmIdTestCAA), this);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   650
	test(iTestMembers[testMemberCount++] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   651
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   652
	// add some power hierarchy members - these use the CDmDomain AO API
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   653
	TInt powerMemberCount = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   654
	TRAP(r, iPowerMembers[powerMemberCount] = CDomainMemberAo::NewL(KDmHierarchyIdPower, KDmIdRoot, KDmIdRoot, this));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   655
	test(iTestMembers[powerMemberCount++] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   656
	TRAP(r, iPowerMembers[powerMemberCount] = CDomainMemberAo::NewL(KDmHierarchyIdPower, KDmIdApps, KDmIdApps, this));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   657
	test(iTestMembers[powerMemberCount++] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   658
	TRAP(r, iPowerMembers[powerMemberCount] = CDomainMemberAo::NewL(KDmHierarchyIdPower, KDmIdUiApps, KDmIdUiApps, this));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   659
	test(iTestMembers[powerMemberCount++] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   660
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   661
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   662
	RArray<const TTransitionFailure> testFailures;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   663
	TInt testFailureCount;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   664
	RArray<const TTransitionFailure> powerFailures;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   665
	TInt powerFailureCount;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   666
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   667
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   668
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   669
	// calculate the expected number of notifications
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   670
	TInt expectedTestNotifications = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   671
	TInt leafNodes = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   672
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   673
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   674
	// work out the domain level, the number of leaf nodes and the expected number of 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   675
	// notifications for the domain that is being transitioned
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   676
	switch(iTestDomainId)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   677
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   678
		case KDmIdRoot		:	iTestDomainLevel = 1; leafNodes = 5; expectedTestNotifications = testMemberCount; break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   679
		case KDmIdTestA		:	iTestDomainLevel = 2; leafNodes = 3; expectedTestNotifications = 5; break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   680
		case KDmIdTestB		:	iTestDomainLevel = 2; leafNodes = 1; expectedTestNotifications = 2; break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   681
		case KDmIdTestC		:	iTestDomainLevel = 2; leafNodes = 1; expectedTestNotifications = 3; break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   682
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   683
		case KDmIdTestAA	:	iTestDomainLevel = 3; leafNodes = 1; expectedTestNotifications = 1; break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   684
		case KDmIdTestAB	:	iTestDomainLevel = 3; leafNodes = 2; expectedTestNotifications = 3; break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   685
		case KDmIdTestBA	:	iTestDomainLevel = 3; leafNodes = 1; expectedTestNotifications = 1; break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   686
		case KDmIdTestCA	:	iTestDomainLevel = 3; leafNodes = 1; expectedTestNotifications = 2; break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   687
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   688
		case KDmIdTestABA	:	iTestDomainLevel = 4; leafNodes = 1; expectedTestNotifications = 1; break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   689
		case KDmIdTestABB	:	iTestDomainLevel = 4; leafNodes = 1; expectedTestNotifications = 1; break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   690
		case KDmIdTestCAA	:	iTestDomainLevel = 4; leafNodes = 1; expectedTestNotifications = 1; break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   691
		default:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   692
			test(0);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   693
		}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   694
	test.Printf(_L("Test Domain id = 0x%x, Level = %d, Target State = 0x%x, expected notifications = %d, leafNodes = %d\n"), 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   695
		iTestDomainId, iTestDomainLevel, iTestState, expectedTestNotifications, leafNodes);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   696
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   697
	TInt expectedPowerNotifications = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   698
	switch(iPowerDomainId)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   699
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   700
		case KDmIdRoot		:	expectedPowerNotifications = powerMemberCount; break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   701
		case KDmIdApps		:	expectedPowerNotifications = 1; break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   702
		case KDmIdUiApps	:	expectedPowerNotifications = 1; break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   703
		default:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   704
			test(0);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   705
		}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   706
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   707
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   708
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   709
	// connect to the test hierarchy
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
   710
	r = iTestDomainManager.Connect(GHierarchyIdUnderTest);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   711
	test(r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   712
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   713
	// verify that we can't connect to the same hierarchy more than once
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   714
	RDmDomainManager	domainManager;
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
   715
	r = domainManager.Connect(GHierarchyIdUnderTest);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   716
	test(r == KErrInUse);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   717
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   718
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   719
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   720
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   721
	// Test 5b - request a positive transition
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   722
	// issue a positive  transition (i.e. transition state increases)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   723
	// and request that the test domain use ETraverseParentsFirst
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   724
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   725
	test.Next(_L("Test 5b - request a positive transition"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   726
	iAckMode = KAckAlways;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   727
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   728
	iTransitionsCompleted = iTestNotifications = iPowerNotifications = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   729
	iPowerNotificationsExpected = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   730
	iTestNotificationsExpected = expectedTestNotifications;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   731
	iTransitionsExpected = 1;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   732
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   733
	// DON'T request any domain transition on the power hierarchy
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   734
	// powerDomainManager->RequestDomainTransition(iPowerDomainId, EPwActive);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   735
	// request a domain transition on the test hierarchy
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   736
	iTraverseDirection = ETraverseParentsFirst;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   737
	if (iTestDomainId == KDmIdRoot)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   738
		iTestDomainManager.RequestSystemTransition(iTestState, ETraverseDefault, CActive::iStatus);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   739
	else
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   740
		iTestDomainManager.RequestDomainTransition(iTestDomainId, iTestState, ETraverseDefault, CActive::iStatus);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   741
	CActive::SetActive();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   742
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   743
	CActiveScheduler::Start();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   744
	test(powerDomainManager->iStatus == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   745
	test(iStatus == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   746
	test(iTestNotifications == iTestNotificationsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   747
	test(iPowerNotifications == iPowerNotificationsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   748
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   749
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   750
	// Test 5c- verify domains are in correct state
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   751
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   752
	test.Next(_L("Test 5c- verify domains are in correct state"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   753
	RDmDomain domainMember;
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
   754
	r = domainMember.Connect(GHierarchyIdUnderTest, iTestDomainId);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   755
	test (r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   756
	TDmDomainState state = domainMember.GetState();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   757
	domainMember.Close();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   758
	test (state == iTestState);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   759
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   760
	// if the transition request is not on the root, verify that that 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   761
	// the root domain and the transition domain are in different states
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   762
	if (iTestDomainId != KDmIdRoot && iTestState != EStartupCriticalStatic)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   763
		{
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
   764
		r = domainMember.Connect(GHierarchyIdUnderTest, KDmIdRoot);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   765
		test (r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   766
		TDmDomainState state = domainMember.GetState();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   767
		domainMember.Close();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   768
		test (state != iTestState);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   769
		}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   770
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   771
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   772
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   773
	// Test 5d- request a negative transition
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   774
	// issue a negative transition (i.e. transition state decreases)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   775
	// and request that the test domain use ETraverseChildrenFirst
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   776
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   777
	test.Next(_L("Test 5d- request a negative transition"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   778
	iAckMode = KAckAlways;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   779
	iTestState--;	// EStartupCriticalStatic;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   780
	iPowerState--;	// EPwStandby
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   781
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   782
	iTransitionsCompleted = iTestNotifications = iPowerNotifications = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   783
	iPowerNotificationsExpected = expectedPowerNotifications;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   784
	iTestNotificationsExpected = expectedTestNotifications;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   785
	iTransitionsExpected = 2;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   786
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   787
	// DO request a domain transition on the power hierarchy
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   788
	powerDomainManager->RequestDomainTransition(iPowerDomainId, iPowerState, ETraverseDefault);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   789
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   790
	// request a domain transition on the test hierarchy
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   791
	iTraverseDirection = ETraverseChildrenFirst;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   792
	iTestDomainManager.RequestDomainTransition(iTestDomainId, iTestState, iTraverseDirection, CActive::iStatus);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   793
	CActive::SetActive();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   794
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   795
	// wait for all test & power transitions to complete
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   796
	CActiveScheduler::Start();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   797
	test(powerDomainManager->iStatus == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   798
	test(iStatus == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   799
	test(iTestNotifications == iTestNotificationsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   800
	test(iPowerNotifications == iPowerNotificationsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   801
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   802
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   803
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   804
	// Test 5e- request a positive transition, with zero acknowledgements
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   805
	// issue a positive transition with no members acknowledging the transition
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
   806
	// Expect timeout from server
957c583b417b 201039_07
hgs
parents: 269
diff changeset
   807
	// Also covers Testcase 2.3.2 from Transition Monitoring test suite when
957c583b417b 201039_07
hgs
parents: 269
diff changeset
   808
	// policy used in 96 or 97.
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   809
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   810
	test.Next(_L("Test 5e- request a positive transition, with zero acknowledgements"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   811
	iAckMode = KAckNever;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   812
	iTestState++;		// EStartupCriticalDynamic;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   813
	iPowerState++;		// EPwActive
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   814
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   815
	// power hierarchy should continue on failure, so we all power domains should transition
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   816
	// test hierarchy should stop on failure, so should get notifications from all leaf nodes
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   817
	iTransitionsCompleted = iTestNotifications = iPowerNotifications = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   818
	iPowerNotificationsExpected = expectedPowerNotifications;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   819
	iTestNotificationsExpected = leafNodes;	// 5 leaf nodes for root domain
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   820
	iTransitionsExpected = 2;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   821
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   822
	// DO request a domain transition on the power hierarchy
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   823
	powerDomainManager->RequestDomainTransition(iPowerDomainId, iPowerState, ETraverseDefault);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   824
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   825
	// request a domain transition on the test hierarchy
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   826
	iTraverseDirection = ETraverseChildrenFirst;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   827
	iTestDomainManager.RequestDomainTransition(iTestDomainId, iTestState, iTraverseDirection, CActive::iStatus);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   828
	CActive::SetActive();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   829
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   830
	// wait for all test & power transitions to complete
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   831
	CActiveScheduler::Start();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   832
	test(powerDomainManager->iStatus == KErrTimedOut);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   833
	test(iStatus == KErrTimedOut);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   834
	test(iTestNotifications == iTestNotificationsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   835
	test(iPowerNotifications == iPowerNotificationsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   836
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   837
	// get the failures on the test hierarchy
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   838
	testFailureCount = iTestDomainManager.GetTransitionFailureCount();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   839
	test (testFailureCount == 1);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   840
269
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   841
#ifdef _DEBUG
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   842
	//***************************************************************
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   843
	// OOM Testing: Simulates heap failure in GetTransitionFailures()
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   844
	//***************************************************************
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   845
	__UHEAP_MARK;
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   846
	RArray<const TTransitionFailure> oomTestFailures;
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   847
	RunTestOnGetTransitionFailures(oomTestFailures);
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   848
	test(oomTestFailures.Count()==1);
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   849
	oomTestFailures.Close();
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   850
	__UHEAP_MARKEND;
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   851
#endif
d57b86b1867a 201035_03
hgs
parents: 245
diff changeset
   852
	
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   853
	r = iTestDomainManager.GetTransitionFailures(testFailures);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   854
	test(r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   855
	test(testFailureCount == testFailures.Count());
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   856
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   857
	test.Printf(_L("Test failures = %d\n"), testFailureCount);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   858
	TInt i;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   859
	for (i=0; i<testFailureCount; i++)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   860
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   861
		test.Printf(_L("%d: iDomainId %d, iError %d\n"), 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   862
			i, testFailures[i].iDomainId, testFailures[i].iError);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   863
		test(testFailures[i].iError == KErrTimedOut);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   864
		}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   865
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   866
	// get the failures on the power hierarchy
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   867
	powerFailureCount = powerDomainManager->GetTransitionFailureCount();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   868
	test (powerFailureCount == expectedPowerNotifications);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   869
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   870
	r = powerDomainManager->GetTransitionFailures(powerFailures);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   871
	test(r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   872
	test(powerFailureCount == powerFailures.Count());
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   873
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   874
	test.Printf(_L("Power failures = %d\n"), powerFailureCount);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   875
	for (i=0; i<powerFailureCount; i++)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   876
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   877
		test.Printf(_L("%d: iDomainId %d, iError %d\n"), 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   878
			i, powerFailures[i].iDomainId, powerFailures[i].iError);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   879
		test(powerFailures[i].iError == KErrTimedOut);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   880
		}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   881
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   882
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   883
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   884
	// Test 5f- request a positive transition, with error acknowledgements
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   885
	// issue a positive transition with all members nack'ing the transition
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   886
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   887
	test.Next(_L("Test 5f- request a positive transition, with error acknowledgements"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   888
	iAckMode = KAckError;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   889
	iTestState++;		
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   890
	iPowerState++;		
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   891
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   892
	// power hierarchy should continue on failure, so all power domains should transition
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   893
	// test hierarchy should stop on failure, so should get notifications from 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   894
	// anything from 1 to all the leaf nodes
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   895
	iTransitionsCompleted = iTestNotifications = iPowerNotifications = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   896
	iPowerNotificationsExpected = expectedPowerNotifications;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   897
	iTestNotificationsExpected = leafNodes;	// 5 leaf nodes for root domain
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   898
	iTransitionsExpected = 2;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   899
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   900
	// DO request a domain transition on the power hierarchy
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   901
	powerDomainManager->RequestDomainTransition(iPowerDomainId, iPowerState, ETraverseDefault);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   902
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   903
	// request a domain transition on the test hierarchy
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   904
	iTraverseDirection = ETraverseChildrenFirst;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   905
	iTestDomainManager.RequestDomainTransition(iTestDomainId, iTestState, iTraverseDirection, CActive::iStatus);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   906
	CActive::SetActive();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   907
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   908
	// wait for all test & power transitions to complete
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   909
	CActiveScheduler::Start();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   910
	test(powerDomainManager->iStatus == KErrGeneral);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   911
	test(iStatus == KErrGeneral);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   912
	test(iTestNotifications <= iTestNotificationsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   913
	test(iPowerNotifications == iPowerNotificationsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   914
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   915
	// get the failures on the test hierarchy
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   916
	testFailureCount = iTestDomainManager.GetTransitionFailureCount();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   917
	test (testFailureCount == 1);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   918
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   919
	r = iTestDomainManager.GetTransitionFailures(testFailures);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   920
	test(r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   921
	test(testFailureCount == testFailures.Count());
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   922
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   923
	test.Printf(_L("Test failures = %d\n"), testFailureCount);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   924
	for (i=0; i<testFailureCount; i++)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   925
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   926
		test.Printf(_L("%d: iDomainId %d, iError %d\n"), 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   927
			i, testFailures[i].iDomainId, testFailures[i].iError);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   928
		test(testFailures[i].iError == KErrGeneral);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   929
		}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   930
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   931
	// get the failures on the power hierarchy
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   932
	powerFailureCount = powerDomainManager->GetTransitionFailureCount();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   933
	test (powerFailureCount == expectedPowerNotifications);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   934
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   935
	r = powerDomainManager->GetTransitionFailures(powerFailures);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   936
	test(r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   937
	test(powerFailureCount == powerFailures.Count());
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   938
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   939
	test.Printf(_L("Power failures = %d\n"), powerFailureCount);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   940
	for (i=0; i<powerFailureCount; i++)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   941
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   942
		test.Printf(_L("%d: iDomainId %d, iError %d\n"), 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   943
			i, powerFailures[i].iDomainId, powerFailures[i].iError);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   944
		test(powerFailures[i].iError == KErrGeneral);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   945
		}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   946
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   947
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   948
	// cleanup
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   949
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   950
	testFailures.Reset();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   951
	powerFailures.Reset();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   952
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   953
	iTestDomainManager.Close();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   954
	delete powerDomainManager;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   955
	powerDomainManager = NULL;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   956
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   957
	CDmTestMember** mt;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   958
	for (mt = iTestMembers; *mt; ++mt)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   959
		delete *mt;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   960
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   961
	CDomainMemberAo** mp;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   962
	for (mp = iPowerMembers; *mp; ++mp)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   963
		delete *mp;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   964
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   965
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   966
	// restore the domain hierarchies to their initial state so as not to 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   967
	// upset any subsequent tests which rely on this
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   968
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   969
	RDmDomainManager manager;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   970
	TInt r = manager.Connect();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   971
	test (r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   972
	TRequestStatus status;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   973
	manager.RequestDomainTransition(KDmIdRoot, EPwActive, status);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   974
	test(status.Int() == KRequestPending);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   975
	User::WaitForRequest(status);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   976
	test(status.Int() == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   977
	manager.Close();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   978
	
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
   979
	r = manager.Connect(GHierarchyIdUnderTest);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   980
	test (r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   981
	manager.RequestDomainTransition(KDmIdRoot, EStartupCriticalStatic, ETraverseDefault, status);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   982
	test(status.Int() == KRequestPending);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   983
	User::WaitForRequest(status);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   984
	test(status.Int() == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   985
	manager.Close();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   986
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   987
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   988
 	__UHEAP_MARKEND;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   989
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   990
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   991
// This handles a transition notification from either a power domain member or 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   992
// a test domain member.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   993
// Verifies that the domain state is as expected.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   994
// Updates the number of notifications for each hierarchy and verifies that all parent 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   995
// domains have transitioned already (for parent-to-child transitions) or that all child 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   996
// domains have been transitioned already (for child-to-parent transitions).
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   997
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   998
TInt CDmTest5::TransitionNotification(MDmDomainMember& aDomainMember)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
   999
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1000
	if (aDomainMember.HierarchyId() == KDmHierarchyIdPower)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1001
		iPowerNotifications++;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1002
	else
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1003
		iTestNotifications++;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1004
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1005
	if (aDomainMember.HierarchyId() == KDmHierarchyIdPower)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1006
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1007
		__PRINT((_L("CDmTest5::TransitionNotification(), Hierarchy = %d, iOrdinal = 0x%08X, state = 0x%x, status = %d\n"), 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1008
			aDomainMember.HierarchyId(), aDomainMember.Ordinal(), aDomainMember.State(), aDomainMember.Status()));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1009
		test(aDomainMember.State() == iPowerState);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1010
		}
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1011
	else if (aDomainMember.HierarchyId() == GHierarchyIdUnderTest)
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1012
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1013
		TBuf16<4> buf;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1014
		GetDomainDesc(aDomainMember.Ordinal(), buf);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1015
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1016
		__PRINT((_L("CDmTest5::TransitionNotification(), Hierarchy = %d, domain = %S, iOrdinal = 0x%08X, state = 0x%x, status = %d\n"), 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1017
			aDomainMember.HierarchyId(), &buf, aDomainMember.Ordinal(), aDomainMember.State(), aDomainMember.Status()));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1018
		test(aDomainMember.State() == iTestState);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1019
		}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1020
	else
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1021
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1022
		test(0);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1023
		}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1024
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1025
	// if we're going from parent to child, 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1026
	// check that each parent domain has received a notification already
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1027
	// if not, check that each child domain has received a notification already
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1028
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1029
	CDmTestMember** mp;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1030
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1031
	if (aDomainMember.HierarchyId() == GHierarchyIdUnderTest && iAckMode == KAckAlways)
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1032
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1033
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1034
		if (iTraverseDirection == ETraverseParentsFirst)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1035
			{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1036
			TUint ordThis = aDomainMember.Ordinal();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1037
			TUint ordParent = PARENT_ORDINAL(ordThis);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1038
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1039
			TInt levelParent = ORDINAL_LEVEL(ordParent);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1040
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1041
			TBuf16<4> buf;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1042
			GetDomainDesc(ordParent, buf);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1043
			if (levelParent >= iTestDomainLevel)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1044
				{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1045
				__PRINT((_L("Searching for parent domain = %S, ordinal = %08X \n"), &buf, ordParent));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1046
				for (mp = iTestMembers; *mp; ++mp)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1047
					{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1048
					if ((*mp)->Ordinal() == ordParent)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1049
						{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1050
						TBuf16<4> buf;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1051
						GetDomainDesc((*mp)->Ordinal(), buf);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1052
						__PRINT((_L("Found parent (%S). notification = %d\n"), &buf, (*mp)->Notifications()));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1053
						test ((*mp)->Notifications() == aDomainMember.Notifications());
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1054
						break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1055
						}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1056
					}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1057
				}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1058
			}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1059
		else
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1060
			{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1061
			__PRINT((_L("Searching for children\n")));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1062
			for (mp = iTestMembers; *mp; ++mp)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1063
				{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1064
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1065
				TUint ordParent = PARENT_ORDINAL((*mp)->Ordinal());
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1066
				if (ordParent == aDomainMember.Ordinal())
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1067
					{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1068
					TBuf16<4> buf;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1069
					GetDomainDesc((*mp)->Ordinal(), buf);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1070
					__PRINT((_L("Found child (%S). notification = %d\n"), &buf, (*mp)->Notifications()));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1071
					test ((*mp)->Notifications() == aDomainMember.Notifications());
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1072
					}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1073
				}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1074
			}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1075
		}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1076
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1077
	TInt ackError;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1078
	switch (iAckMode)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1079
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1080
		case KAckNever:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1081
			ackError = KErrAbort;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1082
			break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1083
		case KAckError:		// return an error to the DM
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1084
			ackError = KErrGeneral;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1085
			break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1086
		case KAckOddDomainsOnly:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1087
			ackError = (aDomainMember.DomainId() & 1)?KErrNone:KErrAbort;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1088
			break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1089
		case KAckAlways:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1090
		default:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1091
			ackError = KErrNone;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1092
			break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1093
		}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1094
	return ackError;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1095
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1096
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1097
void CDmTest5::RunL()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1098
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1099
	iTransitionsCompleted++;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1100
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1101
	__PRINT((_L("CDmTest5::RunL(), error = %d, iTestNotifications %d, iPowerNotifications %d\n"), 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1102
		iStatus.Int(), iTestNotifications , iPowerNotifications));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1103
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1104
	if (iTransitionsCompleted == iTransitionsExpected)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1105
		CActiveScheduler::Stop();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1106
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1107
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1108
void CDmTest5::TransitionRequestComplete()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1109
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1110
	iTransitionsCompleted++;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1111
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1112
	__PRINT((_L("CDmTest5::TransitionRequestComplete(), error = %d, iTestNotifications %d, iPowerNotifications %d\n"), 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1113
		iStatus.Int(), iTestNotifications , iPowerNotifications));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1114
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1115
	if (iTransitionsCompleted == iTransitionsExpected)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1116
		CActiveScheduler::Stop();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1117
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1118
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1119
void CDmTest5::DoCancel()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1120
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1121
	test(0);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1122
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1123
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1124
void CDmTest5::Release()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1125
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1126
	delete this;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1127
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1128
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1129
const TInt KMembersMax = 16;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1130
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1131
// Negative testing 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1132
class CDmTest6 : public CActive, public MDmTest
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1133
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1134
public:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1135
	enum 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1136
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1137
	ENegTestTransitionNoConnect,
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1138
	ENegTestGetStateNoConnect,
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1139
	ENegTestTransitionInvalidMode
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1140
	};
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1141
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1142
	class TData 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1143
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1144
	public:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1145
		inline TData(TInt aTest) : iTest(aTest){};
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1146
		TInt iTest;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1147
		};
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1148
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1149
public: 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1150
	// from CActive
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1151
	void RunL();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1152
 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1153
	// from MDmTest
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1154
	void Perform();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1155
	void Release();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1156
	TInt TransitionNotification(MDmDomainMember& aDomainMember);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1157
	void TransitionRequestComplete();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1158
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1159
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1160
	CDmTest6() : CActive(CActive::EPriorityStandard) {}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1161
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1162
protected:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1163
	// from CActive
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1164
	virtual void DoCancel();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1165
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1166
private:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1167
	static TInt PanicThreadFunc(TAny* aData);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1168
	void PanicTest(TInt aTestNumber);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1169
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1170
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1171
	CDomainMemberAo*	iTestMembers[KMembersMax]; 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1172
	CDomainManagerAo*	iTestDomainManager;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1173
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1174
	TDmDomainId			iTestDomainId;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1175
	TDmDomainState		iTestState;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1176
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1177
public:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1178
	TInt				iTestNotifications;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1179
	TInt				iTestNotificationsExpected;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1180
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1181
	TInt				iTransitionsCompleted;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1182
	TInt				iTransitionsExpected;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1183
	};
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1184
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1185
TInt CDmTest6::PanicThreadFunc(TAny* aData)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1186
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1187
	const TData* data = (const TData*)aData;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1188
	switch (data->iTest)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1189
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1190
		case ENegTestTransitionNoConnect:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1191
			{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1192
			// request a transition notification without connecting first (should panic)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1193
			RDmDomain domainMember;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1194
			TRequestStatus status;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1195
			User::SetJustInTime(EFalse);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1196
			domainMember.RequestTransitionNotification(status);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1197
			}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1198
			break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1199
		case ENegTestGetStateNoConnect:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1200
			{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1201
			// Get the domain state without connecting (should panic)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1202
			RDmDomain domainMember;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1203
			User::SetJustInTime(EFalse);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1204
			domainMember.GetState();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1205
			}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1206
			break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1207
		case ENegTestTransitionInvalidMode:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1208
			{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1209
			RDmDomainManager manager;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1210
			TRequestStatus status;
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1211
			TInt r = manager.Connect(GHierarchyIdUnderTest);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1212
			test(r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1213
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1214
			User::SetJustInTime(EFalse);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1215
			manager.RequestDomainTransition(KDmIdRoot, 0, TDmTraverseDirection(-1), status);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1216
			}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1217
			break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1218
		default:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1219
			break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1220
		}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1221
	return KErrNone;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1222
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1223
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1224
void CDmTest6::PanicTest(TInt aTestNumber)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1225
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1226
	test.Printf(_L("panic test number %d\n"), aTestNumber);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1227
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1228
	TBool jit = User::JustInTime();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1229
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1230
	TData data(aTestNumber);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1231
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1232
	TInt KHeapSize=0x2000;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1233
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1234
	RThread thread;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1235
	TInt ret = thread.Create(KThreadName, PanicThreadFunc, KDefaultStackSize, KHeapSize, KHeapSize, &data);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1236
	test(KErrNone == ret);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1237
	TRequestStatus stat;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1238
	thread.Logon(stat);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1239
	thread.Resume();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1240
	User::WaitForRequest(stat);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1241
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1242
	User::SetJustInTime(jit);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1243
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1244
	// The thread must panic
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1245
	test(thread.ExitType() == EExitPanic);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1246
	TInt exitReason = thread.ExitReason();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1247
	test.Printf(_L("panic test exit reason = %d\n"), exitReason);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1248
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1249
	switch(aTestNumber)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1250
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1251
		case ENegTestTransitionNoConnect:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1252
			test (exitReason == EBadHandle);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1253
			break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1254
		case ENegTestGetStateNoConnect:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1255
			test (exitReason == EBadHandle);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1256
			break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1257
		case ENegTestTransitionInvalidMode:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1258
			break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1259
		default:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1260
			break;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1261
		}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1262
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1263
	CLOSE_AND_WAIT(thread);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1264
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1265
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1266
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1267
//! @SYMTestCaseID PBASE-T_DOMAIN-6
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1268
//! @SYMTestType CT
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1269
//! @SYMTestCaseDesc Negative testing
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1270
//! @SYMPREQ 810
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1271
//! @SYMTestActions Various negative tests
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1272
//! @SYMTestExpectedResults  All tests should pass
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1273
//! @SYMTestPriority High
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1274
//! @SYMTestStatus Defined
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1275
void CDmTest6::Perform()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1276
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1277
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1278
 	__UHEAP_MARK;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1279
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1280
	CActiveScheduler::Add(this);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1281
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1282
	CDomainManagerAo* iTestDomainManager = NULL;
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1283
	TRAP_IGNORE(iTestDomainManager = CDomainManagerAo::NewL(GHierarchyIdUnderTest, *this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1284
	test (iTestDomainManager != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1285
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1286
	TInt r = CDomainManagerAo::AddDomainHierarchy(GHierarchyIdUnderTest);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1287
	test(r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1288
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1289
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1290
	// Test 6a - Connect to the same hierarchy twice
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1291
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1292
	test.Next(_L("Test 6a - Connect to the same hierarchy twice"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1293
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1294
	// verify that we can't connect to the same hierarchy more than once
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1295
	CDomainManagerAo* testDomainManager = NULL;
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1296
	TRAP(r, testDomainManager = CDomainManagerAo::NewL(GHierarchyIdUnderTest, *this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1297
	test(r == KErrInUse);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1298
	test (testDomainManager == NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1299
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1300
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1301
	TInt testMemberCount = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1302
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1303
	// Add some test hierarchy members
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1304
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdRoot, ORDINAL_FROM_DOMAINID0(KDmIdRoot), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1305
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1306
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdRoot, ORDINAL_FROM_DOMAINID0(KDmIdRoot), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1307
	test(iTestMembers[testMemberCount++] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1308
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1309
	// row 1
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1310
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdTestA, ORDINAL_FROM_DOMAINID1(KDmIdRoot, KDmIdTestA), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1311
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1312
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdTestB, ORDINAL_FROM_DOMAINID1(KDmIdRoot, KDmIdTestB), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1313
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1314
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdTestC, ORDINAL_FROM_DOMAINID1(KDmIdRoot, KDmIdTestC), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1315
	test(iTestMembers[testMemberCount++] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1316
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1317
	// row2
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1318
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdTestAA, ORDINAL_FROM_DOMAINID2(KDmIdRoot, KDmIdTestA, KDmIdTestAA), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1319
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1320
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdTestAB, ORDINAL_FROM_DOMAINID2(KDmIdRoot, KDmIdTestA, KDmIdTestAB), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1321
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1322
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdTestBA, ORDINAL_FROM_DOMAINID2(KDmIdRoot, KDmIdTestB, KDmIdTestBA), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1323
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1324
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdTestCA, ORDINAL_FROM_DOMAINID2(KDmIdRoot, KDmIdTestC, KDmIdTestCA), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1325
	test(iTestMembers[testMemberCount++] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1326
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1327
	// row 3
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1328
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdTestABA, ORDINAL_FROM_DOMAINID3(KDmIdRoot, KDmIdTestA, KDmIdTestAB, KDmIdTestABA), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1329
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1330
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdTestABB, ORDINAL_FROM_DOMAINID3(KDmIdRoot, KDmIdTestA, KDmIdTestAB, KDmIdTestABB), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1331
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1332
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdTestCAA, ORDINAL_FROM_DOMAINID3(KDmIdRoot, KDmIdTestC, KDmIdTestCA, KDmIdTestCAA), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1333
	test(iTestMembers[testMemberCount++] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1334
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1335
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1336
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1337
	// Test 6b change to current state
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1338
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1339
	test.Next(_L("Test 6b change to current state"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1340
	iTestState =  EStartupCriticalStatic;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1341
	iTestDomainId = KDmIdRoot;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1342
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1343
	iTransitionsCompleted = iTestNotifications = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1344
	iTestNotificationsExpected = testMemberCount;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1345
	iTransitionsExpected = 1;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1346
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1347
	// request a domain transition
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1348
	iTestDomainManager->RequestDomainTransition(iTestDomainId, iTestState, ETraverseDefault);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1349
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1350
	// wait for test transitions to complete
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1351
	CActiveScheduler::Start();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1352
	test(iStatus == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1353
	test(iTestNotifications == iTestNotificationsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1354
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1355
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1356
	// cancel a member notification request 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1357
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1358
	// Test 6c cancel a member notification request
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1359
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1360
	test.Next(_L("Test 6c cancel a member notification request"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1361
	RDmDomain domainMember;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1362
	TRequestStatus status;
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1363
	domainMember.Connect(GHierarchyIdUnderTest, iTestDomainId);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1364
	domainMember.RequestTransitionNotification(status);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1365
	domainMember.CancelTransitionNotification();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1366
	User::WaitForRequest(status);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1367
	domainMember.Close();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1368
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1369
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1370
	// Test 6d cancel a member notification request without having first requested a notification
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1371
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1372
	test.Next(_L("Test 6d cancel a member notification request without having first requested a notification"));
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1373
	domainMember.Connect(GHierarchyIdUnderTest, iTestDomainId);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1374
	domainMember.CancelTransitionNotification();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1375
	domainMember.Close();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1376
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1377
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1378
	// Test 6e domain controller adds invalid hierarchy
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1379
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1380
	test.Next(_L("Test 6e domain controller connects to invalid hierarchy"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1381
	r = RDmDomainManager::AddDomainHierarchy(TDmHierarchyId(-1));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1382
	test(r == KErrBadHierarchyId);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1383
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1384
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1385
	// Test 6f domain member connects to invalid hierarchy
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1386
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1387
	test.Next(_L("Test 6f domain member connects to invalid hierarchy"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1388
	r = domainMember.Connect(TDmHierarchyId(-1), TDmDomainId(KDmIdRoot));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1389
	test (r == KErrBadHierarchyId);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1390
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1391
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1392
	// Test 6g domain member connects to valid hierarchy but invalid domain
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1393
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1394
	test.Next(_L("Test 6g domain member connects to valid hierarchy but invalid domain"));
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1395
	r = domainMember.Connect(GHierarchyIdUnderTest, TDmDomainId(-1));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1396
	test (r == KDmErrBadDomainId);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1397
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1398
	delete iTestDomainManager;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1399
	iTestDomainManager = NULL;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1400
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1401
	// Panic tests
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1402
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1403
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1404
	// Test 6h request a transition notification without connecting first
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1405
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1406
	test.Next(_L("Test 6h request a transition notification without connecting first"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1407
	PanicTest(ENegTestTransitionNoConnect);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1408
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1409
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1410
	// Test 6i Get the domain state without connecting
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1411
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1412
	test.Next(_L("Test 6i Get the domain state without connecting"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1413
	PanicTest(ENegTestGetStateNoConnect);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1414
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1415
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1416
	// Test 6j request a transition notification with an invalid transition mode
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1417
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1418
	test.Next(_L("Test 6j request a transition notification with an invalid transition mode"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1419
	PanicTest(ENegTestTransitionInvalidMode);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1420
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1421
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1422
	// cleanup
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1423
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1424
	CDomainMemberAo** mt;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1425
	for (mt = iTestMembers; *mt; ++mt)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1426
		delete *mt;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1427
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1428
 	__UHEAP_MARKEND;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1429
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1430
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1431
// This handles a transition notification from a test domain member.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1432
TInt CDmTest6::TransitionNotification(MDmDomainMember& aDomainMember)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1433
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1434
	TInt status = aDomainMember.Status();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1435
		
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1436
	iTestNotifications++;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1437
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1438
	test (aDomainMember.HierarchyId() == GHierarchyIdUnderTest);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1439
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1440
	TBuf16<4> buf;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1441
	GetDomainDesc(aDomainMember.Ordinal(), buf);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1442
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1443
	test.Printf(_L("CDmTest6::TransitionNotification(), Hierarchy = %d, domain = %S, iOrdinal = 0x%08X, state = 0x%x, status = %d\n"), 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1444
		aDomainMember.HierarchyId(), &buf, aDomainMember.Ordinal(), aDomainMember.State(), status);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1445
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1446
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1447
	return KErrNone;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1448
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1449
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1450
void CDmTest6::RunL()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1451
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1452
	iTransitionsCompleted++;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1453
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1454
	TInt error = iStatus.Int();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1455
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1456
	test.Printf(_L("CDmTest6::RunL(), error = %d, iTestNotifications %d\n"), 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1457
		error, iTestNotifications);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1458
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1459
	if (iTransitionsCompleted == iTransitionsExpected)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1460
		CActiveScheduler::Stop();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1461
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1462
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1463
void CDmTest6::TransitionRequestComplete()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1464
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1465
	iTransitionsCompleted++;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1466
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1467
	TInt error = iStatus.Int();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1468
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1469
	test.Printf(_L("CDmTest6::TransitionRequestComplete(), error = %d, iTestNotifications %d\n"), 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1470
		error, iTestNotifications);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1471
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1472
	if (iTransitionsCompleted == iTransitionsExpected)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1473
		CActiveScheduler::Stop();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1474
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1475
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1476
void CDmTest6::DoCancel()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1477
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1478
	test(0);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1479
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1480
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1481
void CDmTest6::Release()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1482
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1483
	delete this;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1484
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1485
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1486
// Transition progress Observer testing
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1487
class CDmTest7 : public CActive, public MDmTest, public MHierarchyObserver
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1488
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1489
public: 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1490
	// from CActive
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1491
	void RunL();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1492
 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1493
	// from MDmTest
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1494
	void Perform();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1495
	void Release();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1496
	TInt TransitionNotification(MDmDomainMember& aDomainMember);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1497
	void TransitionRequestComplete();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1498
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1499
	// from MHierarchyObserver
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1500
	virtual void TransProgEvent(TDmDomainId aDomainId, TDmDomainState aState);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1501
	virtual void TransFailEvent(TDmDomainId aDomainId, TDmDomainState aState, TInt aError);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1502
	virtual void TransReqEvent(TDmDomainId aDomainId, TDmDomainState aState);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1503
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1504
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1505
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1506
	CDmTest7(TDmDomainId aDomainId) : CActive(CActive::EPriorityStandard), iObservedDomainId(aDomainId) {}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1507
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1508
protected:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1509
	// from CActive
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1510
	virtual void DoCancel();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1511
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1512
private:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1513
	void TestForCompletion();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1514
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1515
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1516
private:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1517
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1518
	enum { KMembersMax = 16 };
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1519
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1520
	CDomainMemberAo*	iTestMembers[KMembersMax]; 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1521
	CDomainManagerAo*	iTestDomainManager;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1522
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1523
	TDmDomainId			iTestDomainId;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1524
	TDmDomainState		iTestState;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1525
	TDmDomainId			iObservedDomainId;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1526
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1527
public:
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1528
	TInt				iTestNotifications;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1529
	TInt				iTestNotificationsExpected;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1530
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1531
	TInt				iTransitionsCompleted;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1532
	TInt				iTransitionsExpected;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1533
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1534
	TInt				iTransProgEvents;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1535
	TInt				iTransFailEvents;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1536
	TInt				iTransReqEvents;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1537
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1538
	TInt				iTransProgEventsExpected;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1539
	TInt				iTransFailEventsExpected;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1540
	TInt				iTransReqEventsExpected;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1541
	};
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1542
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1543
//! @SYMTestCaseID PBASE-T_DOMAIN-7
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1544
//! @SYMTestType CT
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1545
//! @SYMTestCaseDesc Transition progress Observer testing
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1546
//! @SYMREQ REQ3723
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1547
//! @SYMTestActions Various negative tests
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1548
//! @SYMTestExpectedResults  All tests should pass
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1549
//! @SYMTestPriority High
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1550
//! @SYMTestStatus Defined
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1551
void CDmTest7::Perform()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1552
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1553
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1554
 	__UHEAP_MARK;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1555
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1556
	//
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1557
	// Test domain transitions with activated observer
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1558
	//
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1559
	CActiveScheduler::Add(this);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1560
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1561
	TInt r = RDmDomainManager::AddDomainHierarchy(GHierarchyIdUnderTest);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1562
	test(r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1563
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1564
	CDomainManagerAo* iTestDomainManager = NULL;
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1565
	TRAP_IGNORE(iTestDomainManager = CDomainManagerAo::NewL(GHierarchyIdUnderTest, *this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1566
	test (iTestDomainManager != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1567
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1568
	r = CDomainManagerAo::AddDomainHierarchy(GHierarchyIdUnderTest);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1569
	test(r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1570
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1571
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1572
	// Test 7a - Testing observer notifications
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1573
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1574
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1575
	test.Next(_L("Test 7a - Testing observer notifications"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1576
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1577
	TInt testMemberCount = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1578
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1579
	// Add some test hierarchy members
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1580
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdRoot, ORDINAL_FROM_DOMAINID0(KDmIdRoot), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1581
	test(iTestMembers[testMemberCount++] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1582
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1583
	// row 1
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1584
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdTestA, ORDINAL_FROM_DOMAINID1(KDmIdRoot, KDmIdTestA), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1585
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1586
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdTestB, ORDINAL_FROM_DOMAINID1(KDmIdRoot, KDmIdTestB), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1587
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1588
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdTestC, ORDINAL_FROM_DOMAINID1(KDmIdRoot, KDmIdTestC), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1589
	test(iTestMembers[testMemberCount++] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1590
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1591
	// row2
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1592
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdTestAA, ORDINAL_FROM_DOMAINID2(KDmIdRoot, KDmIdTestA, KDmIdTestAA), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1593
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1594
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdTestAB, ORDINAL_FROM_DOMAINID2(KDmIdRoot, KDmIdTestA, KDmIdTestAB), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1595
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1596
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdTestBA, ORDINAL_FROM_DOMAINID2(KDmIdRoot, KDmIdTestB, KDmIdTestBA), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1597
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1598
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdTestCA, ORDINAL_FROM_DOMAINID2(KDmIdRoot, KDmIdTestC, KDmIdTestCA), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1599
	test(iTestMembers[testMemberCount++] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1600
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1601
	// row 3
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1602
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdTestABA, ORDINAL_FROM_DOMAINID3(KDmIdRoot, KDmIdTestA, KDmIdTestAB, KDmIdTestABA), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1603
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1604
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdTestABB, ORDINAL_FROM_DOMAINID3(KDmIdRoot, KDmIdTestA, KDmIdTestAB, KDmIdTestABB), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1605
	test(iTestMembers[testMemberCount++] != NULL);
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1606
	TRAP(r, iTestMembers[testMemberCount] = CDomainMemberAo::NewL(GHierarchyIdUnderTest, KDmIdTestCAA, ORDINAL_FROM_DOMAINID3(KDmIdRoot, KDmIdTestC, KDmIdTestCA, KDmIdTestCAA), this));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1607
	test(iTestMembers[testMemberCount++] != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1608
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1609
	// create an observer
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1610
	CHierarchyObserver* observer = NULL;
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1611
	TRAP(r, observer = CHierarchyObserver::NewL(*this, GHierarchyIdUnderTest));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1612
	test (r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1613
	test(observer != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1614
	observer->StartObserver(iObservedDomainId, EDmNotifyAll);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1615
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1616
	// request a state change
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1617
	iTestState =  EStartupCriticalDynamic;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1618
	iTestDomainId = KDmIdRoot;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1619
	iTransitionsCompleted = iTestNotifications = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1620
	iTestNotificationsExpected = testMemberCount;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1621
	iTransitionsExpected = 1;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1622
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1623
	iTransProgEvents = iTransFailEvents = iTransReqEvents = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1624
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1625
	iTransReqEventsExpected = iTransProgEventsExpected = observer->ObserverDomainCount();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1626
	iTransFailEventsExpected = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1627
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1628
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1629
	iTestDomainManager->RequestDomainTransition(iTestDomainId, iTestState, ETraverseDefault);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1630
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1631
	// wait for test transitions to complete
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1632
	CActiveScheduler::Start();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1633
	test(iStatus == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1634
	test(iTestNotifications == iTestNotificationsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1635
	test (iTransProgEvents == iTransProgEventsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1636
	test (iTransFailEvents == iTransFailEventsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1637
	test (iTransReqEvents == iTransReqEventsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1638
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1639
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1640
	// cleanup
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1641
	delete observer; 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1642
	observer = NULL;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1643
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1644
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1645
	// Test 7b - start & stop the observer
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1646
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1647
	test.Next(_L("Test 7b - start & stop the observer"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1648
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1649
	// create an observer, start it stop and then start it again
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1650
	TRAP(r, observer = CHierarchyObserver::NewL(*this, GHierarchyIdUnderTest));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1651
	test (r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1652
	test(observer != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1653
	observer->StartObserver(iObservedDomainId, EDmNotifyAll);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1654
	observer->StopObserver();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1655
	observer->StartObserver(iObservedDomainId, EDmNotifyAll);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1656
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1657
	// request a state change
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1658
	iTestState++;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1659
	iTestDomainId = KDmIdRoot;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1660
	iTransitionsCompleted = iTestNotifications = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1661
	iTestNotificationsExpected = testMemberCount;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1662
	iTransitionsExpected = 1;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1663
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1664
	iTransProgEvents = iTransFailEvents = iTransReqEvents = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1665
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1666
	iTransProgEventsExpected = iTransReqEventsExpected = observer->ObserverDomainCount();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1667
	iTransFailEventsExpected = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1668
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1669
	iTestDomainManager->RequestDomainTransition(iTestDomainId, iTestState, ETraverseDefault);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1670
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1671
	// wait for test transitions to complete
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1672
	CActiveScheduler::Start();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1673
	test(iStatus == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1674
	test(iTestNotifications == iTestNotificationsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1675
	test (iTransProgEvents == iTransProgEventsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1676
	test (iTransFailEvents == iTransFailEventsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1677
	test (iTransReqEvents == iTransReqEventsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1678
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1679
	// stop the observer & request another state change
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1680
	observer->StopObserver();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1681
	iTestState++;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1682
	iTestDomainId = KDmIdRoot;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1683
	iTransitionsCompleted = iTestNotifications = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1684
	iTestNotificationsExpected = testMemberCount;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1685
	iTransitionsExpected = 1;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1686
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1687
	iTransProgEvents = iTransFailEvents = iTransReqEvents = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1688
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1689
	iTransProgEventsExpected = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1690
	iTransFailEventsExpected = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1691
	iTransReqEventsExpected = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1692
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1693
	iTestDomainManager->RequestDomainTransition(iTestDomainId, iTestState, ETraverseDefault);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1694
	// wait for test transitions to complete
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1695
	CActiveScheduler::Start();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1696
	test(iStatus == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1697
	test(iTestNotifications == iTestNotificationsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1698
	test (iTransProgEvents == iTransProgEventsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1699
	test (iTransFailEvents == iTransFailEventsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1700
	test (iTransReqEvents == iTransReqEventsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1701
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1702
	// Start the observer again on a different domain and only ask for transition requests
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1703
	// Then request another state change
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1704
	observer->StartObserver((iObservedDomainId == KDmIdRoot)?KDmIdTestCA:KDmIdRoot, EDmNotifyTransRequest);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1705
	iTestState++;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1706
	iTestDomainId = KDmIdRoot;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1707
	iTransitionsCompleted = iTestNotifications = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1708
	iTestNotificationsExpected = testMemberCount;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1709
	iTransitionsExpected = 1;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1710
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1711
	iTransProgEvents = iTransFailEvents = iTransReqEvents = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1712
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1713
	iTransReqEventsExpected = observer->ObserverDomainCount();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1714
	iTransProgEventsExpected = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1715
	iTransFailEventsExpected = 0;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1716
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1717
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1718
	iTestDomainManager->RequestDomainTransition(iTestDomainId, iTestState, ETraverseDefault);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1719
	// wait for test transitions to complete
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1720
	CActiveScheduler::Start();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1721
	test(iStatus == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1722
	test(iTestNotifications == iTestNotificationsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1723
	test (iTransProgEvents == iTransProgEventsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1724
	test (iTransFailEvents == iTransFailEventsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1725
	test (iTransReqEvents == iTransReqEventsExpected);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1726
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1727
	delete observer; 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1728
	observer = NULL;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1729
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1730
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1731
	// Test 7c - invalid arguments testing for observer
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1732
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1733
	test.Next(_L("Test 7c - Invalid arguments testing for observer"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1734
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1735
	const TDmHierarchyId	KDmHierarchyIdInvalid = 110;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1736
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1737
	test.Printf(_L("Test 7c.1 - create observer with invalid hierarchy Id\n"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1738
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1739
	// create an observer
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1740
	TRAP(r, observer = CHierarchyObserver::NewL(*this, KDmHierarchyIdInvalid));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1741
	test (r == KErrBadHierarchyId);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1742
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1743
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1744
	test.Printf(_L("Test 7c.2 - Starting the observer with wrong domain Id\n"));
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1745
	TRAP(r, observer = CHierarchyObserver::NewL(*this, GHierarchyIdUnderTest));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1746
	test (r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1747
	test(observer != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1748
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1749
	//Wrong domain Id
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1750
	const TDmDomainId	KDmIdInvalid	= 0x0f;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1751
	r= observer->StartObserver(KDmIdInvalid, EDmNotifyAll);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1752
	test(r==KDmErrBadDomainId);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1753
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1754
	test.Printf(_L("Test 7c.3 - Trying to create second observer on the same hierarchy\n"));
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1755
	TRAP(r, CHierarchyObserver::NewL(*this, GHierarchyIdUnderTest));
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1756
	test (r == KDmErrBadSequence);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1757
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1758
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1759
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1760
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1761
	// Test 7d - Wrong sequence of API calls for observer
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1762
	//*************************************************
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1763
	test.Next(_L("Test 7d - Observer wrong sequence of calls"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1764
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1765
	test.Printf(_L("Test 7d.1 - Stopping Observer before starting it\n"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1766
	r = observer->StopObserver();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1767
	test(r==KDmErrBadSequence);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1768
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1769
	test.Printf(_L("Test 7d.2 - Starting Observer twice\n"));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1770
	r= observer->StartObserver(KDmIdRoot, EDmNotifyAll);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1771
	test(r==KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1772
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1773
	r= observer->StartObserver(KDmIdRoot, EDmNotifyAll);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1774
	test(r==KDmErrBadSequence);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1775
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1776
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1777
	delete observer;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1778
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1779
	/***************************************/
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1780
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1781
	delete iTestDomainManager;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1782
	iTestDomainManager = NULL;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1783
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1784
	CDomainMemberAo** mt;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1785
	for (mt = iTestMembers; *mt; ++mt)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1786
		delete *mt;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1787
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1788
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1789
	// restore the domain hierarchies to their initial state so as not to 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1790
	// upset any subsequent tests which rely on this
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1791
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1792
	RDmDomainManager manager;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1793
	TRequestStatus status;
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1794
	TInt r = manager.Connect(GHierarchyIdUnderTest);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1795
	test (r == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1796
	manager.RequestDomainTransition(KDmIdRoot, EStartupCriticalStatic, ETraverseDefault, status);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1797
	User::WaitForRequest(status);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1798
	test(status.Int() == KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1799
	manager.Close();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1800
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1801
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1802
 	__UHEAP_MARKEND;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1803
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1804
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1805
// This handles a transition notification from a test domain member.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1806
TInt CDmTest7::TransitionNotification(MDmDomainMember& aDomainMember)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1807
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1808
		
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1809
	iTestNotifications++;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1810
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1811
	test (aDomainMember.HierarchyId() == GHierarchyIdUnderTest);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1812
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1813
	TBuf16<4> buf;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1814
	GetDomainDesc(aDomainMember.Ordinal(), buf);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1815
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1816
	__PRINT((_L("CDmTest7::TransitionNotification(), Hierarchy = %d, domain = %S, iOrdinal = 0x%08X, state = 0x%x, status = %d\n"), 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1817
		aDomainMember.HierarchyId(), &buf, aDomainMember.Ordinal(), aDomainMember.State(), aDomainMember.Status()));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1818
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1819
	return KErrNone;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1820
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1821
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1822
void CDmTest7::RunL()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1823
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1824
	iTransitionsCompleted++;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1825
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1826
	__PRINT((_L("CDmTest7::RunL(), error = %d, iTestNotifications %d\n"), 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1827
		iStatus.Int(), iTestNotifications));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1828
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1829
	TestForCompletion();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1830
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1831
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1832
void CDmTest7::TransitionRequestComplete()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1833
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1834
	iTransitionsCompleted++;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1835
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1836
	__PRINT((_L("CDmTest7::TransitionRequestComplete(), error = %d, iTestNotifications %d\n"), 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1837
		iStatus.Int(), iTestNotifications));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1838
	
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1839
	TestForCompletion();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1840
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1841
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1842
void CDmTest7::DoCancel()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1843
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1844
	test(0);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1845
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1846
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1847
void CDmTest7::Release()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1848
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1849
	delete this;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1850
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1851
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1852
void CDmTest7::TestForCompletion()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1853
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1854
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1855
	if (iTransitionsCompleted == iTransitionsExpected &&
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1856
		iTransProgEvents == iTransProgEventsExpected && 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1857
		iTransFailEvents == iTransFailEventsExpected &&
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1858
		iTransReqEvents == iTransReqEventsExpected)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1859
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1860
		CActiveScheduler::Stop();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1861
		}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1862
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1863
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1864
#ifdef _DEBUG
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1865
void CDmTest7::TransProgEvent(TDmDomainId aDomainId, TDmDomainState aState)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1866
#else
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1867
void CDmTest7::TransProgEvent(TDmDomainId /*aDomainId*/, TDmDomainState /*aState*/)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1868
#endif
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1869
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1870
	iTransProgEvents++;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1871
	__PRINT((_L("CDmTest7::TransProgEvent(), aDomainId = %d, aState %d, iTransProgEvents %d\n"), 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1872
		aDomainId, aState, iTransProgEvents));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1873
	TestForCompletion();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1874
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1875
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1876
#ifdef _DEBUG
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1877
void CDmTest7::TransFailEvent(TDmDomainId aDomainId, TDmDomainState aState, TInt aError)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1878
#else
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1879
void CDmTest7::TransFailEvent(TDmDomainId /*aDomainId*/, TDmDomainState /*aState*/, TInt /*aError*/)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1880
#endif
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1881
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1882
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1883
	iTransFailEvents++;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1884
	__PRINT((_L("CDmTest7::TransFailEvent(), aDomainId = %d, aState %d aError %d, iTransFailEvents %d\n"), 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1885
		aDomainId, aState, iTransFailEvents, aError));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1886
	TestForCompletion();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1887
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1888
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1889
#ifdef _DEBUG
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1890
void CDmTest7::TransReqEvent(TDmDomainId aDomainId, TDmDomainState aState)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1891
#else
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1892
void CDmTest7::TransReqEvent(TDmDomainId /*aDomainId*/, TDmDomainState /*aState*/)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1893
#endif
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1894
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1895
	iTransReqEvents++;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1896
	__PRINT((_L("CDmTest7::TransReqEvent(), aDomainId = %d, aState %d, iTransReqEvents %d\n"), 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1897
		aDomainId, aState, iTransReqEvents));
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1898
	TestForCompletion();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1899
	}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  1900
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1901
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1902
/**
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1903
   Increase code coverage, in particular get CPowerUpHandler::DoCancel()
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1904
   called.
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1905
*/
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1906
class CDmPowerCoverageTest : public CActive, public MDmTest
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1907
	{
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1908
public:
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1909
	CDmPowerCoverageTest();
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1910
	~CDmPowerCoverageTest()
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1911
		{
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1912
		Cancel();
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1913
		iManager.Close();
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1914
		delete iMember;
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1915
		}
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1916
	// from CActive
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1917
	void RunL();
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1918
	// from MDmTest
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1919
	void Perform();
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1920
	void Release();
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1921
	TInt TransitionNotification(MDmDomainMember&);
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1922
	void TransitionRequestComplete()
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1923
		{}
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1924
private:
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1925
	// from CActive
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1926
	virtual void DoCancel()
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1927
		{
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1928
		test(0);
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1929
		}
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1930
private:
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1931
	CDmTestMember* iMember;
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1932
	RDmDomainManager iManager;
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1933
	};
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1934
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1935
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1936
CDmPowerCoverageTest::CDmPowerCoverageTest()
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1937
	: CActive(CActive::EPriorityStandard)
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1938
	{}
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1939
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1940
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1941
void CDmPowerCoverageTest::RunL()
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1942
	{
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1943
	RDebug::Printf("CDmPowerCoverageTest::RunL(): %d", iStatus.Int());
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1944
	CActiveScheduler::Stop();
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1945
	}
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1946
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1947
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1948
void CDmPowerCoverageTest::Perform()
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1949
	{
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1950
	test.Next(_L("CDmPowerCoverageTest"));
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1951
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1952
	iMember = new CDmTestMember(KDmHierarchyIdPower, KDmIdApps, 0, this);
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1953
	test(iMember != NULL);
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1954
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1955
	TInt r = iManager.Connect();
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1956
	test(r == KErrNone);
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1957
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1958
	CActiveScheduler::Add(this);
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1959
	iManager.RequestSystemTransition(EPwStandby, iStatus);
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1960
	iManager.CancelTransition();
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1961
	CActive::SetActive();
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1962
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1963
	CActiveScheduler::Start();
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1964
	}
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1965
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1966
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1967
TInt CDmPowerCoverageTest::TransitionNotification(MDmDomainMember&)
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1968
	{
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1969
	RDebug::Printf("CDmPowerCoverageTest::TransitionNotification()");
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1970
	// Don't acknowledge
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1971
	return KErrAbort;
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1972
	}
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1973
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1974
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1975
void CDmPowerCoverageTest::Release()
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1976
	{
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1977
	delete this;
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1978
	}
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1979
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1980
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1981
/**
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1982
Test disconnecting domain controller from server whilst
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1983
transition in progress
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1984
*/
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1985
class CDmTestDisconnect : public CBase, public MDmTest
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1986
	{
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1987
public:
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1988
	~CDmTestDisconnect();
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1989
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1990
	// from MDmTest
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1991
	void Perform();
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1992
	void Release();
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1993
	TInt TransitionNotification(MDmDomainMember& aDomainMember);
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1994
	void TransitionRequestComplete() {test(EFalse);}
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1995
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1996
protected:
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1997
	CDmTestMember*		iMember;
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1998
	RDmDomainManager	iManager;
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  1999
	};
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2000
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2001
CDmTestDisconnect::~CDmTestDisconnect()
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2002
	{
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2003
	delete iMember;
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2004
	iManager.Close();
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2005
	}
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2006
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2007
void CDmTestDisconnect::Perform()
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2008
	{
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2009
	TInt r = RDmDomainManager::AddDomainHierarchy(GHierarchyIdUnderTest);
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2010
	test_KErrNone(r);
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2011
	test.Next(_L("Test disconnecting controller during transition"));
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2012
	iMember = new (ELeave) CDmTestMember(GHierarchyIdUnderTest, KDmIdTestAB, ORDINAL_FROM_DOMAINID2(KDmIdRoot, KDmIdTestA, KDmIdTestAB), this);
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2013
	r = iManager.Connect(GHierarchyIdUnderTest);
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2014
	test_KErrNone(r);
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2015
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2016
	test_Equal(0, RThread().RequestCount());
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2017
	TRequestStatus status;
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2018
	iManager.RequestDomainTransition(KDmIdRoot, EStartupCriticalStatic, ETraverseDefault, status);
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2019
	CActiveScheduler::Start();
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2020
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2021
	// No User::WaitForRequest is used, since it is expected that
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2022
	// the outstanding request will not be completed
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2023
	test_Equal(0, RThread().RequestCount());
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2024
	}
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2025
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2026
TInt CDmTestDisconnect::TransitionNotification(MDmDomainMember&)
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2027
	{
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2028
	iManager.Close();
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2029
	CActiveScheduler::Stop();
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2030
	return KErrNone;
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2031
	}
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2032
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2033
void CDmTestDisconnect::Release()
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2034
	{
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2035
	delete this;
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2036
	}
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2037
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2038
void RunTests(TInt aIter)
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2039
	{
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2040
	while (aIter--)
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2041
		{
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2042
		MDmTest* tests[] = 
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2043
			{
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2044
			new CDmTestDisconnect(),
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2045
			new CDmTest1(KDmIdRoot, EPwStandby),
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2046
			new CDmTest1(KDmIdRoot, EPwOff),
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2047
			new CDmTest1(KDmIdRoot, EPwActive),
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2048
			new CDmTest1(KDmIdApps, EPwStandby),
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2049
			new CDmTest1(KDmIdApps, EPwOff),
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2050
			new CDmTest1(KDmIdApps, EPwActive),
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2051
			new CDmTest1(KDmIdUiApps, EPwStandby),
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2052
			new CDmTest1(KDmIdUiApps, EPwOff),
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2053
			new CDmTest1(KDmIdUiApps, EPwActive),
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2054
			new CDmTest2(EPwStandby),
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2055
			new CDmTest3(),
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2056
	
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2057
			// platform security tests
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2058
			new CDmTest4(),
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2059
	
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2060
			// PREQ810 tests :
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2061
			// note that we use a fictitious power state to prevent any 
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2062
			new CDmTest5(KDmIdRoot, KDmIdRoot, EPwActive+10, EStartupCriticalDynamic),
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2063
			new CDmTest5(KDmIdUiApps, KDmIdTestAB, EPwActive+10, EStartupCriticalDynamic),
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2064
	
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2065
		    // negative tests
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2066
			new CDmTest6(),
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2067
	
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2068
	
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2069
			// observer tests
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2070
	 		new CDmTest7(KDmIdTestA),
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2071
			new CDmTest7(KDmIdRoot),
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2072
			
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2073
			// increase code coverage
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2074
			new CDmPowerCoverageTest(),
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2075
			};
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2076
	
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2077
		for (unsigned int i = 0; i < sizeof(tests)/sizeof(*tests); ++i)
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2078
			{
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2079
			test(tests[i] != NULL);
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2080
			tests[i]->Perform();
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2081
			tests[i]->Release();
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2082
			}
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2083
		}
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2084
	}
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2085
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2086
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2087
GLDEF_C TInt E32Main()
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2088
	{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2089
	CTrapCleanup* trapHandler=CTrapCleanup::New();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2090
	test(trapHandler!=NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2091
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2092
	CActiveScheduler* scheduler = new CActiveScheduler();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2093
	test(scheduler != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2094
	CActiveScheduler::Install(scheduler);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2095
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2096
	// Turn off evil lazy dll unloading
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2097
	RLoader l;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2098
	test(l.Connect()==KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2099
	test(l.CancelLazyDllUnload()==KErrNone);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2100
	l.Close();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2101
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2102
	//
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2103
	// Perform the number of iterations specifed by the command line argument.
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2104
	//
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2105
	// If no arguments - perform one iteration
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2106
	//
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2107
    TInt iter = 1;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2108
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2109
	TInt len = User::CommandLineLength();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2110
	if (len)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2111
		{
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2112
		// Copy the command line in a buffer
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2113
		HBufC* hb = HBufC::NewMax(len);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2114
		test(hb != NULL);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2115
		TPtr cmd((TUint16*) hb->Ptr(), len);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2116
		User::CommandLine(cmd);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2117
		// Extract the number of iterations
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2118
		TLex l(cmd);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2119
		TInt i;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2120
		TInt r = l.Val(i);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2121
		if (r == KErrNone)
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2122
			iter = i;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2123
		else
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2124
			// strange command - silently ignore
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2125
			{} 
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2126
		delete hb;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2127
		}
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2128
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2129
	test.Title();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2130
	test.Printf(_L("Go for %d iterations\n"), iter);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2131
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2132
	// Remember the number of open handles. Just for a sanity check ....
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2133
	TInt start_thc, start_phc;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2134
	RThread().HandleCount(start_phc, start_thc);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2135
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2136
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2137
	test.Start(_L("Test run with original test Hierarchy"));	
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2138
	GHierarchyIdUnderTest = KDmHierarchyIdTest;
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2139
	RunTests(iter);
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2140
	test.End();
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2141
	
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2142
	
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2143
	test.Start(_L("Test run with original test Hierarchy as V2 policy"));	
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2144
	GHierarchyIdUnderTest = KDmHierarchyIdTestV2_97;
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2145
	RunTests(iter);
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2146
	test.End();
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2147
279
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2148
	test.Start(_L("Test run with original test Hierarchy as V2 policy, but NULL state specification"));	
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2149
	GHierarchyIdUnderTest = KDmHierarchyIdTestV2_96;
957c583b417b 201039_07
hgs
parents: 269
diff changeset
  2150
	RunTests(iter);
245
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2151
	test.End();
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2152
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2153
	// Sanity check for open handles and for pending requests ...
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2154
	TInt end_thc, end_phc;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2155
	RThread().HandleCount(end_phc, end_thc);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2156
	test(start_thc == end_thc);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2157
	test(start_phc == end_phc);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2158
	test(RThread().RequestCount() >= 0);
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2159
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2160
	delete scheduler;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2161
	delete trapHandler;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2162
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2163
	return KErrNone;
647ab20fee2e 201031_10
hgs
parents:
diff changeset
  2164
	}