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