| author | Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> | 
| Tue, 31 Aug 2010 16:34:26 +0300 | |
| branch | RCL_3 | 
| changeset 43 | c1f20ce4abcf | 
| parent 4 | 56f325a607ea | 
| child 44 | 3e88ff8f41d5 | 
| permissions | -rw-r--r-- | 
| 0 | 1 | // Copyright (c) 2007-2009 Nokia Corporation and/or its subsidiary(-ies). | 
| 2 | // All rights reserved. | |
| 3 | // This component and the accompanying materials are made available | |
| 4 | // under the terms of the License "Eclipse Public License v1.0" | |
| 5 | // which accompanies this distribution, and is available | |
| 6 | // at the URL "http://www.eclipse.org/legal/epl-v10.html". | |
| 7 | // | |
| 8 | // Initial Contributors: | |
| 9 | // Nokia Corporation - initial contribution. | |
| 10 | // | |
| 11 | // Contributors: | |
| 12 | // | |
| 13 | // Description: | |
| 14 | // e32test\resourceman\t_rescontrolcli.cpp | |
| 15 | // TestCase Description: | |
| 16 | // This tests is intended to test the generic layer of PRM. It consists of unit testing and regression testing. | |
| 17 | // Unit testing validates each of the API's. Regression testing performs random operation on random resource and | |
| 18 | // currently executes 500 operations and returns. | |
| 19 | // To run regression testing, test must be invoked with -R option. | |
| 20 | // Testing runs only on simulated PSL. | |
| 21 | // | |
| 22 | // | |
| 23 | ||
| 24 | #include <e32test.h> | |
| 25 | #include <e32hal.h> | |
| 26 | #include <e32math.h> | |
| 27 | #include <e32def.h> | |
| 28 | #include <e32def_private.h> | |
| 29 | #include "d_rescontrolcli.h" | |
| 30 | ||
| 43 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 31 | #include <drivers/resourcecontrol_clientsettings.h> | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 32 | #include <drivers/resourcecontrol_settings.h> | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 33 | |
| 0 | 34 | #define MAX_STATIC_RESOURCE_NUM 24 //Maximum number of static resources in simulated PSL | 
| 35 | #define MAX_STATIC_DEPENDENCY_RESOURCE_NUM 7 //Maximum number of static dependency resources in simulated PSL | |
| 36 | #define DEPENDENCY_RESOURCE_BIT_MASK 0x00010000 | |
| 37 | #define DYNAMIC_RESOURCE_BIT_MASK 0x00020000 | |
| 38 | #define CUSTOM_RESOURCE_NUMBER 20 | |
| 39 | ||
| 40 | /** Macro to push the item into the specified list. Item are pushed to the head of the list. */ | |
| 41 | #define LIST_PUSH(list,item,link) \ | |
| 42 | 	{							   	\
 | |
| 43 | (item)->link = (list); \ | |
| 44 | (list) = (item); \ | |
| 45 | } | |
| 46 | ||
| 47 | /** Macro to pop the item from the specified list. Item are poped from the head of the list. */ | |
| 48 | #define LIST_POP(list,item,link) \ | |
| 49 | 	{							   	\
 | |
| 50 | (item) = (list); \ | |
| 51 | if ((item)) \ | |
| 52 | 		{							\
 | |
| 53 | (list) = (item)->link; \ | |
| 54 | (item)->link = NULL; \ | |
| 55 | } \ | |
| 56 | } | |
| 57 | ||
| 58 | /** Macro to remove the item from the list. */ | |
| 59 | #define LIST_REMOVE(list,item,link,className) \ | |
| 60 | if (list) \ | |
| 61 | 		{											\
 | |
| 62 | className* current = (list); \ | |
| 63 | if (current==(item)) \ | |
| 64 | 			{										\
 | |
| 65 | (list) = (item)->link; \ | |
| 66 | (item)->link = NULL; \ | |
| 67 | } \ | |
| 68 | else \ | |
| 69 | 			{										\
 | |
| 70 | className* next = current->link; \ | |
| 71 | while (next) \ | |
| 72 | 				{									\
 | |
| 73 | if ((item)==next) \ | |
| 74 | 					{								\
 | |
| 75 | current->link=next->link; \ | |
| 76 | next->link = NULL; \ | |
| 77 | break; \ | |
| 78 | } \ | |
| 79 | current = next; \ | |
| 80 | next = next->link; \ | |
| 81 | } \ | |
| 82 | } \ | |
| 83 | } | |
| 84 | ||
| 85 | #ifndef PRM_ENABLE_EXTENDED_VERSION | |
| 86 | _LIT(KLddFileName, "D_RESCONTROLCLI.LDD"); | |
| 87 | _LIT(KPddFileName, "resourcecontroller.pdd"); | |
| 88 | #else | |
| 89 | _LIT(KExtLddFileName, "D_EXTENDEDRESCONTROLCLI.LDD"); | |
| 90 | _LIT(KExtPddFileName, "resourcecontrollerextended.pdd"); | |
| 91 | #endif | |
| 92 | ||
| 93 | LOCAL_D RTest test(_L("RESOURCE_MANAGER_TEST"));
 | |
| 94 | TBuf8<32> SpecialResName(_L8("SymbianSimulResource"));
 | |
| 95 | ||
| 96 | //Enum definition for resource classification. | |
| 97 | enum TType  {EMultiLevel = 0x1, EMultiProperty};
 | |
| 98 | enum TUsage {ESingle, EShared};
 | |
| 99 | enum TLatency {EInstantaneous, ELongLatency};
 | |
| 100 | enum TClass {EPhysical, ELogical};
 | |
| 101 | enum TSense {EPositive, ENegative, ECustom};
 | |
| 102 | ||
| 103 | //Structure to get resource information | |
| 104 | class TPowerResourceInfoV01 | |
| 105 | 	{
 | |
| 106 | public: | |
| 107 | TClass iClass; | |
| 108 | TLatency iLatencyGet; | |
| 109 | TLatency iLatencySet; | |
| 110 | TType iType; | |
| 111 | TUsage iUsage; | |
| 112 | TSense iSense; | |
| 113 | TDesC8* iResourceName; | |
| 114 | TUint iResourceId; | |
| 115 | TInt iDefaultLevel; | |
| 116 | TInt iMinLevel; | |
| 117 | TInt iMaxLevel; | |
| 118 | TInt iReserved1; | |
| 119 | TInt iReserved2; | |
| 120 | TInt iReserved3; | |
| 121 | TInt iPslReserved1; | |
| 122 | TInt iPslReserved2; | |
| 123 | TInt iPslReserved3; | |
| 124 | }; | |
| 125 | ||
| 126 | //Structure to get client information | |
| 127 | struct TPowerClientInfoV01 | |
| 128 | 	{
 | |
| 129 | TUint iClientId; | |
| 130 | TDesC8* iClientName; | |
| 131 | }; | |
| 132 | ||
| 133 | //Structure for holding client information | |
| 134 | struct RMClientInfo | |
| 135 | 	{
 | |
| 136 | TUint iClientId; | |
| 137 | TUint iNumResources; | |
| 138 | TUint iResourceIds[MAX_STATIC_RESOURCE_NUM]; //Each bit corresponds to a static resource. | |
| 139 | }; | |
| 140 | ||
| 141 | //Structure for holding notification information | |
| 142 | struct NotiInfo | |
| 143 | 	{
 | |
| 144 | TUint iClientId; | |
| 145 | TInt iThreshold; | |
| 146 | TInt iDirection; | |
| 147 | TInt iPreviousLevel; | |
| 148 | NotiInfo *iNext; | |
| 149 | }; | |
| 150 | ||
| 151 | // Structure for holding client level | |
| 152 | struct SPowerResourceClientLevel | |
| 153 | 	{
 | |
| 154 | TUint iClientId; | |
| 155 | TUint iResourceId; | |
| 156 | TInt iLevel; | |
| 157 | SPowerResourceClientLevel* iNextInList; | |
| 158 | }; | |
| 159 | ||
| 160 | //Structure for capturing resource information to be used by Idle thread. | |
| 161 | struct SIdleResourceInfo | |
| 162 | 	{
 | |
| 163 | TUint iResourceId; | |
| 164 | TInt iLevelOwnerId; | |
| 165 | TInt iCurrentLevel; | |
| 166 | TInt iReserved1; //Reserved for future use. | |
| 167 | TInt iReserved2; //Reserved for future use. | |
| 168 | TInt iReserved3; //Reserved for future use. | |
| 169 | }; | |
| 170 | ||
| 171 | //Structure for holding resource information | |
| 172 | struct RMResInfo | |
| 173 | 	{
 | |
| 174 | TBuf8<32> iName; | |
| 175 | TUint iResourceId; | |
| 176 | TInt iMaxLevel; | |
| 177 | TInt iMinLevel; | |
| 178 | TInt iDefaultLevel; | |
| 179 | TInt iCurrentLevel; | |
| 180 | TInt iCurrentClient; | |
| 181 | TUint iNumClients; | |
| 182 | TSense iSense; | |
| 183 | TType iType; | |
| 184 | TLatency iLatencyGet; | |
| 185 | TLatency iLatencySet; | |
| 186 | TUsage iUsage; | |
| 187 | TUint iUnCondNotiCount; | |
| 188 | NotiInfo *iCondNoti; | |
| 189 | NotiInfo *iUncondNoti; | |
| 190 | SPowerResourceClientLevel *iLevel; | |
| 191 | }; | |
| 192 | ||
| 193 | //Test class. | |
| 194 | class TestRM | |
| 195 | 	{
 | |
| 196 | private: | |
| 197 | //Possible resource operation. | |
| 198 | enum Operation | |
| 199 | 		{
 | |
| 200 | ERegisterClient = 0, | |
| 201 | EGetClientName = 1, | |
| 202 | EGetAllClientName = 2, | |
| 203 | EGetClientId = 3, | |
| 204 | EGetResourceId = 4, | |
| 205 | EGetResourceInfo = 5, | |
| 206 | EGetNumReosourceInUseByClient = 6, | |
| 207 | EGetInfoOnResourceInUseByClient = 7, | |
| 208 | EGetNumClientsUsingResource = 8, | |
| 209 | EGetInfoOnClientsUsingResource = 9, | |
| 210 | EChangeResourceStateSync = 10, | |
| 211 | EChangeResourceStateAsync = 11, | |
| 212 | EGetResourceStateSync = 12, | |
| 213 | EGetResourceStateAsync = 13, | |
| 214 | ERequestNotificationCond = 14, | |
| 215 | ERequestNotificationUnCond = 15, | |
| 216 | ECancelNotificationCond = 16, | |
| 217 | ECancelNotificationUnCond = 17, | |
| 218 | EOperationEnd = 18 | |
| 219 | }; | |
| 220 | public: | |
| 221 | TestRM(); | |
| 222 | void RegisterClient(); | |
| 223 | void DeRegisterClient(TUint aClientId); | |
| 224 | void GetClientName(TUint aClientId); | |
| 225 | void GetClientId(TUint aClientId); | |
| 226 | void GetResourceId(TUint aResId); | |
| 227 | void GetResourceInfo(TUint aResId); | |
| 228 | void GetNumResourcesInUseByClient(TInt aClientId); | |
| 229 | void GetInfoOnResourcesInUseByClient(TInt aClientId, TUint aNumRes); | |
| 230 | void GetNumClientsUsingResource(TUint aClientId, TUint aResId); | |
| 231 | void GetInfoOnClientsUsingResource(TUint aResId, TUint aNumCli); | |
| 232 | void AllocReserve(TUint aClientId); | |
| 233 | void CheckNotification(TUint aResId, TInt newState); | |
| 234 | void AddClientLevel(TUint aResId, TInt newState); | |
| 235 | void UpdateClientInformation(TUint aResId, TInt aNewState); | |
| 236 | void ChangeResourceStateSync(TUint aResId); | |
| 237 | void ChangeResourceStateAsync(TUint aResId, TBool aReqCancel=EFalse); | |
| 238 | void GetResourceStateSync(TUint aResId); | |
| 239 | void GetResourceStateAsync(TUint aResId, TBool aReqCancel=EFalse); | |
| 240 | void RequestNotification(TUint aResId); | |
| 241 | void RequestNotificationCon(TUint aResId); | |
| 242 | void ValidateClient(TUint aNumClients, TOwnerType aContext); | |
| 243 | void CancelNotification(TUint aResId, TBool Cond); | |
| 244 | void APIValidationTest(); | |
| 245 | void SharedBinaryPositiveResourceTesting(TUint aResId); | |
| 246 | void SharedBinaryNegativeResourceTesting(TUint aResId); | |
| 247 | void CustomResourceTesting(TUint aResId); | |
| 248 | void DeRegisterClientLevelFromResource(TInt aClientId, TUint aResId); | |
| 249 | void RegressionTest(); | |
| 250 | void TestStaticResourceWithDependency(); | |
| 251 | void GetExtendedResStateAsyncAndVerify(TUint aResId, TInt aState, TInt aLevelOwnerId, TBool aReqCancel = EFalse); | |
| 252 | void GetExtendedResStateAndVerify(TUint aResId, TInt aState, TInt aLevelOwnerId); | |
| 253 | void TestDynamicResource(); | |
| 254 | void TestDynamicResourceDependency(); | |
| 255 | void CheckForDependencyInformation(TUint aClientId, TUint aResourceId, TUint aNumDependents, SResourceDependencyInfo* aDepResIdArray); | |
| 256 | void SharedMultilevelNegativeResourceTesting(TUint aResId); | |
| 257 | void SharedMultilevelPositiveResourceTesting(TUint aResId); | |
| 258 | private: | |
| 259 | RArray<RMClientInfo> Clients; | |
| 260 | RMResInfo Resources[MAX_STATIC_RESOURCE_NUM]; | |
| 261 | TUint iStaticDependencyResources[MAX_STATIC_DEPENDENCY_RESOURCE_NUM]; | |
| 262 | TInt iCurrentClientId; | |
| 263 | TUint iMaxClientId; | |
| 264 | TUint iMaxClients; | |
| 265 | TUint iMaxStaticResources; | |
| 266 | TUint iMaxStaticDependentResources; | |
| 267 | TUint iPowerControllerId; | |
| 268 | TUint iTestingExtendedVersion; | |
| 269 | }; | |
| 270 | ||
| 271 | TBool NegativeTesting; //If true enables negative testing of API's | |
| 272 | TInt r = KErrNone; | |
| 273 | TBuf8<32> ClientName(_L8("Client?"));
 | |
| 274 | RTestResMan lddChan; | |
| 275 | TestRM RmTest; | |
| 276 | ||
| 277 | //Class constructor | |
| 278 | TestRM::TestRM(): iCurrentClientId(-1),iMaxClientId(0), iMaxClients(0),iMaxStaticResources(0), iMaxStaticDependentResources(0), iTestingExtendedVersion(0) | |
| 279 | 	{
 | |
| 280 | 	test.Printf(_L("TestRM::TestRM()\n"));
 | |
| 281 | } | |
| 282 | ||
| 283 | //---------------------------------------------------------------------------------------------- | |
| 284 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0573 | |
| 285 | //! @SYMTestType UT | |
| 286 | //! @SYMPREQ PREQ1398 | |
| 287 | //! @SYMTestCaseDesc This test case tests the client registeration functionality of resource | |
| 288 | //! manager.It registeres a client with resource manager and stores the relevant | |
| 289 | //! information in Clients array. Currently allows only maximum of 50 client | |
| 290 | //! registration. | |
| 291 | //! @SYMTestActions 0 Returns if already maximum allowable clients are registered. | |
| 292 | //! 1 Register a client with the resource manager with a unique name. | |
| 293 | //! 2 Appends the client information to an array for futher reference. | |
| 294 | //! | |
| 295 | //! @SYMTestExpectedResults client registration is successful, panics otherwise. | |
| 296 | //! @SYMTestPriority High | |
| 297 | //! @SYMTestStatus Implemented | |
| 298 | //---------------------------------------------------------------------------------------------- | |
| 299 | void TestRM::RegisterClient() | |
| 300 | 	{
 | |
| 301 | TUint clientId = 0; | |
| 302 | RMClientInfo info; | |
| 303 | if(iMaxClientId > MAX_CLIENTS) | |
| 304 | 		{
 | |
| 305 | 		test.Printf(_L("Reached maximum client allocation. Can't allocate more\n"));
 | |
| 306 | return; | |
| 307 | } | |
| 308 | 	ClientName[6] = (TUint8)('0' + iMaxClientId);
 | |
| 309 | r = lddChan.RegisterClient(clientId, (const TDesC*)&ClientName); | |
| 310 | if(r != KErrNone) | |
| 311 | 		test.Printf(_L("Register Client failed with %d\n"), r);
 | |
| 312 | test(r == KErrNone); | |
| 313 | info.iClientId = clientId; | |
| 314 | info.iNumResources = 0; | |
| 315 | for(TUint c = 0; c< MAX_STATIC_RESOURCE_NUM; c++) | |
| 316 | info.iResourceIds[c] = 0; | |
| 317 | iMaxClientId++; | |
| 318 | iMaxClients++; | |
| 319 | r = Clients.Append(info); | |
| 320 | if(r != KErrNone) | |
| 321 | 		test.Printf(_L("Client Append failed with %d\n"), r);
 | |
| 322 | test(r == KErrNone); | |
| 323 | } | |
| 324 | ||
| 325 | //---------------------------------------------------------------------------------------------- | |
| 326 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0574 | |
| 327 | //! @SYMTestType UT | |
| 328 | //! @SYMPREQ PREQ1398 | |
| 329 | //! @SYMTestCaseDesc This test case tests the client deregisteration functionality of resource | |
| 330 | //! manager.It deregisteres a client with the resource manager, calculates | |
| 331 | //! the resource level of each resource that the client was having requirement and | |
| 332 | //! checks the resource level change after client deregistration. | |
| 333 | //! @SYMTestActions 0 Deregister a client from resource manager | |
| 334 | //! 1 Calculates the resource level of each resource the client was having requirement. | |
| 335 | //! 2 Checks the resource level change of each resource for correctness. | |
| 336 | //! 3 Zeros the clientId stored internally to make sure it is not referenced again. | |
| 337 | //! | |
| 338 | //! @SYMTestExpectedResults client deregistration is successful and also the resource level of | |
| 339 | //! each resource the client was holding the resource level is checked | |
| 340 | //! for correctness, panics otherwise | |
| 341 | //! @SYMTestPriority High | |
| 342 | //! @SYMTestStatus Implemented | |
| 343 | //---------------------------------------------------------------------------------------------- | |
| 344 | void TestRM::DeRegisterClient(TUint aClientId) | |
| 345 | 	{
 | |
| 346 | r = lddChan.DeRegisterClient(Clients[aClientId].iClientId); | |
| 347 | if(r != KErrNone) | |
| 348 | 		test.Printf(_L("Client deregistration of %d failed with %d\n"), Clients[aClientId].iClientId, r);
 | |
| 349 | test(r == KErrNone); | |
| 350 | TUint count; | |
| 351 | for(count = 0; count < iMaxStaticResources; count++) | |
| 352 | 		{
 | |
| 353 | RMResInfo *pR = &Resources[count]; | |
| 354 | NotiInfo* pI = pR->iCondNoti; | |
| 355 | NotiInfo* ptr = NULL; | |
| 356 | //Remove any conditional notification that this client has on resource. | |
| 357 | while(pI != NULL) | |
| 358 | 			{
 | |
| 359 | if(pI->iClientId == aClientId) | |
| 360 | 				{
 | |
| 361 | ptr = pI; | |
| 362 | pI = pI->iNext; | |
| 363 | LIST_REMOVE(pR->iCondNoti, ptr, iNext, NotiInfo); | |
| 364 | delete ptr; | |
| 365 | } | |
| 366 | else | |
| 367 | pI = pI->iNext; | |
| 368 | } | |
| 369 | ||
| 370 | //Remove any unconditional notification that this client has on resource. | |
| 371 | pI = pR->iUncondNoti; | |
| 372 | ptr = NULL; | |
| 373 | while(pI != NULL) | |
| 374 | 			{
 | |
| 375 | if(pI->iClientId == aClientId) | |
| 376 | 				{
 | |
| 377 | ptr = pI; | |
| 378 | pI = pI->iNext; | |
| 379 | LIST_REMOVE(pR->iUncondNoti, ptr, iNext, NotiInfo); | |
| 380 | delete ptr; | |
| 381 | } | |
| 382 | else | |
| 383 | pI = pI->iNext; | |
| 384 | } | |
| 385 | } | |
| 386 | //Remove client level | |
| 387 | TUint res = 0; | |
| 388 | for(count = 0; count < Clients[aClientId].iNumResources; count++) | |
| 389 | 		{
 | |
| 390 | res = Clients[aClientId].iResourceIds[count]; | |
| 391 | if(res == 0) | |
| 392 | continue; | |
| 393 | for(TUint c = 0; c< iMaxStaticResources; c++) | |
| 394 | 			{
 | |
| 395 | if(Resources[c].iResourceId == res) | |
| 396 | 				{
 | |
| 397 | res = c; | |
| 398 | break; | |
| 399 | } | |
| 400 | } | |
| 401 | if(Resources[res].iCurrentClient == (TInt)aClientId) | |
| 402 | 			{
 | |
| 403 | if(!Resources[res].iUsage) | |
| 404 | 				{
 | |
| 405 | Resources[res].iCurrentLevel = Resources[res].iDefaultLevel; | |
| 406 | Resources[res].iCurrentClient = -1; | |
| 407 | Resources[res].iNumClients = 0; | |
| 408 | } | |
| 409 | else if(Resources[res].iSense == ECustom) | |
| 410 | continue; | |
| 411 | else | |
| 412 | 				{
 | |
| 413 | TInt maxLevel = KMinTInt; | |
| 414 | TInt id = -1; | |
| 415 | for(SPowerResourceClientLevel* pCL = Resources[res].iLevel; pCL != NULL; pCL = pCL->iNextInList) | |
| 416 | 					{
 | |
| 417 | if(pCL->iClientId == aClientId) | |
| 418 | continue; | |
| 419 | if((maxLevel == KMinTInt) || (maxLevel == pCL->iLevel)) | |
| 420 | 						{
 | |
| 421 | maxLevel = pCL->iLevel; | |
| 422 | id = pCL->iClientId; | |
| 423 | continue; | |
| 424 | } | |
| 425 | if(Resources[res].iSense == EPositive && pCL->iLevel > maxLevel) | |
| 426 | 						{
 | |
| 427 | maxLevel = pCL->iLevel; | |
| 428 | id = pCL->iClientId; | |
| 429 | } | |
| 430 | else if(Resources[res].iSense == ENegative && pCL->iLevel < maxLevel) | |
| 431 | 						{
 | |
| 432 | maxLevel = pCL->iLevel; | |
| 433 | id = pCL->iClientId; | |
| 434 | } | |
| 435 | } | |
| 436 | if(id == -1) | |
| 437 | 					{
 | |
| 438 | Resources[res].iCurrentLevel = Resources[res].iDefaultLevel; | |
| 439 | Resources[res].iCurrentClient = -1; | |
| 440 | Resources[res].iNumClients = 0; | |
| 441 | } | |
| 442 | else | |
| 443 | 					{
 | |
| 444 | Resources[res].iCurrentLevel = maxLevel; | |
| 445 | Resources[res].iCurrentClient = id; | |
| 446 | Resources[res].iNumClients--; | |
| 447 | } | |
| 448 | } | |
| 449 | } | |
| 450 | //Remove client list entry from resource | |
| 451 | for(SPowerResourceClientLevel* pCL = Resources[res].iLevel; pCL != NULL; pCL = pCL->iNextInList) | |
| 452 | 				{
 | |
| 453 | if(pCL->iClientId == aClientId) | |
| 454 | 					{
 | |
| 455 | LIST_REMOVE(Resources[res].iLevel, pCL, iNextInList, SPowerResourceClientLevel); | |
| 456 | delete pCL; | |
| 457 | break; | |
| 458 | } | |
| 459 | } | |
| 460 | } | |
| 461 | //Verify the resource state consistency | |
| 462 | res = 0; | |
| 463 | TInt newState; | |
| 464 | TInt levelOwnerId; | |
| 465 | if(iMaxClients > 1) | |
| 466 | 		{
 | |
| 467 | for(TUint id = 0; id < Clients[aClientId].iNumResources; id++) | |
| 468 | 			{
 | |
| 469 | res = Clients[aClientId].iResourceIds[id]; | |
| 470 | if(res == 0) | |
| 471 | continue; | |
| 472 | for(TUint c = 0; c< iMaxStaticResources; c++) | |
| 473 | 				{
 | |
| 474 | if(Resources[c].iResourceId == res) | |
| 475 | 					{
 | |
| 476 | res = c; | |
| 477 | break; | |
| 478 | } | |
| 479 | } | |
| 480 | r = lddChan.GetResourceStateSync(Clients[0].iClientId, Resources[res].iResourceId, ETrue, newState, levelOwnerId); | |
| 481 | if(r != KErrNone) | |
| 482 | 				test.Printf(_L("GetResourceStateSync returned with %d"), r);
 | |
| 483 | test(r == KErrNone); | |
| 484 | if(newState != Resources[res].iCurrentLevel) | |
| 485 | 				test.Printf(_L("newState = %d, Resources[%d].iCurrentLevel = %d"), newState, Resources[res].iResourceId, Resources[res].iCurrentLevel);
 | |
| 486 | test(newState == Resources[res].iCurrentLevel); | |
| 487 | if(Resources[res].iCurrentClient == -1) | |
| 488 | test(levelOwnerId == -1); | |
| 489 | else if (levelOwnerId != (TInt)Clients[Resources[res].iCurrentClient].iClientId) | |
| 490 | 				{
 | |
| 491 | 				test.Printf(_L("levelOwnerId = 0x%x, iCurrentClient = 0x%x\n"), levelOwnerId, Resources[res].iCurrentClient);
 | |
| 492 | test(0); | |
| 493 | } | |
| 494 | } | |
| 495 | } | |
| 496 | Clients[aClientId].iClientId = 0; | |
| 497 | iMaxClients--; | |
| 498 | } | |
| 499 | ||
| 500 | //---------------------------------------------------------------------------------------------- | |
| 501 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0575 | |
| 502 | //! @SYMTestType UT | |
| 503 | //! @SYMPREQ PREQ1398 | |
| 504 | //! @SYMTestCaseDesc This test case tests the retrieval of client name functionality of resource | |
| 505 | //! manager and compares for correctness. There are negative and positive tests. | |
| 506 | //! @SYMTestActions If negative testing is enabled then following tests are done | |
| 507 | //! 0 Call the API with invalid client Id (calling client Id). | |
| 508 | //! 1 Call the API with invalid instance count of calling client Id. | |
| 509 | //! 2 Call the API with invalid target client Id. | |
| 510 | //! 3 Call the API with invalid instance count of target client Id. | |
| 511 | //! Positive tests | |
| 512 | //! 4 Call the API with valid client Ids (both calling and target client ID) | |
| 513 | //! | |
| 514 | //! @SYMTestExpectedResults 0 API should return with KErrAccessDenied, panics otherwise | |
| 515 | //! 1 API should return with KErrAccessDenied, panics otherwise | |
| 516 | //! 2 API should return with KErrNotFound, panics otherwise | |
| 517 | //! 3 API should return with KErrNotFound, panics otherwise | |
| 518 | //! 4 API should return KErrNone with name updated and also name | |
| 519 | //! is checked for correctness, panics otherwise | |
| 520 | //! @SYMTestPriority High | |
| 521 | //! @SYMTestStatus Implemented | |
| 522 | //---------------------------------------------------------------------------------------------- | |
| 523 | void TestRM::GetClientName(TUint aClientId) | |
| 524 | 	{
 | |
| 525 | 	ClientName[6] = (TUint8)('0' + aClientId);
 | |
| 526 | TBuf8<32> name; | |
| 527 | if(NegativeTesting) | |
| 528 | 		{
 | |
| 529 | //Pass illegal client Id | |
| 530 | r = lddChan.GetClientName(0, Clients[aClientId].iClientId, (TDes8*)&name); | |
| 531 | test(r == KErrAccessDenied); | |
| 532 | ||
| 533 | //Pass illegal instance count | |
| 534 | TUint id = Clients[aClientId].iClientId; | |
| 535 | id = id ^ (3<<16); | |
| 536 | r = lddChan.GetClientName(id, Clients[aClientId].iClientId, (TDes8*)&name); | |
| 537 | test(r == KErrAccessDenied); | |
| 538 | ||
| 539 | //Pass illegal target client id | |
| 540 | r = lddChan.GetClientName(Clients[aClientId].iClientId, iMaxClients, (TDes8*)&name); | |
| 541 | test(r == KErrNotFound); | |
| 542 | ||
| 543 | //Pass illegal instance count of target client id | |
| 544 | id = id ^ (1<<16); | |
| 545 | r = lddChan.GetClientName(Clients[aClientId].iClientId, 0 ,(TDes8*)&name); | |
| 546 | test(r == KErrNotFound); | |
| 547 | } | |
| 548 | r = lddChan.GetClientName(Clients[aClientId].iClientId, Clients[aClientId].iClientId, (TDes8*)&name); | |
| 549 | if(r != KErrNone) | |
| 550 | 		test.Printf(_L("GetClientName of ClientId 0x%x returned with %d"), Clients[aClientId].iClientId, r);
 | |
| 551 | test(r == KErrNone); | |
| 552 | if(name.Compare(ClientName)) | |
| 553 | test(0); | |
| 554 | } | |
| 555 | ||
| 556 | ||
| 557 | //---------------------------------------------------------------------------------------------- | |
| 558 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0576 | |
| 559 | //! @SYMTestType UT | |
| 560 | //! @SYMPREQ PREQ1398 | |
| 561 | //! @SYMTestCaseDesc This test case tests the retrieval of client ID functionality of resource | |
| 562 | //! manager and compares for correctness. There are negative and positive tests. | |
| 563 | //! @SYMTestActions If negative testing is enabled then following tests are done | |
| 564 | //! 0 Call the API with invalid client Id (calling client Id). | |
| 565 | //! 1 Call the API with invalid instance count of calling client Id. | |
| 566 | //! 2 Call the API with client name greater than maximum allowable | |
| 567 | //! client name (32 characters). | |
| 568 | //! 3 Call the API with name not registered with resource manager | |
| 569 | //! (non-existing name). | |
| 570 | //! Positive tests | |
| 571 | //! 4 Call the API with valid client Id. | |
| 572 | //! | |
| 573 | //! @SYMTestExpectedResults 0 API should return with KErrAccessDenied, panics otherwise | |
| 574 | //! 1 API should return with KErrAccessDenied, panics otherwise | |
| 575 | //! 2 API should return with KErrTooBig, panics otherwise | |
| 576 | //! 3 API should return with KErrNotFound, panics otherwise | |
| 577 | //! 4 API should return KErrNone with client Id updated and also Id | |
| 578 | //! is checked for correctness, panics otherwise | |
| 579 | //! @SYMTestPriority High | |
| 580 | //! @SYMTestStatus Implemented | |
| 581 | //---------------------------------------------------------------------------------------------- | |
| 582 | void TestRM::GetClientId(TUint aClientId) | |
| 583 | 	{
 | |
| 584 | TUint clientId; | |
| 585 | 	ClientName[6] = (TUint8)('0' + aClientId);
 | |
| 586 | if(NegativeTesting) | |
| 587 | 		{
 | |
| 588 | //Pass illegial client Id | |
| 589 | r = lddChan.GetClientId(0, (TDesC8&)ClientName, Clients[aClientId].iClientId); | |
| 590 | test(r == KErrAccessDenied); | |
| 591 | ||
| 592 | //Pass illegal instance count | |
| 593 | TUint id = Clients[aClientId].iClientId; | |
| 594 | id = id ^ (3<<16); | |
| 595 | r = lddChan.GetClientId(id, (TDesC8&)ClientName, Clients[aClientId].iClientId); | |
| 596 | test(r == KErrAccessDenied); | |
| 597 | ||
| 598 | 		TBuf8<50> badName = _L8("Clientnamegreaterthan32characters");
 | |
| 599 | r = lddChan.GetClientId(Clients[aClientId].iClientId, (TDesC8&)badName, clientId); | |
| 600 | test(r == KErrTooBig); | |
| 601 | ||
| 602 | 		ClientName[6] = (TUint8)('0' + iMaxClients + 1);
 | |
| 603 | r = lddChan.GetClientId(Clients[aClientId].iClientId, (TDesC8&)ClientName, clientId); | |
| 604 | test(r == KErrNotFound); | |
| 605 | } | |
| 606 | 	ClientName[6] = (TUint8)('0' + aClientId);
 | |
| 607 | r = lddChan.GetClientId(Clients[aClientId].iClientId, (TDesC8&)ClientName, clientId); | |
| 608 | if(r != KErrNone) | |
| 609 | 		test.Printf(_L("GetClientId returned with %d"), r);
 | |
| 610 | test(r == KErrNone); | |
| 611 | if(clientId != Clients[aClientId].iClientId) | |
| 612 | 		test.Printf(_L("ClientId = 0x%x, Expected ClientId = 0x%x"), clientId, Clients[aClientId].iClientId);
 | |
| 613 | test(clientId == Clients[aClientId].iClientId); | |
| 614 | } | |
| 615 | ||
| 616 | //---------------------------------------------------------------------------------------------- | |
| 617 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0577 | |
| 618 | //! @SYMTestType UT | |
| 619 | //! @SYMPREQ PREQ1398 | |
| 620 | //! @SYMTestCaseDesc This test case tests the retrieval of resource ID functionality of resource | |
| 621 | //! manager and compares for correctness. There are negative and positive tests. | |
| 622 | //! @SYMTestActions If negative testing is enabled then following tests are done | |
| 623 | //! 0 Call the API with invalid client Id (calling client Id). | |
| 624 | //! 1 Call the API with invalid instance count of calling client Id. | |
| 625 | //! 2 Call the API with resource name greater than maximum allowable | |
| 626 | //! resource name (32 characters). | |
| 627 | //! 3 Call the API with name not registered with resource manager | |
| 628 | //! (non-existing name). | |
| 629 | //! Positive tests | |
| 630 | //! 4 Call the API with valid client Id and resource name. | |
| 631 | //! | |
| 632 | //! @SYMTestExpectedResults 0 API should return with KErrAccessDenied, panics otherwise | |
| 633 | //! 1 API should return with KErrAccessDenied, panics otherwise | |
| 634 | //! 2 API should return with KErrTooBig, panics otherwise | |
| 635 | //! 3 API should return with KErrNotFound, panics otherwise | |
| 636 | //! 4 API should return KErrNone with resource Id updated and also Id | |
| 637 | //! is checked for correctness, panics otherwise | |
| 638 | //! @SYMTestPriority High | |
| 639 | //! @SYMTestStatus Implemented | |
| 640 | //---------------------------------------------------------------------------------------------- | |
| 641 | void TestRM::GetResourceId(TUint aResId) | |
| 642 | 	{
 | |
| 643 | TUint resId; | |
| 644 | if(NegativeTesting) | |
| 645 | 		{
 | |
| 646 | r = lddChan.GetResourceId(iMaxClients, Resources[aResId].iName, resId); | |
| 647 | test(r == KErrAccessDenied); | |
| 648 | ||
| 649 | //Pass illegal instance count | |
| 650 | TUint id = Clients[iCurrentClientId].iClientId; | |
| 651 | id = id ^ (3<<17); | |
| 652 | r = lddChan.GetResourceId(id, (TDesC8&)Resources[aResId].iName, resId); | |
| 653 | test(r == KErrAccessDenied); | |
| 654 | ||
| 655 | 		TBuf8<50> badName = _L8("Resourcenamegreaterthen32characters");
 | |
| 656 | r = lddChan.GetResourceId(Clients[iCurrentClientId].iClientId, (TDesC8&)badName, resId); | |
| 657 | test(r == KErrTooBig); | |
| 658 | badName = Resources[aResId].iName; | |
| 659 | badName[0] = '0' + 1; | |
| 660 | r = lddChan.GetResourceId(Clients[iCurrentClientId].iClientId, (TDesC8&)badName, resId); | |
| 661 | test(r == KErrNotFound); | |
| 662 | } | |
| 663 | r = lddChan.GetResourceId(Clients[iCurrentClientId].iClientId, (TDesC8&)Resources[aResId].iName, resId); | |
| 664 | if(r != KErrNone) | |
| 665 | 		test.Printf(_L("Return value of GetResourceId %d"), r);
 | |
| 666 | test(r == KErrNone); | |
| 667 | if(resId != Resources[aResId].iResourceId) | |
| 668 | 		test.Printf(_L("resId = %d ... aResId = %d"), resId, Resources[aResId].iResourceId);
 | |
| 669 | test(resId == Resources[aResId].iResourceId); | |
| 670 | } | |
| 671 | ||
| 672 | ||
| 673 | //---------------------------------------------------------------------------------------------- | |
| 674 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0578 | |
| 675 | //! @SYMTestType UT | |
| 676 | //! @SYMPREQ PREQ1398 | |
| 677 | //! @SYMTestCaseDesc This test case tests the retrieval of resource information of a specified | |
| 678 | //! resource functionality of resource manager and compares each info for correctness. | |
| 679 | //! There are negative and positive tests. | |
| 680 | //! @SYMTestActions If negative testing is enabled then following tests are done | |
| 681 | //! 0 Call the API with invalid client Id (calling client Id). | |
| 682 | //! 1 Call the API with invalid instance count of calling client Id. | |
| 683 | //! 2 Call the API with invalid resource id. | |
| 684 | //! Positive tests | |
| 685 | //! 3 Call the API with valid client Id and resource id. | |
| 686 | //! | |
| 687 | //! @SYMTestExpectedResults 0 API should return with KErrAccessDenied, panics otherwise | |
| 688 | //! 1 API should return with KErrAccessDenied, panics otherwise | |
| 689 | //! 2 API should return with KErrNotFound, panics otherwise | |
| 690 | //! 3 API should return KErrNone with resource information updated and also | |
| 691 | //! each information is checked for correctness, panics otherwise | |
| 692 | //! @SYMTestPriority High | |
| 693 | //! @SYMTestStatus Implemented | |
| 694 | //---------------------------------------------------------------------------------------------- | |
| 695 | void TestRM::GetResourceInfo(TUint aResId) | |
| 696 | 	{
 | |
| 697 | RBuf8 infoBuf; | |
| 698 | infoBuf.Create(sizeof(TPowerResourceInfoV01)); | |
| 699 | if(NegativeTesting) | |
| 700 | 		{
 | |
| 701 | r = lddChan.GetResourceInfo(iMaxClients-5, aResId+1, (TAny*)(TDes8*)&infoBuf); | |
| 702 | test(r == KErrAccessDenied); | |
| 703 | ||
| 704 | //Pass illegal instance count | |
| 705 | TUint id = Clients[iCurrentClientId].iClientId; | |
| 706 | id = id ^ (5<<17); | |
| 707 | r = lddChan.GetResourceInfo(id, aResId+1, (TAny*)infoBuf.Ptr()); | |
| 708 | test(r == KErrAccessDenied); | |
| 709 | ||
| 710 | r = lddChan.GetResourceInfo(Clients[iCurrentClientId].iClientId, iMaxStaticResources + 30, (TAny*)(TDes8*)&infoBuf); | |
| 711 | test(r == KErrNotFound); | |
| 712 | r = lddChan.GetResourceInfo(Clients[iCurrentClientId].iClientId, 26, (TAny*)(TDes8*)&infoBuf); | |
| 713 | test(r == KErrNotFound); | |
| 714 | } | |
| 715 | r = lddChan.GetResourceInfo(Clients[iCurrentClientId].iClientId, Resources[aResId].iResourceId, (TAny*)(TDes8*)&infoBuf); | |
| 716 | if(r != KErrNone) | |
| 717 | 		test.Printf(_L("GetResourceInfo returned with %d"), r);
 | |
| 718 | test(r == KErrNone); | |
| 719 | TPowerResourceInfoV01 *ptr = (TPowerResourceInfoV01*)infoBuf.Ptr(); | |
| 720 | //Compare results. | |
| 721 | test(ptr->iResourceId == Resources[aResId].iResourceId); | |
| 722 | test(ptr->iLatencyGet == Resources[aResId].iLatencyGet); | |
| 723 | test(ptr->iLatencySet == Resources[aResId].iLatencySet); | |
| 724 | test(ptr->iType == Resources[aResId].iType); | |
| 725 | test(ptr->iUsage == Resources[aResId].iUsage); | |
| 726 | test(ptr->iSense == Resources[aResId].iSense); | |
| 727 | test(ptr->iMaxLevel == Resources[aResId].iMaxLevel); | |
| 728 | test(ptr->iMinLevel == Resources[aResId].iMinLevel); | |
| 729 | test(ptr->iDefaultLevel == Resources[aResId].iDefaultLevel); | |
| 730 | if(ptr->iUsage == ESingle && Resources[aResId].iNumClients >1) //Single user resource cannot have more than 1 client. | |
| 731 | test(0); | |
| 732 | infoBuf.Close(); | |
| 733 | } | |
| 734 | ||
| 735 | //---------------------------------------------------------------------------------------------- | |
| 736 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0579 | |
| 737 | //! @SYMTestType UT | |
| 738 | //! @SYMPREQ PREQ1398 | |
| 739 | //! @SYMTestCaseDesc This test case tests retrieval of number of resources the requested client has | |
| 740 | //! requirement functionality of resource manager and compares with stored information | |
| 741 | //! for correctness.There are negative and positive tests. | |
| 742 | //! @SYMTestActions If negative testing is enabled then following tests are done | |
| 743 | //! 0 Call the API with invalid client Id (calling client Id). | |
| 744 | //! 1 Call the API with invalid instance count of calling client Id. | |
| 745 | //! 2 Call the API with invalid target client Id. | |
| 746 | //! 3 Call the API with invalid instance count of target client Id. | |
| 747 | //! Positive tests | |
| 748 | //! 4 Call the API with valid calling and target client Id. | |
| 749 | //! | |
| 750 | //! @SYMTestExpectedResults 0 API should return with KErrAccessDenied, panics otherwise | |
| 751 | //! 1 API should return with KErrAccessDenied, panics otherwise | |
| 752 | //! 2 API should return with KErrNotFound, panics otherwise | |
| 753 | //! 3 API should return with KErrNotFound, panics otherwise | |
| 754 | //! 4 API should return KErrNone with number of resources the requested client has | |
| 755 | //! requirement updated and also is checked for correctness, panics otherwise | |
| 756 | //! @SYMTestPriority High | |
| 757 | //! @SYMTestStatus Implemented | |
| 758 | //---------------------------------------------------------------------------------------------- | |
| 759 | void TestRM::GetNumResourcesInUseByClient(TInt aClientId) | |
| 760 | 	{
 | |
| 761 | TUint numRes; | |
| 762 | if(NegativeTesting) | |
| 763 | 		{
 | |
| 764 | //Pass illegial client Id | |
| 765 | r = lddChan.GetNumResourcesInUseByClient(23, Clients[aClientId].iClientId, numRes); | |
| 766 | test(r == KErrAccessDenied); | |
| 767 | ||
| 768 | //Pass illegal instance count | |
| 769 | TUint id = Clients[aClientId].iClientId; | |
| 770 | id = id ^ (1<<16); | |
| 771 | r = lddChan.GetNumResourcesInUseByClient(id, Clients[aClientId].iClientId, numRes); | |
| 772 | test(r == KErrAccessDenied); | |
| 773 | ||
| 774 | //Pass illegal target client id | |
| 775 | r = lddChan.GetNumResourcesInUseByClient(Clients[aClientId].iClientId, iMaxClients, numRes); | |
| 776 | test(r == KErrNotFound); | |
| 777 | ||
| 778 | //Pass illegal instance count of target client id | |
| 779 | id = id ^ (3<<16); | |
| 780 | r = lddChan.GetNumResourcesInUseByClient(Clients[aClientId].iClientId, id ,numRes); | |
| 781 | test(r == KErrNotFound); | |
| 782 | } | |
| 783 | ||
| 784 | if(aClientId == -1) | |
| 785 | 		{
 | |
| 786 | r = lddChan.GetNumResourcesInUseByClient(Clients[0].iClientId, 0, numRes); | |
| 787 | if(r != KErrNone) | |
| 788 | 			test.Printf(_L("GetNumResourcesInUseByClient returned with %d"), r);
 | |
| 789 | test(r == KErrNone); | |
| 790 | if((!iTestingExtendedVersion) && (numRes > MAX_STATIC_RESOURCE_NUM)) | |
| 791 | test(0); | |
| 792 | if(iMaxStaticResources == 0) | |
| 793 | iMaxStaticResources = numRes; | |
| 794 | else | |
| 795 | test(numRes == (iMaxStaticResources + iMaxStaticDependentResources)); | |
| 796 | } | |
| 797 | else | |
| 798 | 		{
 | |
| 799 | r = lddChan.GetNumResourcesInUseByClient(Clients[aClientId].iClientId, Clients[aClientId].iClientId, numRes); | |
| 800 | if(r != KErrNone) | |
| 801 | 			test.Printf(_L("GetNumResourceInUseByClient returned with %d"), r);
 | |
| 802 | test(r == KErrNone); | |
| 803 | if(numRes != Clients[aClientId].iNumResources) | |
| 804 | 			test.Printf(_L("numRes = %d, iNumResources = %d"), numRes, Clients[aClientId].iNumResources);
 | |
| 805 | test(numRes == Clients[aClientId].iNumResources); | |
| 806 | } | |
| 807 | } | |
| 808 | ||
| 809 | //---------------------------------------------------------------------------------------------- | |
| 810 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0580 | |
| 811 | //! @SYMTestType UT | |
| 812 | //! @SYMPREQ PREQ1398 | |
| 813 | //! @SYMTestCaseDesc This test case tests retrieval of information about resources the requested client has | |
| 814 | //! requirement functionality of resource manager and compares with stored information | |
| 815 | //! for correctness.There are negative and positive tests. | |
| 816 | //! @SYMTestActions If negative testing is enabled then following tests are done | |
| 817 | //! 0 Call the API with invalid client Id (calling client Id). | |
| 818 | //! 1 Call the API with invalid instance count of calling client Id. | |
| 819 | //! 2 Call the API with invalid target client Id. | |
| 820 | //! 3 Call the API with invalid instance count of target client Id. | |
| 821 | //! 4 Call the API with null buffer (buffer where the resource information will be updated). | |
| 822 | //! 5 Call the API with the number of resource information to be updated as 0 (specifies the | |
| 823 | //! size of the buffer). | |
| 824 | //! Positive tests | |
| 825 | //! 6 Call the API with valid calling and target client Id, buffer and its size. | |
| 826 | //! | |
| 827 | //! @SYMTestExpectedResults 0 API should return with KErrAccessDenied, panics otherwise | |
| 828 | //! 1 API should return with KErrAccessDenied, panics otherwise | |
| 829 | //! 2 API should return with KErrNotFound, panics otherwise | |
| 830 | //! 3 API should return with KErrNotFound, panics otherwise | |
| 831 | //! 4 API should return with KErrArgument, panics otherwise | |
| 832 | //! 5 API should return with KErrArgument, panics otherwise | |
| 833 | //! 6 API should return KErrNone with resource information about resources the requested | |
| 834 | //! client has requirement updated and also is checked for correctness, panics otherwise | |
| 835 | //! @SYMTestPriority High | |
| 836 | //! @SYMTestStatus Implemented | |
| 837 | //---------------------------------------------------------------------------------------------- | |
| 838 | void TestRM::GetInfoOnResourcesInUseByClient(TInt aClientId, TUint aNumRes) | |
| 839 | 	{
 | |
| 840 | RBuf8 info; | |
| 841 | info.Create(aNumRes * sizeof(TPowerResourceInfoV01)); | |
| 842 | if(NegativeTesting) | |
| 843 | 		{
 | |
| 844 | //Pass illegial client Id | |
| 845 | r = lddChan.GetInfoOnResourcesInUseByClient(32, Clients[aClientId].iClientId, aNumRes, (TAny*)(TDes8*)&info); | |
| 846 | test(r == KErrAccessDenied); | |
| 847 | ||
| 848 | //Pass illegal instance count | |
| 849 | TUint id = Clients[aClientId].iClientId; | |
| 850 | id = id ^ (1<<16); | |
| 851 | r = lddChan.GetInfoOnResourcesInUseByClient(id, Clients[aClientId].iClientId, aNumRes, (TAny*)(TDes8*)&info); | |
| 852 | test(r == KErrAccessDenied); | |
| 853 | ||
| 854 | //Pass illegal target client id | |
| 855 | r = lddChan.GetInfoOnResourcesInUseByClient(Clients[aClientId].iClientId, iMaxClients, aNumRes, (TAny*)(TDes8*)&info); | |
| 856 | test(r == KErrNotFound); | |
| 857 | ||
| 858 | //Pass illegal instance count of target client id | |
| 859 | id = id ^ (3<<16); | |
| 860 | r = lddChan.GetInfoOnResourcesInUseByClient(Clients[aClientId].iClientId, id ,aNumRes,(TAny*)(TDes8*)&info); | |
| 861 | test(r == KErrNotFound); | |
| 862 | ||
| 863 | //Pass null buffer | |
| 864 | r = lddChan.GetInfoOnResourcesInUseByClient(Clients[aClientId].iClientId, Clients[aClientId].iClientId ,aNumRes, (TAny*)NULL); | |
| 865 | test(r == KErrArgument); | |
| 866 | ||
| 867 | //Pass required resources as 0 | |
| 868 | TUint tempRes = 0; | |
| 869 | r = lddChan.GetInfoOnResourcesInUseByClient(Clients[aClientId].iClientId, Clients[aClientId].iClientId, tempRes, (TAny*)(TDes8*)&info); | |
| 870 | test(r == KErrArgument); | |
| 871 | } | |
| 872 | ||
| 873 | if(aClientId == -1) | |
| 874 | 		{
 | |
| 875 | r = lddChan.GetInfoOnResourcesInUseByClient(Clients[0].iClientId, 0, aNumRes, (TAny*)(TDes8*)&info); | |
| 876 | if(r != KErrNone) | |
| 877 | 			test.Printf(_L("GetInfoOnResourceInUseByClient returned with %d"), r);
 | |
| 878 | test(r == KErrNone); | |
| 879 | if(aNumRes != (iMaxStaticResources + iMaxStaticDependentResources)) | |
| 880 | 			test.Printf(_L("aNumRes = %d, iMaxStaticResources = %d"), aNumRes, iMaxStaticResources);
 | |
| 881 | test(aNumRes == (iMaxStaticResources + iMaxStaticDependentResources)); | |
| 882 | ||
| 883 | //Fill in the resource information | |
| 884 | TInt newState, levelOwnerId; | |
| 885 | TPowerResourceInfoV01 *ptr = (TPowerResourceInfoV01*)info.Ptr(); | |
| 886 | ||
| 887 | TUint extCount = 0; | |
| 888 | for(TUint count = 0; count < aNumRes; count++) | |
| 889 | 			{
 | |
| 890 | r = lddChan.GetResourceStateSync(Clients[0].iClientId, ptr->iResourceId, ETrue, newState, levelOwnerId); | |
| 891 | if(r != KErrNone) | |
| 892 | 				test.Printf(_L("GetResourceStateSync failed for ClientId = %d, resourceId = %d with return value %d\n"),  Clients[0].iClientId, count+1, r);
 | |
| 893 | test(r == KErrNone); | |
| 894 | 			test.Printf(_L("Info of Resource %d\n"), count+1);
 | |
| 895 | 			test.Printf(_L("Resource Id %d\n"), ptr->iResourceId);
 | |
| 896 | 			test.Printf(_L("Resource Type %d\n"), ptr->iType);
 | |
| 897 | 			test.Printf(_L("Resource Sense %d\n"), ptr->iSense);
 | |
| 898 | 			test.Printf(_L("Resource Latency Get %d\n"), ptr->iLatencyGet);
 | |
| 899 | 			test.Printf(_L("Resource Latency Set %d\n"), ptr->iLatencySet);
 | |
| 900 | 			test.Printf(_L("Resource usage %d\n"), ptr->iUsage);
 | |
| 901 | 			test.Printf(_L("Resource MinLevel %d\n"), ptr->iMinLevel);
 | |
| 902 | 			test.Printf(_L("Resource MaxLevel %d\n"), ptr->iMaxLevel);
 | |
| 903 | 			test.Printf(_L("Resource DefaultLevel %d\n"), ptr->iDefaultLevel);
 | |
| 904 | ||
| 905 | if(iTestingExtendedVersion && (ptr->iResourceId & DEPENDENCY_RESOURCE_BIT_MASK)) | |
| 906 | 				{
 | |
| 907 | iStaticDependencyResources[extCount++] = ptr->iResourceId; | |
| 908 | ptr++; | |
| 909 | continue; | |
| 910 | } | |
| 911 | if(iTestingExtendedVersion && (ptr->iResourceId & DYNAMIC_RESOURCE_BIT_MASK)) | |
| 912 | 				{
 | |
| 913 | ptr++; | |
| 914 | continue; | |
| 915 | } | |
| 916 | Resources[count].iName.Copy(*ptr->iResourceName); | |
| 917 | Resources[count].iResourceId = ptr->iResourceId; | |
| 918 | Resources[count].iMaxLevel = ptr->iMaxLevel; | |
| 919 | Resources[count].iMinLevel = ptr->iMinLevel; | |
| 920 | Resources[count].iDefaultLevel = ptr->iDefaultLevel; | |
| 921 | Resources[count].iNumClients = 0; | |
| 922 | Resources[count].iCurrentClient = -1; | |
| 923 | Resources[count].iCurrentLevel = newState; | |
| 924 | Resources[count].iType = ptr->iType; | |
| 925 | Resources[count].iSense = ptr->iSense; | |
| 926 | Resources[count].iLatencyGet = ptr->iLatencyGet; | |
| 927 | Resources[count].iLatencySet = ptr->iLatencySet; | |
| 928 | Resources[count].iUsage = ptr->iUsage; | |
| 929 | Resources[count].iUnCondNotiCount = 0; | |
| 930 | Resources[count].iCondNoti = NULL; | |
| 931 | Resources[count].iUncondNoti = NULL; | |
| 932 | Resources[count].iLevel = NULL; | |
| 933 | ptr++; | |
| 934 | } | |
| 935 | iMaxStaticResources -= extCount; | |
| 936 | iMaxStaticDependentResources = extCount; | |
| 937 | info.Close(); | |
| 938 | return; | |
| 939 | } | |
| 940 | r = lddChan.GetInfoOnResourcesInUseByClient(Clients[aClientId].iClientId, Clients[aClientId].iClientId, aNumRes, (TAny*)&info); | |
| 941 | if(aNumRes != Clients[aClientId].iNumResources) | |
| 942 | 		{
 | |
| 943 | 		test.Printf(_L("Expected Resource Num = %d, Returned = %d\n"), Clients[aClientId].iNumResources, aNumRes);
 | |
| 944 | test(0); | |
| 945 | } | |
| 946 | if(aNumRes == 0) | |
| 947 | 		{
 | |
| 948 | test((r == KErrArgument) || (r == KErrNone)); | |
| 949 | info.Close(); | |
| 950 | return; | |
| 951 | } | |
| 952 | else | |
| 953 | test(r == KErrNone); | |
| 954 | TPowerResourceInfoV01 *ptr = (TPowerResourceInfoV01*)info.Ptr(); | |
| 955 | for(TUint count = 0; count < Clients[aClientId].iNumResources; count++) | |
| 956 | 		{
 | |
| 957 | if(Clients[aClientId].iResourceIds[count] == 0) | |
| 958 | continue; | |
| 959 | TUint c; | |
| 960 | for(c = 0; c < Clients[aClientId].iNumResources; c++) | |
| 961 | 			{
 | |
| 962 | if(Clients[aClientId].iResourceIds[c] == ptr->iResourceId) | |
| 963 | break; | |
| 964 | } | |
| 965 | if(c == Clients[aClientId].iNumResources) | |
| 966 | test(0); | |
| 967 | //Find the resource from resource list | |
| 968 | for(c = 0; c < iMaxStaticResources; c++) | |
| 969 | 			{
 | |
| 970 | if(Resources[c].iResourceId == ptr->iResourceId) | |
| 971 | break; | |
| 972 | } | |
| 973 | if(c == iMaxStaticResources) | |
| 974 | test(0); | |
| 975 | test(Resources[c].iResourceId == ptr->iResourceId); | |
| 976 | test(Resources[c].iMaxLevel == ptr->iMaxLevel); | |
| 977 | test(Resources[c].iMinLevel == ptr->iMinLevel); | |
| 978 | test(Resources[c].iDefaultLevel == ptr->iDefaultLevel); | |
| 979 | test(Resources[c].iType == ptr->iType); | |
| 980 | test(Resources[c].iSense == ptr->iSense); | |
| 981 | test(Resources[c].iLatencyGet == ptr->iLatencyGet); | |
| 982 | test(Resources[c].iLatencySet == ptr->iLatencySet); | |
| 983 | test(Resources[c].iUsage == ptr->iUsage); | |
| 984 | test(!Resources[c].iName.Compare(*ptr->iResourceName)); | |
| 985 | ptr++; | |
| 986 | } | |
| 987 | info.Close(); | |
| 988 | } | |
| 989 | ||
| 990 | //---------------------------------------------------------------------------------------------- | |
| 991 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0581 | |
| 992 | //! @SYMTestType UT | |
| 993 | //! @SYMPREQ PREQ1398 | |
| 994 | //! @SYMTestCaseDesc This test case tests retrieval of number of clients holding requirement on | |
| 995 | //! the requested resource functionality of resource manager and compares with stored | |
| 996 | //! information for correctness.There are negative and positive tests. | |
| 997 | //! @SYMTestActions If negative testing is enabled then following tests are done | |
| 998 | //! 0 Call the API with invalid client Id (calling client Id). | |
| 999 | //! 1 Call the API with invalid instance count of calling client Id. | |
| 1000 | //! 2 Call the API with invalid resource Id. | |
| 1001 | //! Positive tests | |
| 1002 | //! 3 Call the API with valid calling client Id and resource Id. | |
| 1003 | //! | |
| 1004 | //! @SYMTestExpectedResults 0 API should return with KErrAccessDenied, panics otherwise | |
| 1005 | //! 1 API should return with KErrAccessDenied, panics otherwise | |
| 1006 | //! 2 API should return with KErrNotFound, panics otherwise | |
| 1007 | //! 3 API should return KErrNone with number of clients holding requirement on | |
| 1008 | //! the requested resource updated and also is checked for correctness, panics otherwise | |
| 1009 | //! @SYMTestPriority High | |
| 1010 | //! @SYMTestStatus Implemented | |
| 1011 | //---------------------------------------------------------------------------------------------- | |
| 1012 | void TestRM::GetNumClientsUsingResource(TUint aClientId, TUint aResId) | |
| 1013 | 	{
 | |
| 1014 | TUint clientNum = 0; | |
| 1015 | if(NegativeTesting) | |
| 1016 | 		{
 | |
| 1017 | //Pass illegial client Id | |
| 1018 | r = lddChan.GetNumClientsUsingResource(32, 1, clientNum); | |
| 1019 | test(r == KErrAccessDenied); | |
| 1020 | ||
| 1021 | //Pass illegal instance count | |
| 1022 | TUint id = Clients[aClientId].iClientId; | |
| 1023 | id = id ^ (1<<16); | |
| 1024 | r = lddChan.GetNumClientsUsingResource(id, 1, clientNum); | |
| 1025 | test(r == KErrAccessDenied); | |
| 1026 | ||
| 1027 | //Invalid resource id | |
| 1028 | r = lddChan.GetNumClientsUsingResource(Clients[aClientId].iClientId, iMaxStaticResources+40, clientNum); | |
| 1029 | test(r == KErrNotFound); | |
| 1030 | } | |
| 1031 | if((TInt)aResId == -1) | |
| 1032 | r = lddChan.GetNumClientsUsingResource(Clients[aClientId].iClientId, 0, clientNum); | |
| 1033 | else | |
| 1034 | r = lddChan.GetNumClientsUsingResource(Clients[aClientId].iClientId, Resources[aResId].iResourceId, clientNum); | |
| 1035 | if(r != KErrNone) | |
| 1036 | 		test.Printf(_L("GetNumClientsUsingResource for client 0x%x failed with %d"), Clients[aClientId].iClientId, r);
 | |
| 1037 | test(r==KErrNone); | |
| 1038 | if((TInt)aResId == -1) | |
| 1039 | 		{
 | |
| 1040 | if(clientNum != (TUint)(Clients.Count() + 1)) | |
| 1041 | 			test.Printf(_L("ClientNum = %d, Expected clientNum = %d"), clientNum, Clients.Count()+1);
 | |
| 1042 | test(clientNum == (TUint)(Clients.Count() + 1)); | |
| 1043 | } | |
| 1044 | else | |
| 1045 | 		{
 | |
| 1046 | test(Resources[aResId].iNumClients == clientNum); | |
| 1047 | if(!Resources[aResId].iUsage && clientNum > 1) //Single user resource cannot have more that one client | |
| 1048 | test(0); | |
| 1049 | } | |
| 1050 | } | |
| 1051 | ||
| 1052 | //---------------------------------------------------------------------------------------------- | |
| 1053 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0582 | |
| 1054 | //! @SYMTestType UT | |
| 1055 | //! @SYMPREQ PREQ1398 | |
| 1056 | //! @SYMTestCaseDesc This test case tests retrieval of information about clients holding requirement on | |
| 1057 | //! the passed resource functionality of resource manager and compares with stored information | |
| 1058 | //! for correctness.There are negative and positive tests. | |
| 1059 | //! @SYMTestActions If negative testing is enabled then following tests are done | |
| 1060 | //! 0 Call the API with invalid client Id (calling client Id). | |
| 1061 | //! 1 Call the API with invalid instance count of calling client Id. | |
| 1062 | //! 2 Call the API with invalid resource Id. | |
| 1063 | //! 3 Call the API with null buffer (buffer where the resource information will be updated). | |
| 1064 | //! 4 Call the API with the number of resource information to be updated as 0 (specifies the | |
| 1065 | //! size of the buffer). | |
| 1066 | //! Positive tests | |
| 1067 | //! 5 Call the API with valid calling and target client Id, buffer and its size. | |
| 1068 | //! | |
| 1069 | //! @SYMTestExpectedResults 0 API should return with KErrAccessDenied, panics otherwise | |
| 1070 | //! 1 API should return with KErrAccessDenied, panics otherwise | |
| 1071 | //! 2 API should return with KErrNotFound, panics otherwise | |
| 1072 | //! 3 API should return with KErrArgument, panics otherwise | |
| 1073 | //! 4 API should return with KErrArgument, panics otherwise | |
| 1074 | //! 5 API should return KErrNone with resource information about clients holding requirement | |
| 1075 | //! on the passed resource and also is checked for correctness, panics otherwise | |
| 1076 | //! @SYMTestPriority High | |
| 1077 | //! @SYMTestStatus Implemented | |
| 1078 | //---------------------------------------------------------------------------------------------- | |
| 1079 | void TestRM::GetInfoOnClientsUsingResource(TUint aResId, TUint aNumCli) | |
| 1080 | 	{
 | |
| 1081 | RBuf8 info; | |
| 1082 | info.Create(aNumCli * sizeof(TPowerClientInfoV01)); | |
| 1083 | if(NegativeTesting) | |
| 1084 | 		{
 | |
| 1085 | //Pass illegial client Id | |
| 1086 | r = lddChan.GetInfoOnClientsUsingResource(2, 1, aNumCli, (TAny*)(TDes8*)&info); | |
| 1087 | test(r == KErrAccessDenied); | |
| 1088 | ||
| 1089 | //Pass illegal instance count | |
| 1090 | TUint id = Clients[iCurrentClientId].iClientId; | |
| 1091 | id = id ^ (1<<16); | |
| 1092 | r = lddChan.GetInfoOnClientsUsingResource(id, 1, aNumCli, (TAny*)(TDes8*)&info); | |
| 1093 | test(r == KErrAccessDenied); | |
| 1094 | ||
| 1095 | //Invalid resource id | |
| 1096 | r = lddChan.GetInfoOnClientsUsingResource(Clients[iCurrentClientId].iClientId, iMaxStaticResources+40, aNumCli, (TAny*)(TDes8*)&info); | |
| 1097 | test(r == KErrNotFound); | |
| 1098 | ||
| 1099 | //Pass null buffer | |
| 1100 | r = lddChan.GetInfoOnClientsUsingResource(Clients[iCurrentClientId].iClientId, 1 ,aNumCli, (TAny*)NULL); | |
| 1101 | test(r == KErrArgument); | |
| 1102 | ||
| 1103 | //Pass required resources as 0 | |
| 1104 | TUint tempCli = 0; | |
| 1105 | r = lddChan.GetInfoOnClientsUsingResource(Clients[iCurrentClientId].iClientId, 1 ,tempCli, (TAny*)(TDes8*)&info); | |
| 1106 | test(r == KErrArgument); | |
| 1107 | } | |
| 1108 | if((TInt)aResId == -1) | |
| 1109 | r = lddChan.GetInfoOnClientsUsingResource(Clients[iCurrentClientId].iClientId, 0, aNumCli, (TAny*)(TDes8*)&info); | |
| 1110 | else | |
| 1111 | r = lddChan.GetInfoOnClientsUsingResource(Clients[iCurrentClientId].iClientId, Resources[aResId].iResourceId, aNumCli, (TAny*)(TDes8*)&info); | |
| 1112 | if(r == KErrArgument) | |
| 1113 | 		{
 | |
| 1114 | if(aResId != 0) | |
| 1115 | test(Resources[aResId].iNumClients == 0); | |
| 1116 | info.Close(); | |
| 1117 | return; | |
| 1118 | } | |
| 1119 | test(r == KErrNone); | |
| 1120 | TPowerClientInfoV01 *ptr = (TPowerClientInfoV01*)info.Ptr(); | |
| 1121 | if((TInt)aResId == -1) | |
| 1122 | 		{
 | |
| 1123 | test(aNumCli == (TUint)(Clients.Count() + 1)); | |
| 1124 | TUint c = 0; | |
| 1125 | for(TUint count = 0; count < aNumCli; count++) | |
| 1126 | 			{
 | |
| 1127 | //Skip comparision of first client as that will be PowerController. | |
| 1128 | if(ptr->iClientId == iPowerControllerId) | |
| 1129 | 				{
 | |
| 1130 | ptr++; | |
| 1131 | continue; | |
| 1132 | } | |
| 1133 | for(c = 0; c< iMaxClients; c++) | |
| 1134 | 				{
 | |
| 1135 | if(ptr->iClientId == Clients[c].iClientId) | |
| 1136 | break; | |
| 1137 | } | |
| 1138 | if(c == iMaxClients) | |
| 1139 | test(0); | |
| 1140 | ptr++; | |
| 1141 | } | |
| 1142 | } | |
| 1143 | else | |
| 1144 | 		{
 | |
| 1145 | if(aNumCli != Resources[aResId].iNumClients) | |
| 1146 | 			test.Printf(_L("aNumCli = %d, Expected numClients = %d\n"), aNumCli, Resources[aResId].iNumClients);
 | |
| 1147 | test(aNumCli == Resources[aResId].iNumClients); | |
| 1148 | //Compare results | |
| 1149 | SPowerResourceClientLevel *level = Resources[aResId].iLevel; | |
| 1150 | TUint c = 0; | |
| 1151 | for(TUint count = 0; count < aNumCli; count++) | |
| 1152 | 			{
 | |
| 1153 | SPowerResourceClientLevel *pL = Resources[aResId].iLevel; | |
| 1154 | for(c =0;c<aNumCli;c++) | |
| 1155 | 				{
 | |
| 1156 | if(Clients[pL->iClientId].iClientId == ptr->iClientId) | |
| 1157 | break; | |
| 1158 | pL = pL->iNextInList; | |
| 1159 | } | |
| 1160 | if(c == aNumCli) | |
| 1161 | 				{
 | |
| 1162 | 				test.Printf(_L("Client Id %d is not in the resource clientlevel list\n"), Clients[level->iClientId].iClientId);
 | |
| 1163 | test(0); | |
| 1164 | } | |
| 1165 | level = level->iNextInList; | |
| 1166 | ptr++; | |
| 1167 | } | |
| 1168 | } | |
| 1169 | info.Close(); | |
| 1170 | } | |
| 1171 | ||
| 1172 | //---------------------------------------------------------------------------------------------- | |
| 1173 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0583 | |
| 1174 | //! @SYMTestType UT | |
| 1175 | //! @SYMPREQ PREQ1398 | |
| 1176 | //! @SYMTestCaseDesc This test case tests preallocation of memory for resource manager internal | |
| 1177 | //! structure.There are negative and positive tests. | |
| 1178 | //! @SYMTestActions If negative testing is enabled then following tests are done | |
| 1179 | //! 0 Call the API with invalid client Id | |
| 1180 | //! 1 Call the API with invalid instance count of client Id. | |
| 1181 | //! Positive tests | |
| 1182 | //! 2 Call the API with valid client Id. | |
| 1183 | //! | |
| 1184 | //! @SYMTestExpectedResults 0 API should return with KErrAccessDenied, panics otherwise | |
| 1185 | //! 1 API should return with KErrAccessDenied, panics otherwise | |
| 1186 | //! 2 API should return with KErrNone, panic otherwise. Really cannot | |
| 1187 | //! test this for correctness. | |
| 1188 | //! @SYMTestPriority High | |
| 1189 | //! @SYMTestStatus Implemented | |
| 1190 | //---------------------------------------------------------------------------------------------- | |
| 1191 | void TestRM::AllocReserve(TUint aClientId) | |
| 1192 | 	{
 | |
| 1193 | if(NegativeTesting) | |
| 1194 | 		{
 | |
| 1195 | //Pass illegial client Id | |
| 1196 | r = lddChan.AllocReserve(11, 0, 3); | |
| 1197 | test(r == KErrAccessDenied); | |
| 1198 | ||
| 1199 | //Pass illegal instance count | |
| 1200 | TUint id = Clients[aClientId].iClientId; | |
| 1201 | id = id ^ (1<<16); | |
| 1202 | r = lddChan.AllocReserve(id, 0, 0); | |
| 1203 | test(r == KErrAccessDenied); | |
| 1204 | ||
| 1205 | } | |
| 1206 | r = lddChan.AllocReserve(Clients[iCurrentClientId].iClientId, 1, 0); | |
| 1207 | if(r != KErrNone) | |
| 1208 | 		test.Printf(_L("Alloc Reserve failed with %d"), r);
 | |
| 1209 | test(r == KErrNone); | |
| 1210 | } | |
| 1211 | ||
| 1212 | //This function validates the conditional and unconditional notification for the | |
| 1213 | //specified resource state change. | |
| 1214 | void TestRM::CheckNotification(TUint aResId, TInt newState) | |
| 1215 | 	{
 | |
| 1216 | if(newState == Resources[aResId].iCurrentLevel) | |
| 1217 | return; | |
| 1218 | //Return if the newState is in decreasing order with respect to sense. | |
| 1219 | if(Resources[aResId].iUsage == EShared && Resources[aResId].iCurrentClient != -1) | |
| 1220 | 		{
 | |
| 1221 | if(Resources[aResId].iSense == EPositive) | |
| 1222 | 			{
 | |
| 1223 | if(newState <= Resources[aResId].iCurrentLevel && Resources[aResId].iCurrentClient != iCurrentClientId) | |
| 1224 | return; | |
| 1225 | } | |
| 1226 | else | |
| 1227 | 			{
 | |
| 1228 | if(newState >= Resources[aResId].iCurrentLevel && Resources[aResId].iCurrentClient != iCurrentClientId) | |
| 1229 | return; | |
| 1230 | } | |
| 1231 | } | |
| 1232 | TUint notificationUnCon = Resources[aResId].iUnCondNotiCount; | |
| 1233 | TUint notificationCon =0; | |
| 1234 | for(NotiInfo* info = Resources[aResId].iCondNoti; info != NULL; info = info->iNext) | |
| 1235 | 		{
 | |
| 1236 | if((info->iDirection && (info->iPreviousLevel < info->iThreshold) && (newState >= info->iThreshold)) || | |
| 1237 | (!info->iDirection && (info->iPreviousLevel > info->iThreshold) && (newState <= info->iThreshold))) | |
| 1238 | notificationCon++; | |
| 1239 | info->iPreviousLevel = newState; | |
| 1240 | } | |
| 1241 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, notificationUnCon, notificationCon); | |
| 1242 | if(r != KErrNone) | |
| 1243 | 		test.Printf(_L("Check Notifications failed with %d"), r);
 | |
| 1244 | test(r == KErrNone); | |
| 1245 | } | |
| 1246 | ||
| 1247 | //This function updates the client level.This will be used by other functions for validation. | |
| 1248 | void TestRM::AddClientLevel(TUint aResId, TInt newState) | |
| 1249 | 	{
 | |
| 1250 | SPowerResourceClientLevel *pCL = NULL; | |
| 1251 | if(Resources[aResId].iUsage == EShared) | |
| 1252 | 		{
 | |
| 1253 | for(pCL = Resources[aResId].iLevel;pCL != NULL; pCL = pCL->iNextInList) | |
| 1254 | 			{
 | |
| 1255 | if((TInt)pCL->iClientId == iCurrentClientId) | |
| 1256 | 				{
 | |
| 1257 | pCL->iLevel = newState; | |
| 1258 | return; | |
| 1259 | } | |
| 1260 | } | |
| 1261 | pCL = new SPowerResourceClientLevel; | |
| 1262 | test(pCL != NULL); | |
| 1263 | pCL->iClientId = iCurrentClientId; | |
| 1264 | pCL->iResourceId = Resources[aResId].iResourceId; | |
| 1265 | pCL->iLevel = newState; | |
| 1266 | LIST_PUSH(Resources[aResId].iLevel, pCL, iNextInList); | |
| 1267 | Resources[aResId].iNumClients++; | |
| 1268 | } | |
| 1269 | else | |
| 1270 | 		{
 | |
| 1271 | if(Resources[aResId].iCurrentClient == -1) | |
| 1272 | 			{
 | |
| 1273 | pCL = new SPowerResourceClientLevel; | |
| 1274 | test(pCL != NULL); | |
| 1275 | pCL->iClientId = iCurrentClientId; | |
| 1276 | pCL->iResourceId = Resources[aResId].iResourceId; | |
| 1277 | pCL->iLevel = newState; | |
| 1278 | LIST_PUSH(Resources[aResId].iLevel, pCL, iNextInList); | |
| 1279 | Resources[aResId].iNumClients++; | |
| 1280 | } | |
| 1281 | else | |
| 1282 | 			{
 | |
| 1283 | SPowerResourceClientLevel* pCL = Resources[aResId].iLevel; | |
| 1284 | pCL->iLevel = newState; | |
| 1285 | } | |
| 1286 | } | |
| 1287 | } | |
| 1288 | ||
| 1289 | //This function updates the current level and client information in corresponding resource array. | |
| 1290 | void TestRM::UpdateClientInformation(TUint aResId, TInt aNewState) | |
| 1291 | 	{
 | |
| 1292 | if(Resources[aResId].iCurrentClient == -1) | |
| 1293 | 		{
 | |
| 1294 | Resources[aResId].iCurrentLevel = aNewState; | |
| 1295 | Resources[aResId].iCurrentClient = iCurrentClientId; | |
| 1296 | return; | |
| 1297 | } | |
| 1298 | if(!Resources[aResId].iUsage) | |
| 1299 | 		{
 | |
| 1300 | Resources[aResId].iCurrentLevel = aNewState; | |
| 1301 | return; | |
| 1302 | } | |
| 1303 | if(Resources[aResId].iSense == EPositive) | |
| 1304 | 		{
 | |
| 1305 | if(aNewState > Resources[aResId].iCurrentLevel) | |
| 1306 | 			{
 | |
| 1307 | Resources[aResId].iCurrentLevel = aNewState; | |
| 1308 | Resources[aResId].iCurrentClient = iCurrentClientId; | |
| 1309 | } | |
| 1310 | else if(Resources[aResId].iCurrentClient == iCurrentClientId) | |
| 1311 | 			{
 | |
| 1312 | SPowerResourceClientLevel *pCL = NULL; | |
| 1313 | for(pCL = Resources[aResId].iLevel;pCL != NULL; pCL = pCL->iNextInList) | |
| 1314 | 				{
 | |
| 1315 | if(pCL->iLevel > aNewState) | |
| 1316 | 					{
 | |
| 1317 | Resources[aResId].iCurrentLevel = pCL->iLevel; | |
| 1318 | Resources[aResId].iCurrentClient = pCL->iClientId; | |
| 1319 | return; | |
| 1320 | } | |
| 1321 | } | |
| 1322 | Resources[aResId].iCurrentLevel = aNewState; | |
| 1323 | Resources[aResId].iCurrentClient = iCurrentClientId; | |
| 1324 | } | |
| 1325 | return; | |
| 1326 | } | |
| 1327 | if(Resources[aResId].iSense == ENegative) | |
| 1328 | 		{
 | |
| 1329 | if(aNewState < Resources[aResId].iCurrentLevel) | |
| 1330 | 			{
 | |
| 1331 | Resources[aResId].iCurrentLevel = aNewState; | |
| 1332 | Resources[aResId].iCurrentClient = iCurrentClientId; | |
| 1333 | } | |
| 1334 | else if(Resources[aResId].iCurrentClient == iCurrentClientId) | |
| 1335 | 			{
 | |
| 1336 | SPowerResourceClientLevel *pCL = NULL; | |
| 1337 | for(pCL = Resources[aResId].iLevel;pCL != NULL; pCL = pCL->iNextInList) | |
| 1338 | 				{
 | |
| 1339 | if(pCL->iLevel < aNewState) | |
| 1340 | 					{
 | |
| 1341 | Resources[aResId].iCurrentLevel = pCL->iLevel; | |
| 1342 | Resources[aResId].iCurrentClient = pCL->iClientId; | |
| 1343 | return; | |
| 1344 | } | |
| 1345 | } | |
| 1346 | Resources[aResId].iCurrentLevel = aNewState; | |
| 1347 | Resources[aResId].iCurrentClient = iCurrentClientId; | |
| 1348 | } | |
| 1349 | } | |
| 1350 | return; | |
| 1351 | } | |
| 1352 | ||
| 1353 | //---------------------------------------------------------------------------------------------- | |
| 1354 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0584 | |
| 1355 | //! @SYMTestType UT | |
| 1356 | //! @SYMPREQ PREQ1398 | |
| 1357 | //! @SYMTestCaseDesc This test case tests change resource state functionality of resource manager | |
| 1358 | //! by changing the state of the resource to random value between resource minimum | |
| 1359 | //! and maximum value synchronously.This function will add the client level if required | |
| 1360 | //! and update resource information and will check notification for correctness.There are | |
| 1361 | //! postive and negative tests. | |
| 1362 | //! @SYMTestActions If negative testing is enabled then following tests are done | |
| 1363 | //! 0 Call the API with invalid client Id | |
| 1364 | //! 1 Call the API with invalid instance count of client Id. | |
| 1365 | //! 2 Call the API with invalid resource Id | |
| 1366 | //! Positive tests | |
| 1367 | //! 3 Call the API with valid client and resource Id. | |
| 1368 | //! | |
| 1369 | //! @SYMTestExpectedResults 0 API should return with KErrAccessDenied, panics otherwise | |
| 1370 | //! 1 API should return with KErrAccessDenied, panics otherwise | |
| 1371 | //! 2 API should return with KErrNotFound, panic otherwise. | |
| 1372 | //! 3 API should return with KErrNone, panic otherwise. | |
| 1373 | //! This also checks for notifications revceived as a result of this | |
| 1374 | //! resource change and checks for correctness. | |
| 1375 | //! @SYMTestPriority High | |
| 1376 | //! @SYMTestStatus Implemented | |
| 1377 | //---------------------------------------------------------------------------------------------- | |
| 1378 | void TestRM::ChangeResourceStateSync(TUint aResId) | |
| 1379 | 	{
 | |
| 1380 | TInt newState = 0; | |
| 1381 | if(NegativeTesting) | |
| 1382 | 		{
 | |
| 1383 | //Pass illegial client Id | |
| 1384 | r = lddChan.ChangeResourceStateSync(434224, Resources[aResId].iResourceId, newState); | |
| 1385 | test(r == KErrAccessDenied); | |
| 1386 | ||
| 1387 | //Pass illegal instance count | |
| 1388 | TUint id = Clients[iCurrentClientId].iClientId; | |
| 1389 | id = id ^ (1<<16); | |
| 1390 | r = lddChan.ChangeResourceStateSync(id, Resources[aResId].iResourceId, newState); | |
| 1391 | test(r == KErrAccessDenied); | |
| 1392 | ||
| 1393 | //Invalid resource id | |
| 1394 | r = lddChan.ChangeResourceStateSync(Clients[iCurrentClientId].iClientId, iMaxStaticResources+40, newState); | |
| 1395 | test(r == KErrNotFound); | |
| 1396 | ||
| 1397 | r = lddChan.ChangeResourceStateSync(Clients[iCurrentClientId].iClientId, 26, newState); | |
| 1398 | test(r == KErrNotFound); | |
| 1399 | } | |
| 1400 | TInt maxLevel = Resources[aResId].iMaxLevel; | |
| 1401 | TInt minLevel = Resources[aResId].iNumClients? Resources[aResId].iCurrentLevel : Resources[aResId].iMinLevel; | |
| 1402 | //Toggle current state for binary resources | |
| 1403 | if(!Resources[aResId].iType) | |
| 1404 | newState = !Resources[aResId].iCurrentLevel; | |
| 1405 | else if (Resources[aResId].iType == EMultiLevel) | |
| 1406 | 		{
 | |
| 1407 | TInt diff = Abs(maxLevel - minLevel); | |
| 1408 | if(Resources[aResId].iSense == EPositive) | |
| 1409 | 			{
 | |
| 1410 | if(minLevel == maxLevel) | |
| 1411 | newState = maxLevel - Math::Random() % diff; | |
| 1412 | else | |
| 1413 | newState = minLevel + Math::Random() % diff; | |
| 1414 | } | |
| 1415 | else | |
| 1416 | 			{
 | |
| 1417 | if(minLevel == maxLevel) | |
| 1418 | newState = maxLevel + Math::Random() % diff; | |
| 1419 | else | |
| 1420 | newState = minLevel - Math::Random() % diff; | |
| 1421 | } | |
| 1422 | } | |
| 1423 | TInt reqState = newState; | |
| 1424 | r = lddChan.ChangeResourceStateSync(Clients[iCurrentClientId].iClientId, Resources[aResId].iResourceId, newState); | |
| 1425 | if(r == KErrAccessDenied) | |
| 1426 | return; | |
| 1427 | if(r != KErrNone) | |
| 1428 | 		test.Printf(_L("Synchronous resource change returned with %d"), r);
 | |
| 1429 | test(r == KErrNone); | |
| 1430 | if(newState != reqState) | |
| 1431 | 		test.Printf(_L("NewState = %d, Expected state = %d"), newState, reqState);
 | |
| 1432 | if(!Resources[aResId].iUsage) | |
| 1433 | test(newState == reqState); | |
| 1434 | CheckNotification(aResId, reqState); | |
| 1435 | AddClientLevel(aResId, reqState); | |
| 1436 | UpdateClientInformation(aResId, reqState); | |
| 1437 | TUint c = 0; | |
| 1438 | for(c = 0; c< Clients[iCurrentClientId].iNumResources; c++) | |
| 1439 | 		{
 | |
| 1440 | if(Clients[iCurrentClientId].iResourceIds[c] == Resources[aResId].iResourceId) | |
| 1441 | return; | |
| 1442 | } | |
| 1443 | Clients[iCurrentClientId].iResourceIds[c] = Resources[aResId].iResourceId; | |
| 1444 | Clients[iCurrentClientId].iNumResources++; | |
| 1445 | return; | |
| 1446 | } | |
| 1447 | ||
| 1448 | //---------------------------------------------------------------------------------------------- | |
| 1449 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0585 | |
| 1450 | //! @SYMTestType UT | |
| 1451 | //! @SYMPREQ PREQ1398 | |
| 1452 | //! @SYMTestCaseDesc This test case tests change resource state functionality of resource manager | |
| 1453 | //! by changing the state of the resource to random value between resource minimum | |
| 1454 | //! and maximum value asynchronously.This function will add the client level if required | |
| 1455 | //! and update resource information and will check notification for correctness.This | |
| 1456 | //! also tests the cancellation of asynchronous function by immediately cancelling the | |
| 1457 | //! operation after requesting resource state change. This is taken care in the driver. | |
| 1458 | //! There are postive and negative tests. | |
| 1459 | //! @SYMTestActions If negative testing is enabled then following tests are done | |
| 1460 | //! 0 Call the API with invalid client Id | |
| 1461 | //! 1 Call the API with invalid instance count of client Id. | |
| 1462 | //! 2 Call the API with invalid resource Id | |
| 1463 | //! Positive tests | |
| 1464 | //! 3 Call the API with valid client and resource Id. | |
| 1465 | //! | |
| 1466 | //! @SYMTestExpectedResults 0 API should return with KErrAccessDenied, panics otherwise | |
| 1467 | //! 1 API should return with KErrAccessDenied, panics otherwise | |
| 1468 | //! 2 API should return with KErrNotFound, panic otherwise. | |
| 1469 | //! 3 API should return with KErrNone or if cancellation of this | |
| 1470 | //! API is tested then will return with KErrCancel, panic otherwise. | |
| 1471 | //! This also checks for notifications received as a result of this | |
| 1472 | //! resource change and checks for correctness. | |
| 1473 | //! @SYMTestPriority High | |
| 1474 | //! @SYMTestStatus Implemented | |
| 1475 | //---------------------------------------------------------------------------------------------- | |
| 1476 | void TestRM::ChangeResourceStateAsync(TUint aResId, TBool aReqCancel) | |
| 1477 | 	{
 | |
| 1478 | TRequestStatus resChange; | |
| 1479 | TInt newState = 0; | |
| 1480 | if(NegativeTesting) | |
| 1481 | 		{
 | |
| 1482 | //Pass illegial client Id | |
| 1483 | lddChan.ChangeResourceStateAsync(434224, Resources[aResId].iResourceId, newState, resChange); | |
| 1484 | User::WaitForRequest(resChange); | |
| 1485 | test(resChange.Int() == KErrAccessDenied); | |
| 1486 | ||
| 1487 | //Pass illegal instance count | |
| 1488 | TUint id = Clients[iCurrentClientId].iClientId; | |
| 1489 | id = id ^ (1<<16); | |
| 1490 | lddChan.ChangeResourceStateAsync(id, Resources[aResId].iResourceId, newState, resChange); | |
| 1491 | User::WaitForRequest(resChange); | |
| 1492 | test(resChange.Int() == KErrAccessDenied); | |
| 1493 | ||
| 1494 | //Invalid resource id | |
| 1495 | lddChan.ChangeResourceStateAsync(Clients[iCurrentClientId].iClientId, iMaxStaticResources+40, newState, resChange); | |
| 1496 | User::WaitForRequest(resChange); | |
| 1497 | test(resChange.Int() == KErrNotFound); | |
| 1498 | ||
| 1499 | lddChan.ChangeResourceStateAsync(Clients[iCurrentClientId].iClientId, 19, newState, resChange); | |
| 1500 | User::WaitForRequest(resChange); | |
| 1501 | test(resChange.Int() == KErrNotFound); | |
| 1502 | } | |
| 1503 | TInt maxLevel = Resources[aResId].iMaxLevel; | |
| 1504 | TInt minLevel = (Resources[aResId].iCurrentClient != -1)? Resources[aResId].iCurrentLevel : Resources[aResId].iMinLevel; | |
| 1505 | //Check if the resource is positive | |
| 1506 | if(!Resources[aResId].iType) | |
| 1507 | newState = !Resources[aResId].iCurrentLevel; | |
| 1508 | else if (Resources[aResId].iType == EMultiLevel) | |
| 1509 | 		{
 | |
| 1510 | TInt diff = Abs(maxLevel - minLevel); | |
| 1511 | if( diff == 0) | |
| 1512 | diff = Abs(Resources[aResId].iMaxLevel - Resources[aResId].iMinLevel); | |
| 1513 | if(Resources[aResId].iSense == EPositive) | |
| 1514 | 			{
 | |
| 1515 | if(minLevel == maxLevel) | |
| 1516 | newState = maxLevel - Math::Random() % diff; | |
| 1517 | else | |
| 1518 | newState = minLevel + Math::Random() % diff; | |
| 1519 | } | |
| 1520 | else | |
| 1521 | 			{
 | |
| 1522 | if(minLevel == maxLevel) | |
| 1523 | newState = maxLevel + Math::Random() % diff; | |
| 1524 | else | |
| 1525 | newState = minLevel - Math::Random() % diff; | |
| 1526 | } | |
| 1527 | } | |
| 1528 | TInt reqState = newState; | |
| 1529 | //Long latency resource | |
| 1530 | lddChan.ChangeResourceStateAsync(Clients[iCurrentClientId].iClientId, Resources[aResId].iResourceId, newState, resChange, aReqCancel); | |
| 1531 | User::WaitForRequest(resChange); | |
| 1532 | if(aReqCancel && (resChange.Int() != KErrNone)) | |
| 1533 | 		{
 | |
| 1534 | test(resChange.Int() == KErrCancel || resChange.Int() == KErrCompletion); | |
| 1535 | return; | |
| 1536 | } | |
| 1537 | if(resChange.Int() == KErrAccessDenied) | |
| 1538 | return; | |
| 1539 | if(!Resources[aResId].iUsage) | |
| 1540 | test(newState == reqState); | |
| 1541 | CheckNotification(aResId, reqState); | |
| 1542 | AddClientLevel(aResId, reqState); | |
| 1543 | UpdateClientInformation(aResId, reqState); | |
| 1544 | TUint c = 0; | |
| 1545 | for(c = 0; c< Clients[iCurrentClientId].iNumResources; c++) | |
| 1546 | 		{
 | |
| 1547 | if(Clients[iCurrentClientId].iResourceIds[c] == Resources[aResId].iResourceId) | |
| 1548 | return; | |
| 1549 | } | |
| 1550 | Clients[iCurrentClientId].iResourceIds[c] = Resources[aResId].iResourceId; | |
| 1551 | Clients[iCurrentClientId].iNumResources++; | |
| 1552 | return; | |
| 1553 | } | |
| 1554 | ||
| 1555 | //---------------------------------------------------------------------------------------------- | |
| 1556 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0586 | |
| 1557 | //! @SYMTestType UT | |
| 1558 | //! @SYMPREQ PREQ1398 | |
| 1559 | //! @SYMTestCaseDesc This test case tests synchronous version of get resource state functionality of | |
| 1560 | //! resource manager by getting the state of the resource checks for correctness. | |
| 1561 | //! There are positive and negative tests. | |
| 1562 | //! @SYMTestActions If negative testing is enabled then following tests are done | |
| 1563 | //! 0 Call the API with invalid client Id | |
| 1564 | //! 1 Call the API with invalid instance count of client Id. | |
| 1565 | //! 2 Call the API with invalid resource Id | |
| 1566 | //! Positive tests | |
| 1567 | //! 3 Call the API with valid client and resource Id. | |
| 1568 | //! | |
| 1569 | //! @SYMTestExpectedResults 0 API should return with KErrAccessDenied, panics otherwise | |
| 1570 | //! 1 API should return with KErrAccessDenied, panics otherwise | |
| 1571 | //! 2 API should return with KErrNotFound, panic otherwise. | |
| 1572 | //! 3 API should return with KErrNone and also the state and Owner Id are checked | |
| 1573 | //! for correctness, panic otherwise. | |
| 1574 | //! @SYMTestPriority High | |
| 1575 | //! @SYMTestStatus Implemented | |
| 1576 | //---------------------------------------------------------------------------------------------- | |
| 1577 | void TestRM::GetResourceStateSync(TUint aResId) | |
| 1578 | 	{
 | |
| 1579 | static TBool Cached; | |
| 1580 | TInt state = 0, levelOwnerId = 0; | |
| 1581 | if(NegativeTesting) | |
| 1582 | 		{
 | |
| 1583 | //Pass illegial client Id | |
| 1584 | r = lddChan.GetResourceStateSync(4342241, Resources[aResId].iResourceId, Cached, state, levelOwnerId); | |
| 1585 | test(r == KErrAccessDenied); | |
| 1586 | ||
| 1587 | //Pass illegal instance count | |
| 1588 | TUint id = Clients[iCurrentClientId].iClientId; | |
| 1589 | id = id ^ (1<<30); | |
| 1590 | r = lddChan.GetResourceStateSync(id, Resources[aResId].iResourceId, Cached, state, levelOwnerId); | |
| 1591 | test(r == KErrAccessDenied); | |
| 1592 | ||
| 1593 | //Invalid resource id | |
| 1594 | r = lddChan.GetResourceStateSync(Clients[iCurrentClientId].iClientId, iMaxStaticResources+40, Cached, state, levelOwnerId); | |
| 1595 | test(r == KErrNotFound); | |
| 1596 | ||
| 1597 | r = lddChan.GetResourceStateSync(Clients[iCurrentClientId].iClientId, 20, Cached, state, levelOwnerId); | |
| 1598 | test(r == KErrNotFound); | |
| 1599 | } | |
| 1600 | r = lddChan.GetResourceStateSync(Clients[iCurrentClientId].iClientId, Resources[aResId].iResourceId, Cached, state, levelOwnerId); | |
| 1601 | test(r == KErrNone); | |
| 1602 | test(state == Resources[aResId].iCurrentLevel); | |
| 1603 | if(Resources[aResId].iCurrentClient == -1) | |
| 1604 | test(levelOwnerId == -1); | |
| 1605 | else if (levelOwnerId != (TInt)Clients[Resources[aResId].iCurrentClient].iClientId) | |
| 1606 | 		{
 | |
| 1607 | 		test.Printf(_L("Expected ClientId = 0x%x, Returned ClientId = 0x%x\n"), Resources[aResId].iCurrentClient, levelOwnerId);
 | |
| 1608 | test(0); | |
| 1609 | } | |
| 1610 | Cached = !Cached; | |
| 1611 | return; | |
| 1612 | } | |
| 1613 | ||
| 1614 | //---------------------------------------------------------------------------------------------- | |
| 1615 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0587 | |
| 1616 | //! @SYMTestType UT | |
| 1617 | //! @SYMPREQ PREQ1398 | |
| 1618 | //! @SYMTestCaseDesc This test case tests get resource state functionality of resource manager | |
| 1619 | //! by getting the state of the resource asynchronously and checking for correctness. | |
| 1620 | //! This also tests the cancellation of asynchronous function by immediately cancelling the | |
| 1621 | //! operation after requesting get resource state. This is taken care in the driver. | |
| 1622 | //! There are positive and negative tests. | |
| 1623 | //! @SYMTestActions If negative testing is enabled then following tests are done | |
| 1624 | //! 0 Call the API with invalid client Id | |
| 1625 | //! 1 Call the API with invalid instance count of client Id. | |
| 1626 | //! 2 Call the API with invalid resource Id | |
| 1627 | //! Positive tests | |
| 1628 | //! 3 Call the API with valid client and resource Id. | |
| 1629 | //! | |
| 1630 | //! @SYMTestExpectedResults 0 API should return with KErrAccessDenied, panics otherwise | |
| 1631 | //! 1 API should return with KErrAccessDenied, panics otherwise | |
| 1632 | //! 2 API should return with KErrNotFound, panic otherwise. | |
| 1633 | //! 3 API should return with KErrNone or if cancellation of this | |
| 1634 | //! API is tested then will return with KErrCancel, panic otherwise. | |
| 1635 | //! This also checks the updated level and owner Id for correctness, | |
| 1636 | //! panics otherwise. | |
| 1637 | //! @SYMTestPriority High | |
| 1638 | //! @SYMTestStatus Implemented | |
| 1639 | //---------------------------------------------------------------------------------------------- | |
| 1640 | void TestRM::GetResourceStateAsync(TUint aResId, TBool aReqCancel) | |
| 1641 | 	{
 | |
| 1642 | static TBool Cached; | |
| 1643 | TRequestStatus resGet; | |
| 1644 | TInt state, levelOwnerId; | |
| 1645 | if(NegativeTesting) | |
| 1646 | 		{
 | |
| 1647 | //Pass illegial client Id | |
| 1648 | lddChan.GetResourceStateAsync(4342241, Resources[aResId].iResourceId, Cached, resGet, state, levelOwnerId); | |
| 1649 | User::WaitForRequest(resGet); | |
| 1650 | test(resGet.Int() == KErrAccessDenied); | |
| 1651 | ||
| 1652 | //Pass illegal instance count | |
| 1653 | TUint id = Clients[iCurrentClientId].iClientId; | |
| 1654 | id = id ^ (1<<30); | |
| 1655 | lddChan.GetResourceStateAsync(id, Resources[aResId].iResourceId, Cached, resGet, state, levelOwnerId); | |
| 1656 | User::WaitForRequest(resGet); | |
| 1657 | test(resGet.Int() == KErrAccessDenied); | |
| 1658 | ||
| 1659 | //Invalid resource id | |
| 1660 | lddChan.GetResourceStateAsync(Clients[iCurrentClientId].iClientId, iMaxStaticResources+48, Cached, resGet, state, levelOwnerId); | |
| 1661 | User::WaitForRequest(resGet); | |
| 1662 | test(resGet.Int() == KErrNotFound); | |
| 1663 | ||
| 1664 | lddChan.GetResourceStateAsync(Clients[iCurrentClientId].iClientId, 20, Cached, resGet, state, levelOwnerId); | |
| 1665 | User::WaitForRequest(resGet); | |
| 1666 | test(resGet.Int() == KErrNotFound); | |
| 1667 | } | |
| 1668 | lddChan.GetResourceStateAsync(Clients[iCurrentClientId].iClientId, Resources[aResId].iResourceId, Cached, resGet, state, levelOwnerId, aReqCancel); | |
| 1669 | User::WaitForRequest(resGet); | |
| 1670 | if(aReqCancel && (resGet.Int() != KErrNone)) | |
| 1671 | 		{
 | |
| 1672 | test(resGet.Int() == KErrCancel || resGet.Int() == KErrCompletion); | |
| 1673 | return; | |
| 1674 | } | |
| 1675 | test(state == Resources[aResId].iCurrentLevel); | |
| 1676 | if(Resources[aResId].iCurrentClient == -1) | |
| 1677 | test(levelOwnerId == -1); | |
| 1678 | else if (levelOwnerId != (TInt)Clients[Resources[aResId].iCurrentClient].iClientId) | |
| 1679 | 			{
 | |
| 1680 | 		test.Printf(_L("Expected ClientId = 0x%x, Returned ClientId = 0x%x\n"), Resources[aResId].iCurrentClient, levelOwnerId);
 | |
| 1681 | test(0); | |
| 1682 | } | |
| 1683 | Cached = !Cached; | |
| 1684 | } | |
| 1685 | ||
| 1686 | //---------------------------------------------------------------------------------------------- | |
| 1687 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0588 | |
| 1688 | //! @SYMTestType UT | |
| 1689 | //! @SYMPREQ PREQ1398 | |
| 1690 | //! @SYMTestCaseDesc This test case tests unconditional notification request functionality of resource manager. | |
| 1691 | //! @SYMTestActions Call the API with valid client and resource Id. | |
| 1692 | //! | |
| 1693 | //! @SYMTestExpectedResults API should return with KErrNone, panics otherwise. | |
| 1694 | //! @SYMTestPriority High | |
| 1695 | //! @SYMTestStatus Implemented | |
| 1696 | //---------------------------------------------------------------------------------------------- | |
| 1697 | void TestRM::RequestNotification(TUint aResId) | |
| 1698 | 	{
 | |
| 1699 | //If unconditional notification is already queued for this client then dont request another one. | |
| 1700 | for(NotiInfo *pN = Resources[aResId].iUncondNoti; pN != NULL; pN = pN->iNext) | |
| 1701 | 		{
 | |
| 1702 | if((TInt)pN->iClientId == iCurrentClientId) | |
| 1703 | return; | |
| 1704 | } | |
| 1705 | r = lddChan.RequestNotification(Clients[iCurrentClientId].iClientId, Resources[aResId].iResourceId); | |
| 1706 | if(r != KErrNone) | |
| 1707 | 		test.Printf(_L("Request Notification returned with %d"), r);
 | |
| 1708 | test(r == KErrNone); | |
| 1709 | //Add to resource list | |
| 1710 | NotiInfo *info = new NotiInfo; | |
| 1711 | test(info != NULL); | |
| 1712 | info->iClientId = iCurrentClientId; | |
| 1713 | LIST_PUSH(Resources[aResId].iUncondNoti, info, iNext); | |
| 1714 | Resources[aResId].iUnCondNotiCount++; | |
| 1715 | } | |
| 1716 | ||
| 1717 | //---------------------------------------------------------------------------------------------- | |
| 1718 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0589 | |
| 1719 | //! @SYMTestType UT | |
| 1720 | //! @SYMPREQ PREQ1398 | |
| 1721 | //! @SYMTestCaseDesc This test case tests conditional notification request functionality of resource manager. | |
| 1722 | //! Threshold and direction are chosen randomly for each resource based on the resource information. | |
| 1723 | //! @SYMTestActions Call the API with valid client and resource Id. | |
| 1724 | //! | |
| 1725 | //! @SYMTestExpectedResults API should return with KErrNone, panics otherwise. | |
| 1726 | //! @SYMTestPriority High | |
| 1727 | //! @SYMTestStatus Implemented | |
| 1728 | //---------------------------------------------------------------------------------------------- | |
| 1729 | void TestRM::RequestNotificationCon(TUint aResId) | |
| 1730 | 	{
 | |
| 1731 | //Allow only one notification per client. | |
| 1732 | static TBool direction; | |
| 1733 | TInt threshold = direction; | |
| 1734 | for(NotiInfo *pN = Resources[aResId].iCondNoti; pN != NULL; pN = pN->iNext) | |
| 1735 | 		{
 | |
| 1736 | if((TInt)pN->iClientId == iCurrentClientId) | |
| 1737 | return; | |
| 1738 | } | |
| 1739 | if(Resources[aResId].iType) | |
| 1740 | 		{
 | |
| 1741 | if(Resources[aResId].iSense == EPositive) | |
| 1742 | 			{
 | |
| 1743 | threshold = Math::Random() % Resources[aResId].iMaxLevel; | |
| 1744 | if(threshold < Resources[aResId].iMinLevel) | |
| 1745 | threshold += Resources[aResId].iMinLevel; | |
| 1746 | } | |
| 1747 | else if(Resources[aResId].iSense == ENegative) | |
| 1748 | 			{
 | |
| 1749 | threshold = Math::Random() % Resources[aResId].iMinLevel; | |
| 1750 | if(threshold < Resources[aResId].iMaxLevel) | |
| 1751 | threshold += Resources[aResId].iMaxLevel; | |
| 1752 | } | |
| 1753 | } | |
| 1754 | r = lddChan.RequestNotification(Clients[iCurrentClientId].iClientId, Resources[aResId].iResourceId, direction, threshold); | |
| 1755 | if(r != KErrNone) | |
| 1756 | 		test.Printf(_L("Request Notification returned with %d for direction = %d, threshold = %d"), r, direction, threshold);
 | |
| 1757 | test(r == KErrNone); | |
| 1758 | NotiInfo *info = new NotiInfo; | |
| 1759 | test(info != NULL); | |
| 1760 | info->iClientId = iCurrentClientId; | |
| 1761 | info->iThreshold = threshold; | |
| 1762 | info->iDirection = direction; | |
| 1763 | info->iPreviousLevel = Resources[aResId].iCurrentLevel; | |
| 1764 | LIST_PUSH(Resources[aResId].iCondNoti, info, iNext); | |
| 1765 | direction = !direction; | |
| 1766 | } | |
| 1767 | ||
| 1768 | //---------------------------------------------------------------------------------------------- | |
| 1769 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0590 | |
| 1770 | //! @SYMTestType UT | |
| 1771 | //! @SYMPREQ PREQ1398 | |
| 1772 | //! @SYMTestCaseDesc This test case tests cancellation of notification functionality of resource manager. | |
| 1773 | //! @SYMTestActions Call the API with valid client and resource Id. | |
| 1774 | //! | |
| 1775 | //! @SYMTestExpectedResults API should return with KErrCancel, panics otherwise. | |
| 1776 | //! @SYMTestPriority High | |
| 1777 | //! @SYMTestStatus Implemented | |
| 1778 | //---------------------------------------------------------------------------------------------- | |
| 1779 | void TestRM::CancelNotification(TUint aResId, TBool Cond) | |
| 1780 | 	{
 | |
| 1781 | RMResInfo *pR = &Resources[aResId]; | |
| 1782 | TBool found = EFalse; | |
| 1783 | if(Cond) | |
| 1784 | 		{
 | |
| 1785 | //Remove any conditional notification this client has on resource. | |
| 1786 | for(NotiInfo* pI = pR->iCondNoti; pI != NULL; pI = pI->iNext) | |
| 1787 | 			{
 | |
| 1788 | if((TInt)pI->iClientId == iCurrentClientId) | |
| 1789 | 				{
 | |
| 1790 | LIST_REMOVE(pR->iCondNoti, pI, iNext, NotiInfo); | |
| 1791 | delete pI; | |
| 1792 | found = ETrue; | |
| 1793 | break; | |
| 1794 | } | |
| 1795 | } | |
| 1796 | } | |
| 1797 | else | |
| 1798 | 		{
 | |
| 1799 | //Remove any unconditional notification this client has on resource. | |
| 1800 | for(NotiInfo* pI = pR->iUncondNoti; pI != NULL; pI = pI->iNext) | |
| 1801 | 			{
 | |
| 1802 | if((TInt)pI->iClientId == iCurrentClientId) | |
| 1803 | 				{
 | |
| 1804 | LIST_REMOVE(pR->iUncondNoti, pI, iNext, NotiInfo); | |
| 1805 | pR->iUnCondNotiCount--; | |
| 1806 | delete pI; | |
| 1807 | found = ETrue; | |
| 1808 | break; | |
| 1809 | } | |
| 1810 | } | |
| 1811 | } | |
| 1812 | if(found) | |
| 1813 | 		{
 | |
| 1814 | r = lddChan.CancelNotification(Clients[iCurrentClientId].iClientId, Resources[aResId].iResourceId, Cond); | |
| 1815 | if(r != KErrCancel) | |
| 1816 | 			test.Printf(_L("CancelNotification Clients %d, return value = %d"), iCurrentClientId, r);
 | |
| 1817 | test(r == KErrCancel); | |
| 1818 | } | |
| 1819 | } | |
| 1820 | ||
| 1821 | //---------------------------------------------------------------------------------------------- | |
| 1822 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0591 | |
| 1823 | //! @SYMTestType UT | |
| 1824 | //! @SYMPREQ PREQ1398 | |
| 1825 | //! @SYMTestCaseDesc This test case tests client registration and deregistration API of resource manager. | |
| 1826 | //! There are positive and negative tests. | |
| 1827 | //! @SYMTestActions 0 Call the client registration API with valid client name to register | |
| 1828 | //! 1 Call the client name updation API with valid client Id to get the client name | |
| 1829 | //! 2 Call the client name updation API with invalid client id. | |
| 1830 | //! 3 Call the client registration API with client name greater than maximum | |
| 1831 | //! allowable name length (32 characters) | |
| 1832 | //! 4 Call the client deregistration API by passing invalid client Id. | |
| 1833 | //! 5 Call the client deregistration API by passing invalid instance count. | |
| 1834 | //! 6 Call the client deregistration API by passing valid client Id. | |
| 1835 | //! | |
| 1836 | //! @SYMTestExpectedResults 0 API should return with KErrNone, panics otherwise. | |
| 1837 | //! 1 API should return with KErrNone and updated name is checked for | |
| 1838 | //! correctness, panics otherwise. | |
| 1839 | //! 2 API should return with KErrAccessDenied, panics otherwise. | |
| 1840 | //! 3 API should return with KErrTooBig, panics otherwise. | |
| 1841 | //! 4 API should return with KErrNotFound, panics otherwise. | |
| 1842 | //! 5 API should return with KErrNotFound, panics otherwise. | |
| 1843 | //! 6 API should return with KErrNone, panics otherwise. | |
| 1844 | //! @SYMTestPriority High | |
| 1845 | //! @SYMTestStatus Implemented | |
| 1846 | //---------------------------------------------------------------------------------------------- | |
| 1847 | void TestRM::ValidateClient(TUint aNumClients, TOwnerType aContext) | |
| 1848 | 	{
 | |
| 1849 | TInt r = KErrNone; | |
| 1850 | TBuf8<32> ClientName; | |
| 1851 | ClientName.Zero(); | |
| 1852 | 	ClientName.Append(_L8("Clients?"));
 | |
| 1853 | TUint clientId[MAX_CLIENTS]; | |
| 1854 | if(aNumClients > MAX_CLIENTS) | |
| 1855 | return; | |
| 1856 | TUint c; | |
| 1857 | for(c = 0; c < aNumClients; c++) | |
| 1858 | 		{
 | |
| 1859 | 		ClientName[7] = (TUint8)('0' + c);
 | |
| 1860 | r = lddChan.RegisterClient(clientId[c], (const TDesC*)&ClientName, aContext); | |
| 1861 | if(r != KErrNone) | |
| 1862 | 			{
 | |
| 1863 | 			test.Printf(_L("Client registration failed with %d"), r);
 | |
| 1864 | test(0); | |
| 1865 | } | |
| 1866 | } | |
| 1867 | ||
| 1868 | //Validate Client | |
| 1869 | TBuf8<32> aName; | |
| 1870 | ||
| 1871 | for(c = 0; c < aNumClients; c++) | |
| 1872 | 		{
 | |
| 1873 | 		ClientName[7] = (TUint8)('0' + c);
 | |
| 1874 | r = lddChan.GetClientName(clientId[c], clientId[c], (TDes8*)&aName); | |
| 1875 | if(r != KErrNone) | |
| 1876 | 			{
 | |
| 1877 | 			test.Printf(_L("GetClientName API failed with error %d"), r);
 | |
| 1878 | test(0); | |
| 1879 | } | |
| 1880 | r = aName.Compare(ClientName); | |
| 1881 | if(r != KErrNone) | |
| 1882 | 			{
 | |
| 1883 | 			test.Printf(_L("Client Name is not as expected"));
 | |
| 1884 | test(0); | |
| 1885 | } | |
| 1886 | } | |
| 1887 | //Invalid tests | |
| 1888 | 	ClientName[7] = (TUint8)('0' + aNumClients+1);
 | |
| 1889 | r = lddChan.GetClientName(aNumClients, clientId[0], &aName); | |
| 1890 | if(r != KErrAccessDenied) | |
| 1891 | 		{
 | |
| 1892 | 		test.Printf(_L("RM allows illegal clients"));
 | |
| 1893 | test(0); | |
| 1894 | } | |
| 1895 | ||
| 1896 | //Long filename | |
| 1897 | TBuf8<50> name; | |
| 1898 | name.Zero(); | |
| 1899 | 	name.Append(_L8("RegisteringClientNameGreaterThan32Characters"));
 | |
| 1900 | TUint id =0; | |
| 1901 | r = lddChan.RegisterClient(id, (const TDesC*)&name, aContext); | |
| 1902 | if(r != KErrTooBig) | |
| 1903 | 		{
 | |
| 1904 | 		test.Printf(_L("RM allows big names !!!"));
 | |
| 1905 | test(0); | |
| 1906 | } | |
| 1907 | 	test.Printf(_L("Client Deregistration"));
 | |
| 1908 | //Deregistration of non-existing client | |
| 1909 | id = 0; | |
| 1910 | r = lddChan.DeRegisterClient(id); | |
| 1911 | if(r != KErrNotFound) | |
| 1912 | 		{
 | |
| 1913 | 		test.Printf(_L("RM allows invalid client ID deregistration!!!"));
 | |
| 1914 | test(0); | |
| 1915 | } | |
| 1916 | ||
| 1917 | //Get client Name by passing invalid client Id (changing a bit in instance count) | |
| 1918 | id = clientId[0] ^ (1<<16); | |
| 1919 | r = lddChan.DeRegisterClient(id); | |
| 1920 | if(r != KErrNotFound) | |
| 1921 | 		{
 | |
| 1922 | 		test.Printf(_L("RM allows invalid client ID deregistation!!!"));
 | |
| 1923 | test(0); | |
| 1924 | } | |
| 1925 | ||
| 1926 | //Deregister the client registered at the start of this function | |
| 1927 | for(c = 0; c < aNumClients; c++) | |
| 1928 | 		{
 | |
| 1929 | r = lddChan.DeRegisterClient(clientId[c]); | |
| 1930 | if(r != KErrNone) | |
| 1931 | 			{
 | |
| 1932 | 			test.Printf(_L("Deregistration of client id 0x%x failed"), clientId[c]);
 | |
| 1933 | test(0); | |
| 1934 | } | |
| 1935 | } | |
| 1936 | return; | |
| 1937 | } | |
| 1938 | ||
| 1939 | #ifdef PRM_ENABLE_EXTENDED_VERSION | |
| 1940 | //---------------------------------------------------------------------------------------------- | |
| 1941 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0597 | |
| 1942 | //! @SYMTestType UT | |
| 1943 | //! @SYMPREQ PREQ1398 | |
| 1944 | //! @SYMTestCaseDesc This test case tests dynamic resources with dependency. | |
| 1945 | //! @SYMTestActions 0 Register clients | |
| 1946 | //! 1 Register dynamic resource with dependency | |
| 1947 | //! 2 Establish dependency between resources | |
| 1948 | //! 3 Register notifications | |
| 1949 | //! 4 Check dependency information for correctness | |
| 1950 | //! 5 Change Resource State of each resource | |
| 1951 | //! 6 Get state of the resources and verify them for correctness | |
| 1952 | //! 7 Check notification count for correctness | |
| 1953 | //! 8 Deregister dependency between resources | |
| 1954 | //! 9 Deregister client level | |
| 1955 | //! 10 Deregister dynamic resource with dependency | |
| 1956 | //! 11 Deregister clients | |
| 1957 | //! | |
| 1958 | //! @SYMTestExpectedResults 0 API should return with KErrNone, panics otherwise. | |
| 1959 | //! 1 API should return with KErrNone, panics otherwise. | |
| 1960 | //! 2 API should return with KErrNone, panics otherwise. | |
| 1961 | //! 3 API should return with KErrNone, panics otherwise. | |
| 1962 | //! 4 API should return with KErrNone, panics otherwise. | |
| 1963 | //! 5 API should return with KErrNone, panics otherwise. | |
| 1964 | //! 6 API should return with KErrNone, panics otherwise. | |
| 1965 | //! 7 API should return with KErrNone, panics otherwise. | |
| 1966 | //! 8 API should return with KErrNone, panics otherwise. | |
| 1967 | //! 9 API should return with KErrNone, panics otherwise. | |
| 1968 | //! 10 API should return with KErrNone, panics otherwise. | |
| 1969 | //! 11 API should return with KErrNone, panics otherwise. | |
| 1970 | //! @SYMTestPriority High | |
| 1971 | //! @SYMTestStatus Implemented | |
| 1972 | //---------------------------------------------------------------------------------------------- | |
| 1973 | /*This tests dynamic dependency resource. It also creates a dependency between static resource. | |
| 1974 | Below is the dependency tree | |
| 1975 | ResourceA <----------------> ResourceD <------------->ResourceE <--------------> ResourceC | |
| 1976 | | | | |
| 1977 | | | | |
| 1978 | | | | |
| 1979 | | | | |
| 1980 | | | | |
| 1981 | | | | |
| 1982 | ResourceF ResourceG <-------------> Resource H <------->Resource I | |
| 1983 | ¦ (Dynamic) (Dynamic) | |
| 1984 | ¦ | |
| 1985 | ¦ | |
| 1986 | ¦ | |
| 1987 | Resource J <-------->Resource K | |
| 1988 | (Dynamic) (Dynamic) | |
| 1989 | */ | |
| 1990 | void TestRM::TestDynamicResourceDependency() | |
| 1991 | 	{
 | |
| 1992 | TInt state; | |
| 1993 | TRequestStatus req; | |
| 1994 | SResourceDependencyInfo info1, info2; | |
| 1995 | SResourceDependencyInfo sResDepInfo; | |
| 1996 | RArray<SResourceDependencyInfo>depResArray; | |
| 1997 | ||
| 1998 | TUint dynamicDepResId[4]; | |
| 1999 | ||
| 2000 | 	test.Next(_L("Testing Dynamic + static resource dependency"));
 | |
| 2001 | RmTest.RegisterClient(); /* Register Client 1 */ | |
| 2002 | ||
| 2003 | //Register dependency resource | |
| 2004 | dynamicDepResId[0] = 5; | |
| 2005 | r = lddChan.RegisterDynamicResource(Clients[0].iClientId, dynamicDepResId[0]); | |
| 2006 | test(r == KErrNone); | |
| 2007 | ||
| 2008 | info1.iResourceId = iStaticDependencyResources[5]; | |
| 2009 | info1.iDependencyPriority = 3; | |
| 2010 | ||
| 2011 | info2.iResourceId = dynamicDepResId[0]; | |
| 2012 | info2.iDependencyPriority = 2; | |
| 2013 | ||
| 2014 | r = lddChan.RegisterResourceDependency(Clients[0].iClientId, info1, info2); | |
| 2015 | test(r == KErrNone); | |
| 2016 | ||
| 2017 | //Check for correctness of dependency resource information | |
| 2018 | sResDepInfo.iResourceId = iStaticDependencyResources[3]; | |
| 2019 | sResDepInfo.iDependencyPriority = 1; | |
| 2020 | depResArray.Append(sResDepInfo); | |
| 2021 | sResDepInfo.iResourceId = dynamicDepResId[0]; | |
| 2022 | sResDepInfo.iDependencyPriority = 2; | |
| 2023 | depResArray.Append(sResDepInfo); | |
| 2024 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, iStaticDependencyResources[5], 2, &depResArray[0]); | |
| 2025 | ||
| 2026 | depResArray[0].iResourceId = iStaticDependencyResources[5]; | |
| 2027 | depResArray[0].iDependencyPriority = 3; | |
| 2028 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, dynamicDepResId[0], 1, &depResArray[0]); | |
| 2029 | ||
| 2030 | //Change Static dependency resource to -50 | |
| 2031 | RmTest.RegisterClient(); /* Register Client 2 */ | |
| 2032 | state = -50; | |
| 2033 | lddChan.ChangeResourceStateAsync(Clients[1].iClientId, iStaticDependencyResources[0], state, req); | |
| 2034 | User::WaitForRequest(req); | |
| 2035 | test(req.Int() == KErrNone); | |
| 2036 | ||
| 2037 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[0], -50, Clients[1].iClientId, EFalse); | |
| 2038 | GetExtendedResStateAndVerify(iStaticDependencyResources[1], -11, iStaticDependencyResources[0]); | |
| 2039 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[2], 1, iStaticDependencyResources[0], EFalse); | |
| 2040 | GetExtendedResStateAndVerify(iStaticDependencyResources[3], 13, iStaticDependencyResources[0]); | |
| 2041 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 0, iStaticDependencyResources[3], EFalse); | |
| 2042 | GetExtendedResStateAndVerify(iStaticDependencyResources[5], 73, iStaticDependencyResources[3]); | |
| 2043 | GetExtendedResStateAndVerify(dynamicDepResId[0], 80, iStaticDependencyResources[5]); | |
| 2044 | ||
| 2045 | //Register dynamic dependency resource I | |
| 2046 | dynamicDepResId[1] = 6; | |
| 2047 | r = lddChan.RegisterDynamicResource(Clients[0].iClientId, dynamicDepResId[1]); | |
| 2048 | test(r == KErrNone); | |
| 2049 | ||
| 2050 | //Register dynamic dependency resource J | |
| 2051 | dynamicDepResId[2] = 7; | |
| 2052 | r = lddChan.RegisterDynamicResource(Clients[0].iClientId, dynamicDepResId[2]); | |
| 2053 | test(r == KErrNone); | |
| 2054 | ||
| 2055 | //Register dynamic dependency resource K | |
| 2056 | dynamicDepResId[3] = 8; | |
| 2057 | r = lddChan.RegisterDynamicResource(Clients[0].iClientId, dynamicDepResId[3]); | |
| 2058 | test(r == KErrNone); | |
| 2059 | ||
| 2060 | RmTest.RegisterClient(); /* Register Client3 */ | |
| 2061 | RmTest.RegisterClient(); /* Register Client4 */ | |
| 2062 | ||
| 2063 | //Register notifications | |
| 2064 | r = lddChan.RequestNotification(Clients[1].iClientId, iStaticDependencyResources[5]); | |
| 2065 | test(r == KErrNone); | |
| 2066 | r = lddChan.RequestNotification(Clients[2].iClientId, dynamicDepResId[0]); | |
| 2067 | test(r == KErrNone); | |
| 2068 | r = lddChan.RequestNotification(Clients[1].iClientId, dynamicDepResId[1]); | |
| 2069 | test(r == KErrNone); | |
| 2070 | r = lddChan.RequestNotification(Clients[2].iClientId, dynamicDepResId[2]); | |
| 2071 | test(r == KErrNone); | |
| 2072 | r = lddChan.RequestNotification(Clients[1].iClientId, dynamicDepResId[3]); | |
| 2073 | test(r == KErrNone); | |
| 2074 | ||
| 2075 | //Create depedency between H and I | |
| 2076 | info1.iResourceId = dynamicDepResId[0]; | |
| 2077 | info1.iDependencyPriority = 1; | |
| 2078 | ||
| 2079 | info2.iResourceId = dynamicDepResId[1]; | |
| 2080 | info2.iDependencyPriority = 1; | |
| 2081 | ||
| 2082 | //Register dependency between resource H and I | |
| 2083 | r = lddChan.RegisterResourceDependency(Clients[0].iClientId, info1, info2); | |
| 2084 | test(r == KErrNone); | |
| 2085 | //Validate dependency information | |
| 2086 | depResArray[0].iResourceId = dynamicDepResId[1]; | |
| 2087 | depResArray[0].iDependencyPriority = 1; | |
| 2088 | depResArray[1].iResourceId = iStaticDependencyResources[5]; | |
| 2089 | depResArray[1].iDependencyPriority = 3; | |
| 2090 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, dynamicDepResId[0], 2, &depResArray[0]); | |
| 2091 | ||
| 2092 | depResArray[0].iResourceId = dynamicDepResId[0]; | |
| 2093 | depResArray[0].iDependencyPriority = 1; | |
| 2094 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, dynamicDepResId[1], 1, &depResArray[0]); | |
| 2095 | ||
| 2096 | //Create depedency between H and J | |
| 2097 | info1.iResourceId = dynamicDepResId[0]; | |
| 2098 | info1.iDependencyPriority = 1; | |
| 2099 | ||
| 2100 | info2.iResourceId = dynamicDepResId[2]; | |
| 2101 | info2.iDependencyPriority = 2; | |
| 2102 | ||
| 2103 | //Register dependency between resource H and J | |
| 2104 | r = lddChan.RegisterResourceDependency(Clients[0].iClientId, info1, info2); | |
| 2105 | test(r == KErrNone); | |
| 2106 | ||
| 2107 | depResArray[0].iResourceId = dynamicDepResId[1]; | |
| 2108 | depResArray[0].iDependencyPriority = 1; | |
| 2109 | depResArray[1].iResourceId = dynamicDepResId[2]; | |
| 2110 | depResArray[1].iDependencyPriority = 2; | |
| 2111 | sResDepInfo.iResourceId = iStaticDependencyResources[5]; | |
| 2112 | sResDepInfo.iDependencyPriority = 3; | |
| 2113 | depResArray.Append(sResDepInfo); | |
| 2114 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, dynamicDepResId[0], 3, &depResArray[0]); | |
| 2115 | ||
| 2116 | depResArray[0].iResourceId = dynamicDepResId[0]; | |
| 2117 | depResArray[0].iDependencyPriority = 1; | |
| 2118 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, dynamicDepResId[2], 1, &depResArray[0]); | |
| 2119 | ||
| 2120 | // Check if the priority for a new dependency is already existing. | |
| 2121 | //Create dependency between J and K | |
| 2122 | info1.iResourceId = dynamicDepResId[2]; | |
| 2123 | info1.iDependencyPriority = 1; | |
| 2124 | ||
| 2125 | info2.iResourceId = dynamicDepResId[3]; | |
| 2126 | info2.iDependencyPriority = 1; | |
| 2127 | ||
| 2128 | //Register dependency between resource J and K | |
| 2129 | r = lddChan.RegisterResourceDependency(Clients[0].iClientId, info1, info2); | |
| 2130 | test(r == KErrAlreadyExists); | |
| 2131 | ||
| 2132 | //Create depedency between J and K | |
| 2133 | info1.iResourceId = dynamicDepResId[2]; | |
| 2134 | info1.iDependencyPriority = 1; | |
| 2135 | ||
| 2136 | info2.iResourceId = dynamicDepResId[3]; | |
| 2137 | info2.iDependencyPriority = 2; | |
| 2138 | ||
| 2139 | //Register dependency between resource J and K | |
| 2140 | r = lddChan.RegisterResourceDependency(Clients[0].iClientId, info1, info2); | |
| 2141 | test(r == KErrNone); | |
| 2142 | ||
| 2143 | depResArray[0].iResourceId = dynamicDepResId[2]; | |
| 2144 | depResArray[0].iDependencyPriority = 1; | |
| 2145 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, dynamicDepResId[3], 1, &depResArray[0]); | |
| 2146 | ||
| 2147 | depResArray[0].iResourceId = dynamicDepResId[0]; | |
| 2148 | depResArray[0].iDependencyPriority = 1; | |
| 2149 | depResArray[1].iResourceId = dynamicDepResId[3]; | |
| 2150 | depResArray[1].iDependencyPriority = 2; | |
| 2151 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, dynamicDepResId[2], 2, &depResArray[0]); | |
| 2152 | ||
| 2153 | RmTest.RegisterClient(); /* Client5 registration */ | |
| 2154 | //Change H to 85 | |
| 2155 | r = lddChan.ChangeResourceStateSync(Clients[2].iClientId, dynamicDepResId[0], 85); | |
| 2156 | test(r == KErrNone); | |
| 2157 | ||
| 2158 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[0], -50, Clients[1].iClientId, EFalse); | |
| 2159 | GetExtendedResStateAndVerify(iStaticDependencyResources[1], -11, iStaticDependencyResources[0]); | |
| 2160 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[2], 1, iStaticDependencyResources[0], EFalse); | |
| 2161 | GetExtendedResStateAndVerify(iStaticDependencyResources[3], 13, iStaticDependencyResources[0]); | |
| 2162 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 0, iStaticDependencyResources[3], EFalse); | |
| 2163 | GetExtendedResStateAndVerify(iStaticDependencyResources[5], 71, dynamicDepResId[0]); | |
| 2164 | GetExtendedResStateAndVerify(dynamicDepResId[0], 85, Clients[2].iClientId); | |
| 2165 | GetExtendedResStateAsyncAndVerify(dynamicDepResId[1], 1, dynamicDepResId[0]); | |
| 2166 | GetExtendedResStateAsyncAndVerify(dynamicDepResId[2], 18, dynamicDepResId[0], EFalse); | |
| 2167 | GetExtendedResStateAndVerify(dynamicDepResId[3], 1, dynamicDepResId[2]); | |
| 2168 | ||
| 2169 | //Check notifications | |
| 2170 | r = lddChan.CheckNotifications(iStaticDependencyResources[5], 1, 0); | |
| 2171 | test(r == KErrNone); | |
| 2172 | r = lddChan.CheckNotifications(dynamicDepResId[0], 1, 0); | |
| 2173 | test(r == KErrNone); | |
| 2174 | r = lddChan.CheckNotifications(dynamicDepResId[1], 1, 0); | |
| 2175 | test(r == KErrNone); | |
| 2176 | r = lddChan.CheckNotifications(dynamicDepResId[2], 1, 0); | |
| 2177 | test(r == KErrNone); | |
| 2178 | ||
| 2179 | //Change K to 1 | |
| 2180 | state= 1; | |
| 2181 | lddChan.ChangeResourceStateAsync(Clients[2].iClientId, dynamicDepResId[3], state, req); | |
| 4 
56f325a607ea
Revision: 200951
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
0diff
changeset | 2182 | User::WaitForRequest(req); | 
| 
56f325a607ea
Revision: 200951
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
0diff
changeset | 2183 | test(req.Int() == KErrNone); | 
| 0 | 2184 | |
| 2185 | GetExtendedResStateAsyncAndVerify(dynamicDepResId[2], 18, dynamicDepResId[0], EFalse); | |
| 2186 | GetExtendedResStateAsyncAndVerify(dynamicDepResId[3], 1, Clients[2].iClientId, EFalse); | |
| 2187 | ||
| 2188 | //Check notifications | |
| 2189 | r = lddChan.CheckNotifications(dynamicDepResId[2], 0, 0); | |
| 2190 | test(r == KErrNone); | |
| 2191 | r = lddChan.CheckNotifications(dynamicDepResId[3], 0, 0); | |
| 2192 | test(r == KErrNone); | |
| 2193 | ||
| 2194 | //Change J to 12 | |
| 2195 | r = lddChan.ChangeResourceStateSync(Clients[2].iClientId, dynamicDepResId[2],12); | |
| 2196 | test(r == KErrNone); | |
| 2197 | ||
| 2198 | GetExtendedResStateAsyncAndVerify(dynamicDepResId[2], 12, Clients[2].iClientId, EFalse); | |
| 2199 | ||
| 2200 | //Check notifications | |
| 2201 | r = lddChan.CheckNotifications(dynamicDepResId[0], 0, 0); | |
| 2202 | test(r == KErrNone); | |
| 2203 | r = lddChan.CheckNotifications(dynamicDepResId[2], 1, 0); | |
| 2204 | test(r == KErrNone); | |
| 2205 | r = lddChan.CheckNotifications(dynamicDepResId[3], 0, 0); | |
| 2206 | test(r == KErrNone); | |
| 2207 | ||
| 2208 | //Change H to 90 | |
| 2209 | TRequestStatus reqSet; | |
| 2210 | state = 90; | |
| 2211 | lddChan.CheckParallelExecutionForChangeResState(Clients[2].iClientId, | |
| 2212 | dynamicDepResId[0],state, | |
| 2213 | 5, 0, reqSet); | |
| 2214 | User::WaitForRequest(reqSet); | |
| 2215 | test(reqSet.Int() == KErrNone); | |
| 2216 | ||
| 2217 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[0], -50, Clients[1].iClientId, EFalse); | |
| 2218 | GetExtendedResStateAndVerify(iStaticDependencyResources[1], -11, iStaticDependencyResources[0]); | |
| 2219 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[2], 1, iStaticDependencyResources[0], EFalse); | |
| 2220 | GetExtendedResStateAndVerify(iStaticDependencyResources[3], 13, iStaticDependencyResources[0]); | |
| 2221 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 0, iStaticDependencyResources[3], EFalse); | |
| 2222 | GetExtendedResStateAndVerify(iStaticDependencyResources[5], 69, dynamicDepResId[0]); | |
| 2223 | GetExtendedResStateAndVerify(dynamicDepResId[0], 90, Clients[2].iClientId); | |
| 2224 | GetExtendedResStateAsyncAndVerify(dynamicDepResId[1], 1, dynamicDepResId[0]); | |
| 2225 | GetExtendedResStateAsyncAndVerify(dynamicDepResId[2], 11, dynamicDepResId[0], EFalse); | |
| 2226 | GetExtendedResStateAndVerify(dynamicDepResId[3], 1, Clients[2].iClientId); | |
| 2227 | ||
| 2228 | //Check notifications | |
| 2229 | r = lddChan.CheckNotifications(iStaticDependencyResources[5], 1, 0); | |
| 2230 | test(r == KErrNone); | |
| 2231 | r = lddChan.CheckNotifications(dynamicDepResId[0], 1, 0); | |
| 2232 | test(r == KErrNone); | |
| 2233 | r = lddChan.CheckNotifications(dynamicDepResId[1], 0, 0); | |
| 2234 | test(r == KErrNone); | |
| 2235 | r = lddChan.CheckNotifications(dynamicDepResId[2], 1, 0); | |
| 2236 | test(r == KErrNone); | |
| 2237 | r = lddChan.CheckNotifications(dynamicDepResId[3], 0, 0); | |
| 2238 | test(r == KErrNone); | |
| 2239 | ||
| 2240 | state = 9; | |
| 2241 | lddChan.ChangeResourceStateAsync(Clients[1].iClientId, dynamicDepResId[2], state, req); | |
| 2242 | User::WaitForRequest(req); | |
| 2243 | test(req.Int() == KErrNone); | |
| 2244 | ||
| 2245 | GetExtendedResStateAndVerify(dynamicDepResId[0], 90, Clients[2].iClientId); | |
| 2246 | GetExtendedResStateAsyncAndVerify(dynamicDepResId[1], 1, dynamicDepResId[0]); | |
| 2247 | GetExtendedResStateAsyncAndVerify(dynamicDepResId[2], 9, Clients[1].iClientId, EFalse); | |
| 2248 | GetExtendedResStateAndVerify(dynamicDepResId[3], 1, Clients[2].iClientId); | |
| 2249 | ||
| 2250 | //Check notifications | |
| 2251 | r = lddChan.CheckNotifications(dynamicDepResId[0], 0, 0); | |
| 2252 | test(r == KErrNone); | |
| 2253 | r = lddChan.CheckNotifications(dynamicDepResId[1], 0, 0); | |
| 2254 | test(r == KErrNone); | |
| 2255 | r = lddChan.CheckNotifications(dynamicDepResId[2], 1, 0); | |
| 2256 | test(r == KErrNone); | |
| 2257 | r = lddChan.CheckNotifications(dynamicDepResId[3], 0, 0); | |
| 2258 | test(r == KErrNone); | |
| 2259 | ||
| 2260 | //Change D to 50 | |
| 2261 | state = 50; | |
| 2262 | lddChan.ChangeResourceStateAsync(Clients[1].iClientId, iStaticDependencyResources[0], state, req); | |
| 2263 | User::WaitForRequest(req); | |
| 2264 | test(req.Int() == KErrNone); | |
| 2265 | ||
| 2266 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[0], 50, Clients[1].iClientId, EFalse); | |
| 2267 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[1], -12, iStaticDependencyResources[0], EFalse); | |
| 2268 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[2], 1, iStaticDependencyResources[0], EFalse); | |
| 2269 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[3], 16, iStaticDependencyResources[0], EFalse); | |
| 2270 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 0, iStaticDependencyResources[3], EFalse); | |
| 2271 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[5], 67, iStaticDependencyResources[3], EFalse); | |
| 2272 | GetExtendedResStateAndVerify(dynamicDepResId[0], 90, Clients[2].iClientId); | |
| 2273 | GetExtendedResStateAsyncAndVerify(dynamicDepResId[1], 1, dynamicDepResId[0]); | |
| 2274 | GetExtendedResStateAsyncAndVerify(dynamicDepResId[2], 9, Clients[1].iClientId, EFalse); | |
| 2275 | GetExtendedResStateAndVerify(dynamicDepResId[3], 1, Clients[2].iClientId); | |
| 2276 | ||
| 2277 | //Check notifications | |
| 2278 | r = lddChan.CheckNotifications(iStaticDependencyResources[5], 1, 0); | |
| 2279 | test(r == KErrNone); | |
| 2280 | //DeRegister dependency between J and K | |
| 2281 | r = lddChan.DeRegisterResourceDependency(Clients[0].iClientId, dynamicDepResId[3], dynamicDepResId[2]); | |
| 2282 | test(r == KErrNone); | |
| 2283 | ||
| 2284 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, dynamicDepResId[3], 0, &depResArray[0]); | |
| 2285 | ||
| 2286 | depResArray[0].iResourceId = dynamicDepResId[0]; | |
| 2287 | depResArray[0].iDependencyPriority = 1; | |
| 2288 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, dynamicDepResId[2], 1, &depResArray[0]); | |
| 2289 | ||
| 2290 | //Change J t0 13 | |
| 2291 | r = lddChan.ChangeResourceStateSync(Clients[1].iClientId, dynamicDepResId[2], 13); | |
| 2292 | test(r == KErrNone); | |
| 2293 | ||
| 2294 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[0], 50, Clients[1].iClientId, EFalse); | |
| 2295 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[1], -12, iStaticDependencyResources[0], EFalse); | |
| 2296 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[2], 1, iStaticDependencyResources[0], EFalse); | |
| 2297 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[3], 16, iStaticDependencyResources[0], EFalse); | |
| 2298 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 0, iStaticDependencyResources[3], EFalse); | |
| 2299 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[5], 67, iStaticDependencyResources[3], EFalse); | |
| 2300 | GetExtendedResStateAndVerify(dynamicDepResId[0], 90, Clients[2].iClientId); | |
| 2301 | GetExtendedResStateAsyncAndVerify(dynamicDepResId[1], 1, dynamicDepResId[0]); | |
| 2302 | GetExtendedResStateAsyncAndVerify(dynamicDepResId[2], 12, Clients[2].iClientId, EFalse); | |
| 2303 | GetExtendedResStateAndVerify(dynamicDepResId[3], 1, Clients[2].iClientId); | |
| 2304 | //Check notifications | |
| 2305 | r = lddChan.CheckNotifications(dynamicDepResId[2], 1, 0); | |
| 2306 | test(r == KErrNone); | |
| 2307 | /* Remove client level from resource 7 */ | |
| 2308 | r = lddChan.DeRegisterClientLevelFromResource(Clients[2].iClientId, dynamicDepResId[3]); | |
| 2309 | test(r == KErrNone); | |
| 2310 | ||
| 2311 | GetExtendedResStateAndVerify(dynamicDepResId[3], 0, -1); | |
| 2312 | //Check notifications | |
| 2313 | r = lddChan.CheckNotifications(dynamicDepResId[3], 1, 0); | |
| 2314 | test(r == KErrNone); | |
| 2315 | ||
| 2316 | r = lddChan.DeRegisterDynamicResource(Clients[0].iClientId, dynamicDepResId[3], NULL); | |
| 2317 | test(r == KErrNone); | |
| 2318 | //Check notifications | |
| 2319 | r = lddChan.CheckNotifications(dynamicDepResId[3], 1, 0); | |
| 2320 | test(r == KErrNone); | |
| 2321 | ||
| 2322 | //Deregister dependency between H and J | |
| 2323 | r = lddChan.DeRegisterResourceDependency(Clients[0].iClientId, dynamicDepResId[2], dynamicDepResId[0]); | |
| 2324 | test(r == KErrNone); | |
| 2325 | ||
| 2326 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, dynamicDepResId[2], 0, &depResArray[0]); | |
| 2327 | ||
| 2328 | depResArray[0].iResourceId = dynamicDepResId[1]; | |
| 2329 | depResArray[0].iDependencyPriority = 1; | |
| 2330 | depResArray[1].iResourceId = iStaticDependencyResources[5]; | |
| 2331 | depResArray[1].iDependencyPriority = 3; | |
| 2332 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, dynamicDepResId[0], 2, &depResArray[0]); | |
| 2333 | ||
| 2334 | /* Remove client level from resource 7 */ | |
| 2335 | r = lddChan.DeRegisterClientLevelFromResource(Clients[1].iClientId, dynamicDepResId[2]); | |
| 2336 | test(r == KErrNone); | |
| 2337 | ||
| 2338 | GetExtendedResStateAndVerify(dynamicDepResId[2], 12, Clients[2].iClientId); | |
| 2339 | //Check notifications | |
| 2340 | r = lddChan.CheckNotifications(dynamicDepResId[2], 0, 0); | |
| 2341 | test(r == KErrNone); | |
| 2342 | ||
| 2343 | r = lddChan.DeRegisterClient(Clients[2].iClientId); | |
| 2344 | test(r == KErrNone); | |
| 2345 | ||
| 2346 | GetExtendedResStateAsyncAndVerify(dynamicDepResId[2], 19, -1, EFalse); | |
| 2347 | ||
| 2348 | //Deregister dependency between G and H | |
| 2349 | r = lddChan.DeRegisterResourceDependency(Clients[1].iClientId, iStaticDependencyResources[5], dynamicDepResId[0]); | |
| 2350 | test(r == KErrNone); | |
| 2351 | ||
| 2352 | depResArray[0].iResourceId = dynamicDepResId[1]; | |
| 2353 | depResArray[0].iDependencyPriority = 1; | |
| 2354 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, dynamicDepResId[0], 1, &depResArray[0]); | |
| 2355 | ||
| 2356 | depResArray[0].iResourceId = iStaticDependencyResources[3]; | |
| 2357 | depResArray[0].iDependencyPriority = 1; | |
| 2358 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, iStaticDependencyResources[5], 1, &depResArray[0]); | |
| 2359 | ||
| 2360 | GetExtendedResStateAndVerify(dynamicDepResId[0], 75, -1); | |
| 2361 | GetExtendedResStateAsyncAndVerify(dynamicDepResId[1], 0, dynamicDepResId[0]); | |
| 2362 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[5], 67, iStaticDependencyResources[3], EFalse); | |
| 2363 | ||
| 2364 | //Deregister dependency between I and H | |
| 2365 | r = lddChan.DeRegisterResourceDependency(Clients[1].iClientId, dynamicDepResId[1], dynamicDepResId[0]); | |
| 2366 | test(r == KErrNone); | |
| 2367 | ||
| 2368 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, dynamicDepResId[0], 0, &depResArray[0]); | |
| 2369 | ||
| 2370 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, dynamicDepResId[1], 0, &depResArray[0]); | |
| 2371 | ||
| 2372 | GetExtendedResStateAndVerify(dynamicDepResId[0], 75, -1); | |
| 2373 | GetExtendedResStateAsyncAndVerify(dynamicDepResId[1], 0, -1); | |
| 2374 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[5], 67, iStaticDependencyResources[3], EFalse); | |
| 2375 | //Check notifications | |
| 2376 | r = lddChan.CheckNotifications(iStaticDependencyResources[5], 0, 0); | |
| 2377 | test(r == KErrNone); | |
| 2378 | r = lddChan.CheckNotifications(dynamicDepResId[1], 1, 0); | |
| 2379 | test(r == KErrNone); | |
| 2380 | ||
| 2381 | r = lddChan.DeRegisterDynamicResource(Clients[0].iClientId, dynamicDepResId[2], NULL); | |
| 2382 | test(r == KErrNone); | |
| 2383 | r = lddChan.DeRegisterDynamicResource(Clients[0].iClientId, dynamicDepResId[1], NULL); | |
| 2384 | test(r == KErrNone); | |
| 2385 | //Check notifications | |
| 2386 | r = lddChan.CheckNotifications(dynamicDepResId[1], 1, 0); | |
| 2387 | test(r == KErrNone); | |
| 2388 | r = lddChan.DeRegisterDynamicResource(Clients[0].iClientId, dynamicDepResId[0], NULL); | |
| 2389 | test(r == KErrNone); | |
| 2390 | r = lddChan.DeRegisterClient(Clients[1].iClientId); | |
| 2391 | test(r == KErrNone); | |
| 2392 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[0], -100, -1, EFalse); | |
| 2393 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[1], -10, iStaticDependencyResources[0], EFalse); | |
| 2394 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[2], 0, iStaticDependencyResources[0], EFalse); | |
| 2395 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[3], 10, iStaticDependencyResources[0], EFalse); | |
| 2396 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 1, iStaticDependencyResources[3], EFalse); | |
| 2397 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[5], 75, iStaticDependencyResources[3], EFalse); | |
| 2398 | r = lddChan.DeRegisterClient(Clients[3].iClientId); | |
| 2399 | test(r == KErrNone); | |
| 2400 | ||
| 2401 | r = lddChan.DeRegisterClient(Clients[0].iClientId); | |
| 2402 | test(r == KErrNone); | |
| 2403 | ||
| 2404 | r = lddChan.DeRegisterClient(Clients[4].iClientId); | |
| 2405 | test(r == KErrNone); | |
| 2406 | ||
| 2407 | depResArray.Close(); | |
| 2408 | return; | |
| 2409 | } | |
| 2410 | ||
| 2411 | //---------------------------------------------------------------------------------------------- | |
| 2412 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0596 | |
| 2413 | //! @SYMTestType UT | |
| 2414 | //! @SYMPREQ PREQ1398 | |
| 2415 | //! @SYMTestCaseDesc This test case tests dynamic resources which does not support dependency | |
| 2416 | //! @SYMTestActions 0 Register clients | |
| 2417 | //! 1 Register dynamic resource | |
| 2418 | //! 2 Register notifications | |
| 2419 | //! 3 Change Resource State of each static resource with dependency | |
| 2420 | //! 4 Get state of the resource and check for correctness | |
| 2421 | //! 5 Check notification count for correctness | |
| 2422 | //! 6 Deregister client level | |
| 2423 | //! 7 Deregister dynamic resource | |
| 2424 | //! 8 Deregister clients | |
| 2425 | //! | |
| 2426 | //! @SYMTestExpectedResults 0 API should return with KErrNone, panics otherwise. | |
| 2427 | //! 1 API should return with KErrNone, panics otherwise. | |
| 2428 | //! 2 API should return with KErrNone, panics otherwise. | |
| 2429 | //! 3 API should return with KErrNone, panics otherwise. | |
| 2430 | //! 4 API should return with KErrNone, panics otherwise. | |
| 2431 | //! 5 API should return with KErrNone, panics otherwise. | |
| 2432 | //! 6 API should return with KErrNone, panics otherwise. | |
| 2433 | //! 7 API should return with KErrNone, panics otherwise. | |
| 2434 | //! 8 API should return with KErrNone, panics otherwise. | |
| 2435 | //! @SYMTestPriority High | |
| 2436 | //! @SYMTestStatus Implemented | |
| 2437 | //---------------------------------------------------------------------------------------------- | |
| 2438 | void TestRM::TestDynamicResource() | |
| 2439 | 	{
 | |
| 2440 | TInt state; | |
| 2441 | TRequestStatus req; | |
| 2442 | TUint dynamicResId[4]; | |
| 2443 | ||
| 2444 | 	test.Next(_L("Testing dynamic resource"));
 | |
| 2445 | //Register client 1 | |
| 2446 | RmTest.RegisterClient(); | |
| 2447 | //Register client 2 | |
| 2448 | RmTest.RegisterClient(); | |
| 2449 | //Register client 3 | |
| 2450 | RmTest.RegisterClient(); | |
| 2451 | ||
| 2452 | NegativeTesting = EFalse; | |
| 2453 | dynamicResId[0] = 1; | |
| 2454 | //Register dynamic resource 1 | |
| 2455 | r = lddChan.RegisterDynamicResource(Clients[0].iClientId, dynamicResId[0]); | |
| 2456 | test(r == KErrNone); | |
| 2457 | //Deregister dynamic resource with different client id | |
| 2458 | r = lddChan.DeRegisterDynamicResource(Clients[1].iClientId, dynamicResId[0], NULL); | |
| 2459 | test(r == KErrAccessDenied); | |
| 2460 | dynamicResId[1] = 2; | |
| 2461 | //Register dynamic resource 2 | |
| 2462 | r = lddChan.RegisterDynamicResource(Clients[1].iClientId, dynamicResId[1]); | |
| 2463 | test(r == KErrNone); | |
| 2464 | RmTest.GetNumResourcesInUseByClient(iCurrentClientId); | |
| 2465 | RmTest.GetInfoOnResourcesInUseByClient(iCurrentClientId, iMaxStaticResources); | |
| 2466 | ||
| 2467 | TUint numClients; | |
| 2468 | r = lddChan.GetNumClientsUsingResource(Clients[0].iClientId, dynamicResId[0], numClients); | |
| 2469 | test(r == KErrNone); | |
| 2470 | test(numClients == 0); | |
| 2471 | ||
| 2472 | r = lddChan.RequestNotification(Clients[1].iClientId, dynamicResId[0]); | |
| 2473 | test(r == KErrNone); | |
| 2474 | //Register client 4 | |
| 2475 | RmTest.RegisterClient(); | |
| 2476 | r = lddChan.RequestNotification(Clients[2].iClientId, dynamicResId[0], 1, 1); | |
| 2477 | test(r == KErrNone); | |
| 2478 | //Change state of dynamic resource 1 and verify | |
| 2479 | state = 1; | |
| 2480 | lddChan.ChangeResourceStateAsync(Clients[0].iClientId, dynamicResId[0], state, req); | |
| 2481 | User::WaitForRequest(req); | |
| 2482 | test(req.Int() == KErrNone); | |
| 2483 | ||
| 2484 | r = lddChan.CheckNotifications(dynamicResId[0], 1, 1); | |
| 2485 | test(r == KErrNone); | |
| 2486 | ||
| 2487 | GetExtendedResStateAsyncAndVerify(dynamicResId[0], 1, Clients[0].iClientId, EFalse); | |
| 2488 | ||
| 2489 | r = lddChan.GetNumClientsUsingResource(Clients[0].iClientId, dynamicResId[0], numClients); | |
| 2490 | test(r == KErrNone); | |
| 2491 | test(numClients == 1); | |
| 2492 | //Change state of dynamic resource 1. | |
| 2493 | r = lddChan.ChangeResourceStateSync(Clients[1].iClientId, dynamicResId[0], 0); | |
| 2494 | test(r == KErrAccessDenied); | |
| 2495 | //Deregister dynamic resource 1 and set the resource to 1. | |
| 2496 | state = 1; | |
| 2497 | r = lddChan.DeRegisterDynamicResource(Clients[0].iClientId, dynamicResId[0], &state); | |
| 2498 | test(r == KErrNone); | |
| 2499 | ||
| 2500 | r = lddChan.CheckNotifications(dynamicResId[0], 1, 1); | |
| 2501 | test(r == KErrNone); | |
| 2502 | ||
| 2503 | r = lddChan.GetNumClientsUsingResource(Clients[0].iClientId, dynamicResId[0], numClients); | |
| 2504 | test(r == KErrNotFound); | |
| 2505 | //Register client 5 | |
| 2506 | RmTest.RegisterClient(); | |
| 2507 | ||
| 2508 | GetExtendedResStateAndVerify(dynamicResId[1], -5, -1); | |
| 2509 | ||
| 2510 | r = lddChan.RequestNotification(Clients[1].iClientId, dynamicResId[1]); | |
| 2511 | test(r == KErrNone); | |
| 2512 | ||
| 2513 | r = lddChan.RequestNotification(Clients[2].iClientId, dynamicResId[1], 0, -8); | |
| 2514 | test(r == KErrNone); | |
| 2515 | //Change state of dynamic resource 1 and verify | |
| 2516 | state = -7; | |
| 2517 | lddChan.ChangeResourceStateAsync(Clients[2].iClientId, dynamicResId[1], state, req); | |
| 2518 | User::WaitForRequest(req); | |
| 2519 | test(req.Int() == KErrNone); | |
| 2520 | ||
| 2521 | r = lddChan.CheckNotifications(dynamicResId[1], 1, 0); | |
| 2522 | test(r == KErrNone); | |
| 2523 | ||
| 2524 | GetExtendedResStateAndVerify(dynamicResId[1], -7, Clients[2].iClientId); | |
| 2525 | //Register client 6 | |
| 2526 | RmTest.RegisterClient(); | |
| 2527 | //Register client 7 | |
| 2528 | RmTest.RegisterClient(); | |
| 2529 | //Change state of dynamic resource 2 and verify | |
| 2530 | state = -9; | |
| 2531 | lddChan.ChangeResourceStateAsync(Clients[3].iClientId, dynamicResId[1], state, req); | |
| 2532 | User::WaitForRequest(req); | |
| 2533 | test(req.Int() == KErrNone); | |
| 2534 | ||
| 2535 | r = lddChan.CheckNotifications(dynamicResId[1], 1, 1); | |
| 2536 | test(r == KErrNone); | |
| 2537 | ||
| 2538 | GetExtendedResStateAsyncAndVerify(dynamicResId[1], -9, Clients[3].iClientId, EFalse); | |
| 2539 | //Change state of dynamic resource 1 and verify | |
| 2540 | state = -10; | |
| 2541 | lddChan.ChangeResourceStateAsync(Clients[4].iClientId, dynamicResId[1], state, req); | |
| 2542 | User::WaitForRequest(req); | |
| 2543 | test(req.Int() == KErrNone); | |
| 2544 | ||
| 2545 | r = lddChan.CheckNotifications(dynamicResId[1], 1, 0); | |
| 2546 | test(r == KErrNone); | |
| 2547 | ||
| 2548 | GetExtendedResStateAsyncAndVerify(dynamicResId[1], -10, Clients[4].iClientId, EFalse); | |
| 2549 | ||
| 2550 | lddChan.ChangeResourceStateSync(Clients[5].iClientId, dynamicResId[1], state); | |
| 2551 | test(r == KErrNone); | |
| 2552 | ||
| 2553 | r = lddChan.CheckNotifications(dynamicResId[1], 0, 0); | |
| 2554 | test(r == KErrNone); | |
| 2555 | ||
| 2556 | GetExtendedResStateAsyncAndVerify(dynamicResId[1], -10, Clients[4].iClientId, EFalse); | |
| 2557 | //Change state of dynamic resource 1 and verify | |
| 2558 | state = -6; | |
| 2559 | lddChan.ChangeResourceStateSync(Clients[6].iClientId, dynamicResId[1], state); | |
| 2560 | test(r == KErrNone); | |
| 2561 | ||
| 2562 | r = lddChan.CheckNotifications(dynamicResId[1], 0, 0); | |
| 2563 | test(r == KErrNone); | |
| 2564 | ||
| 2565 | GetExtendedResStateAsyncAndVerify(dynamicResId[1], -10, Clients[4].iClientId, EFalse); | |
| 2566 | ||
| 2567 | r = lddChan.DeRegisterClientLevelFromResource(Clients[4].iClientId, dynamicResId[1]); | |
| 2568 | test(r == KErrNone); | |
| 2569 | ||
| 2570 | GetExtendedResStateAsyncAndVerify(dynamicResId[1], -10, Clients[5].iClientId, EFalse); | |
| 2571 | ||
| 2572 | r = lddChan.DeRegisterClientLevelFromResource(Clients[5].iClientId, dynamicResId[1]); | |
| 2573 | test(r == KErrNone); | |
| 2574 | ||
| 2575 | r = lddChan.CheckNotifications(dynamicResId[1], 1, 0); | |
| 2576 | test(r == KErrNone); | |
| 2577 | GetExtendedResStateAsyncAndVerify(dynamicResId[1], -9, Clients[3].iClientId, EFalse); | |
| 2578 | //Deregister client 4 | |
| 2579 | r = lddChan.DeRegisterClient(Clients[3].iClientId); | |
| 2580 | test(r == KErrNone); | |
| 2581 | ||
| 2582 | r = lddChan.CheckNotifications(dynamicResId[1], 1, 0); | |
| 2583 | test(r == KErrNone); | |
| 2584 | GetExtendedResStateAsyncAndVerify(dynamicResId[1], -7, Clients[2].iClientId, EFalse); | |
| 2585 | ||
| 2586 | r = lddChan.DeRegisterClientLevelFromResource(Clients[2].iClientId, dynamicResId[1]); | |
| 2587 | test(r == KErrNone); | |
| 2588 | ||
| 2589 | r = lddChan.CheckNotifications(dynamicResId[1], 1, 0); | |
| 2590 | test(r == KErrNone); | |
| 2591 | GetExtendedResStateAsyncAndVerify(dynamicResId[1], -6, Clients[6].iClientId, EFalse); | |
| 2592 | ||
| 2593 | r = lddChan.DeRegisterClientLevelFromResource(Clients[6].iClientId, dynamicResId[1]); | |
| 2594 | test(r == KErrNone); | |
| 2595 | ||
| 2596 | r = lddChan.CheckNotifications(dynamicResId[1], 1, 0); | |
| 2597 | test(r == KErrNone); | |
| 2598 | GetExtendedResStateAsyncAndVerify(dynamicResId[1], -5, -1, EFalse); | |
| 2599 | //Deregister dynamic resource 2 | |
| 2600 | r = lddChan.DeRegisterDynamicResource(Clients[1].iClientId, dynamicResId[1], NULL); | |
| 2601 | test(r == KErrNone); | |
| 2602 | ||
| 2603 | r = lddChan.CheckNotifications(dynamicResId[1], 1, 1); | |
| 2604 | test(r == KErrNone); | |
| 2605 | //Register dynamic resource 3 | |
| 2606 | dynamicResId[2] = 3; | |
| 2607 | r = lddChan.RegisterDynamicResource(Clients[2].iClientId, dynamicResId[2]); | |
| 2608 | test(r == KErrNone); | |
| 2609 | //Register dynamic resource 4 | |
| 2610 | dynamicResId[3] = 4; | |
| 2611 | r = lddChan.RegisterDynamicResource(Clients[6].iClientId, dynamicResId[3]); | |
| 2612 | test(r == KErrNone); | |
| 2613 | //Change state of dynamic resource 3 to 0 | |
| 2614 | r = lddChan.ChangeResourceStateSync(Clients[4].iClientId, dynamicResId[2], 0); | |
| 2615 | test(r == KErrNone); | |
| 2616 | GetExtendedResStateAndVerify(dynamicResId[2], 0, Clients[4].iClientId); | |
| 2617 | //Change state of dynamic resource 3 to 1 | |
| 2618 | r = lddChan.ChangeResourceStateSync(Clients[5].iClientId, dynamicResId[2], 1); | |
| 2619 | test(r == KErrNone); | |
| 2620 | GetExtendedResStateAndVerify(dynamicResId[2], 0, Clients[4].iClientId); | |
| 2621 | //Deregister client 5 | |
| 2622 | r = lddChan.DeRegisterClient(Clients[4].iClientId); | |
| 2623 | test(r == KErrNone); | |
| 2624 | GetExtendedResStateAndVerify(dynamicResId[2], 1, Clients[5].iClientId); | |
| 2625 | //Deregister dynamic resource 3 | |
| 2626 | r = lddChan.DeRegisterDynamicResource(Clients[2].iClientId, dynamicResId[2], NULL); | |
| 2627 | test(r == KErrInUse); | |
| 2628 | //Deregister client 6 | |
| 2629 | r = lddChan.DeRegisterClient(Clients[5].iClientId); | |
| 2630 | test(r == KErrNone); | |
| 2631 | GetExtendedResStateAndVerify(dynamicResId[2], 1, -1); | |
| 2632 | //Deregister dynamic resource 3 | |
| 2633 | r = lddChan.DeRegisterDynamicResource(Clients[2].iClientId, dynamicResId[2], NULL); | |
| 2634 | test(r == KErrNone); | |
| 2635 | //Change state of dynamic resource 4 to 15 | |
| 2636 | r = lddChan.ChangeResourceStateSync(Clients[6].iClientId, dynamicResId[3], 15); | |
| 2637 | test(r == KErrNone); | |
| 2638 | GetExtendedResStateAndVerify(dynamicResId[3], 15, Clients[6].iClientId); | |
| 2639 | //Change state of resource and try to deregister the resource while the change is taking place | |
| 2640 | state = 17; | |
| 2641 | lddChan.ChangeResStateAndDeRegisterDynamicRes(Clients[6].iClientId, dynamicResId[3], state, req); | |
| 2642 | User::WaitForRequest(req); | |
| 2643 | test(req.Int() == KErrNone); | |
| 2644 | test(state == 17); | |
| 2645 | GetExtendedResStateAndVerify(dynamicResId[3], 17, Clients[6].iClientId); | |
| 2646 | //Deregister dynamic resource 4 with some other client which is not owner | |
| 2647 | r = lddChan.DeRegisterDynamicResource(Clients[2].iClientId, dynamicResId[3], NULL); | |
| 2648 | test(r == KErrAccessDenied); | |
| 2649 | //Deregister dynamic resource 4 | |
| 2650 | r = lddChan.DeRegisterDynamicResource(Clients[6].iClientId, dynamicResId[3], NULL); | |
| 2651 | test(r == KErrNone); | |
| 2652 | //Deregister client 7 | |
| 2653 | r = lddChan.DeRegisterClient(Clients[6].iClientId); | |
| 2654 | test(r == KErrNone); | |
| 2655 | //Deregister client 3 | |
| 2656 | r = lddChan.DeRegisterClient(Clients[2].iClientId); | |
| 2657 | test(r == KErrNone); | |
| 2658 | //Deregister client 2 | |
| 2659 | r = lddChan.DeRegisterClient(Clients[1].iClientId); | |
| 2660 | test(r == KErrNone); | |
| 2661 | //Deregister client 1 | |
| 2662 | r = lddChan.DeRegisterClient(Clients[0].iClientId); | |
| 2663 | test(r == KErrNone); | |
| 2664 | Clients.Close(); | |
| 2665 | } | |
| 2666 | ||
| 2667 | //This function gets extended resource state synchronously and verifies for correctness | |
| 2668 | void TestRM::GetExtendedResStateAndVerify(TUint aResId, TInt aState, TInt aLevelOwnerId) | |
| 2669 | 	{
 | |
| 2670 | static TBool cached = ETrue; | |
| 2671 | TInt state; | |
| 2672 | TInt levelOwnerId; | |
| 2673 | r = lddChan.GetResourceStateSync(Clients[0].iClientId, aResId, cached, state, levelOwnerId); | |
| 2674 | test(r == KErrNone); | |
| 2675 | test(state == aState); | |
| 2676 | test(levelOwnerId == aLevelOwnerId); | |
| 2677 | return; | |
| 2678 | } | |
| 2679 | ||
| 2680 | //This function gets extended resource state asynchronously and verifies for correctness | |
| 2681 | void TestRM::GetExtendedResStateAsyncAndVerify(TUint aResId, TInt aState, TInt aLevelOwnerId, TBool aReqCancel) | |
| 2682 | 	{
 | |
| 2683 | static TBool cached = ETrue; | |
| 2684 | TRequestStatus resGet; | |
| 2685 | TInt levelOwnerId; | |
| 2686 | TInt state; | |
| 2687 | lddChan.GetResourceStateAsync(Clients[0].iClientId, aResId, cached, resGet, state, levelOwnerId, aReqCancel); | |
| 2688 | User::WaitForRequest(resGet); | |
| 2689 | if(aReqCancel && (resGet.Int() != KErrNone)) | |
| 2690 | 		{
 | |
| 2691 | test((resGet.Int() == KErrCompletion) || (resGet.Int() == KErrCancel)); | |
| 2692 | return; | |
| 2693 | } | |
| 2694 | test(resGet.Int() == KErrNone); | |
| 2695 | test(state == aState); | |
| 2696 | test(levelOwnerId == aLevelOwnerId); | |
| 2697 | } | |
| 2698 | ||
| 2699 | //This function validates number of dependency resource and their id's for correctness | |
| 2700 | void TestRM::CheckForDependencyInformation(TUint aClientId, TUint aResourceId, TUint aNumDependents, SResourceDependencyInfo* aDepResIdArray) | |
| 2701 | 	{
 | |
| 2702 | TUint numDepResources; | |
| 2703 | ||
| 2704 | //Get the number of dependent's for the resource | |
| 2705 | r = lddChan.GetNumDependentsForResource(aClientId, aResourceId, numDepResources); | |
| 2706 | if(r != KErrNone) | |
| 2707 | 		test.Printf(_L("GetNumDependentsForResource returned with %d\n"), r);
 | |
| 2708 | test(r == KErrNone); | |
| 2709 | if(aNumDependents != numDepResources) | |
| 2710 | 		test.Printf(_L("aNumDependents = %d, numDepResource = %d\n"), aNumDependents, numDepResources);
 | |
| 2711 | test(aNumDependents == numDepResources); | |
| 2712 | if(numDepResources == 0) | |
| 2713 | return; | |
| 2714 | //Get the dependent's id | |
| 2715 | RBuf8 info; | |
| 2716 | info.Create(aNumDependents * sizeof(SResourceDependencyInfo)); | |
| 2717 | r = lddChan.GetDependentsIdForResource(aClientId, aResourceId, (TAny*)&info, numDepResources); | |
| 2718 | if(r != KErrNone) | |
| 2719 | 		{
 | |
| 2720 | 		test.Printf(_L("GetDependentsIdForResource returned with %d\n"), r);
 | |
| 2721 | info.Close(); | |
| 2722 | } | |
| 2723 | test(r == KErrNone); | |
| 2724 | if(aNumDependents != numDepResources) | |
| 2725 | 		{
 | |
| 2726 | 		test.Printf(_L("aNumDependents = %d, numDepResource = %d\n"), aNumDependents, numDepResources);
 | |
| 2727 | info.Close(); | |
| 2728 | } | |
| 2729 | test(aNumDependents == numDepResources); | |
| 2730 | SResourceDependencyInfo* sResDepInfoPtr = (SResourceDependencyInfo*)info.Ptr(); | |
| 2731 | for(TUint count = 0; count < aNumDependents; count++, sResDepInfoPtr++) | |
| 2732 | 		{
 | |
| 2733 | if(sResDepInfoPtr->iResourceId != aDepResIdArray[count].iResourceId) | |
| 2734 | 			{
 | |
| 2735 | 			test.Printf(_L("Expected resourceId : %d, Returned ResourceId = %d\n"),sResDepInfoPtr->iResourceId, 
 | |
| 2736 | aDepResIdArray[count].iResourceId); | |
| 2737 | info.Close(); | |
| 2738 | test(0); | |
| 2739 | } | |
| 2740 | if(sResDepInfoPtr->iDependencyPriority != aDepResIdArray[count].iDependencyPriority) | |
| 2741 | 			{
 | |
| 2742 | 			test.Printf(_L("Expected resource priority : %d, Returned resource priority = %d\n"),sResDepInfoPtr->iDependencyPriority, 
 | |
| 2743 | aDepResIdArray[count].iDependencyPriority); | |
| 2744 | info.Close(); | |
| 2745 | test(0); | |
| 2746 | } | |
| 2747 | } | |
| 2748 | info.Close(); | |
| 2749 | return; | |
| 2750 | } | |
| 2751 | ||
| 2752 | //---------------------------------------------------------------------------------------------- | |
| 2753 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0595 | |
| 2754 | //! @SYMTestType UT | |
| 2755 | //! @SYMPREQ PREQ1398 | |
| 2756 | //! @SYMTestCaseDesc This test case tests static resources with dependency. | |
| 2757 | //! @SYMTestActions 0 Register clients | |
| 2758 | //! 1 Check dependency information of each resource | |
| 2759 | //! 2 Register notifications | |
| 2760 | //! 3 Change Resource State of each static resource with dependency | |
| 2761 | //! 4 Get state of the resources and verify them for correctness | |
| 2762 | //! 5 Check notification count for correctness | |
| 2763 | //! 6 Deregister client level | |
| 2764 | //! 7 Deregister clients | |
| 2765 | //! | |
| 2766 | //! @SYMTestExpectedResults 0 API should return with KErrNone, panics otherwise. | |
| 2767 | //! 1 API should return with KErrNone, panics otherwise. | |
| 2768 | //! 2 API should return with KErrNone, panics otherwise. | |
| 2769 | //! 3 API should return with KErrNone, panics otherwise. | |
| 2770 | //! 4 API should return with KErrNone, panics otherwise. | |
| 2771 | //! 5 API should return with KErrNone, panics otherwise. | |
| 2772 | //! 6 API should return with KErrNone, panics otherwise. | |
| 2773 | //! 7 API should return with KErrNone, panics otherwise. | |
| 2774 | //! @SYMTestPriority High | |
| 2775 | //! @SYMTestStatus Implemented | |
| 2776 | //---------------------------------------------------------------------------------------------- | |
| 2777 | void TestRM::TestStaticResourceWithDependency() | |
| 2778 | 	{
 | |
| 2779 | TUint count; | |
| 2780 | RArray<SResourceDependencyInfo>depResArray; | |
| 2781 | SResourceDependencyInfo sResDepInfo; | |
| 2782 | TUint numClients; // The maximum no. of dependents in the dependency tree. | |
| 2783 | ||
| 2784 | ||
| 2785 | //Register client 1. | |
| 2786 | RmTest.RegisterClient(); | |
| 2787 | iCurrentClientId = -1; | |
| 2788 | TInt state; | |
| 2789 | TRequestStatus reqSet; | |
| 2790 | ||
| 2791 | NegativeTesting = EFalse; | |
| 2792 | 	test.Next(_L("\nTesting static resource with dependency...."));
 | |
| 2793 | ||
| 2794 | //Check for resource dependency information of Resource D | |
| 2795 | sResDepInfo.iResourceId = iStaticDependencyResources[1]; | |
| 2796 | sResDepInfo.iDependencyPriority = 1; | |
| 2797 | depResArray.Append(sResDepInfo); | |
| 2798 | sResDepInfo.iResourceId = iStaticDependencyResources[3]; | |
| 2799 | sResDepInfo.iDependencyPriority = 2; | |
| 2800 | depResArray.Append(sResDepInfo); | |
| 2801 | sResDepInfo.iResourceId = iStaticDependencyResources[2]; | |
| 2802 | sResDepInfo.iDependencyPriority = 3; | |
| 2803 | depResArray.Append(sResDepInfo); | |
| 2804 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, iStaticDependencyResources[0], 3, &depResArray[0]); | |
| 2805 | ||
| 2806 | //Check for resource dependency information of Resource E | |
| 2807 | depResArray[0].iResourceId = iStaticDependencyResources[4]; | |
| 2808 | depResArray[0].iDependencyPriority = 1; | |
| 2809 | depResArray[1].iResourceId = iStaticDependencyResources[5]; | |
| 2810 | depResArray[1].iDependencyPriority = 2; | |
| 2811 | depResArray[2].iResourceId = iStaticDependencyResources[0]; | |
| 2812 | depResArray[2].iDependencyPriority = 3; | |
| 2813 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, iStaticDependencyResources[3], 3, &depResArray[0]); | |
| 2814 | ||
| 2815 | //Check for resource dependency information of Resource C | |
| 2816 | depResArray[0].iResourceId = iStaticDependencyResources[3]; | |
| 2817 | depResArray[0].iDependencyPriority = 1; | |
| 2818 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, iStaticDependencyResources[4], 1, &depResArray[0]); | |
| 2819 | ||
| 2820 | //Check for resource dependency information of Resource G | |
| 2821 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, iStaticDependencyResources[5], 1, &depResArray[0]); | |
| 2822 | ||
| 2823 | //Check for resource dependency information of Resource F | |
| 2824 | depResArray[0].iResourceId = iStaticDependencyResources[0]; | |
| 2825 | depResArray[0].iDependencyPriority = 1; | |
| 2826 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, iStaticDependencyResources[2], 1, &depResArray[0]); | |
| 2827 | ||
| 2828 | //Check for resource dependency information of Resource A | |
| 2829 | RmTest.CheckForDependencyInformation(Clients[0].iClientId, iStaticDependencyResources[1], 1, &depResArray[0]); | |
| 2830 | ||
| 2831 | RmTest.GetNumResourcesInUseByClient(iCurrentClientId); | |
| 2832 | RmTest.GetInfoOnResourcesInUseByClient(iCurrentClientId, iMaxStaticResources + iMaxStaticDependentResources); | |
| 2833 | iCurrentClientId = 0; | |
| 2834 | //Get resource state of all dependent resource and verify | |
| 2835 | GetExtendedResStateAndVerify(iStaticDependencyResources[0], -50, -1); | |
| 2836 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[1], -11, iStaticDependencyResources[0]); | |
| 2837 | GetExtendedResStateAndVerify(iStaticDependencyResources[2], 1, iStaticDependencyResources[0]); | |
| 2838 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[3], 13, iStaticDependencyResources[0]); | |
| 2839 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 0, iStaticDependencyResources[3]); | |
| 2840 | GetExtendedResStateAndVerify(iStaticDependencyResources[5], 73, iStaticDependencyResources[3]); | |
| 2841 | ||
| 2842 | r = lddChan.GetNumClientsUsingResource(Clients[0].iClientId, iStaticDependencyResources[3], numClients); | |
| 2843 | test(r == KErrNone); | |
| 2844 | test(numClients == 0); | |
| 2845 | //Request notification | |
| 2846 | for(count = 0; count < iMaxStaticDependentResources; count++) | |
| 2847 | 		{
 | |
| 2848 | r = lddChan.RequestNotification(Clients[0].iClientId, iStaticDependencyResources[count]); | |
| 2849 | test(r == KErrNone); | |
| 2850 | } | |
| 2851 | //Change state of resource A to -11 and verify | |
| 2852 | r = lddChan.ChangeResourceStateSync(Clients[0].iClientId, iStaticDependencyResources[1], -11); | |
| 2853 | test(r == KErrNone); | |
| 2854 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[1], -11, Clients[0].iClientId); | |
| 2855 | //Change state of resource A to -12 and verify | |
| 2856 | state = -12; | |
| 2857 | lddChan.ChangeResourceStateAsync(Clients[0].iClientId, iStaticDependencyResources[1], state, reqSet); | |
| 2858 | User::WaitForRequest(reqSet); | |
| 2859 | test(reqSet.Int() == KErrNone); | |
| 2860 | r = lddChan.CheckNotifications(iStaticDependencyResources[1], 1, 0); | |
| 2861 | test(r == KErrNone); | |
| 2862 | //Register client2 | |
| 2863 | RmTest.RegisterClient(); | |
| 2864 | //Change state of resource D to -49 and verify | |
| 2865 | state = -49; | |
| 2866 | lddChan.ChangeResourceStateAsync(Clients[1].iClientId, iStaticDependencyResources[0], state, reqSet); | |
| 2867 | User::WaitForRequest(reqSet); | |
| 2868 | test(reqSet.Int() == KErrNone); | |
| 2869 | //Check for notifications | |
| 2870 | r = lddChan.CheckNotifications(iStaticDependencyResources[0], 1, 0); | |
| 2871 | test(r == KErrNone); | |
| 2872 | r = lddChan.CheckNotifications(iStaticDependencyResources[1], 1, 0); | |
| 2873 | test(r == KErrNone); | |
| 2874 | r = lddChan.CheckNotifications(iStaticDependencyResources[3], 1, 0); | |
| 2875 | test(r == KErrNone); | |
| 2876 | r = lddChan.CheckNotifications(iStaticDependencyResources[5], 1, 0); | |
| 2877 | test(r == KErrNone); | |
| 2878 | //Get the state and verify for correctness | |
| 2879 | GetExtendedResStateAndVerify(iStaticDependencyResources[0], -49, Clients[1].iClientId); | |
| 2880 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[1], -13, iStaticDependencyResources[0]); | |
| 2881 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[2], 1, iStaticDependencyResources[0]); | |
| 2882 | GetExtendedResStateAndVerify(iStaticDependencyResources[3], 16, iStaticDependencyResources[0]); | |
| 2883 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 0, iStaticDependencyResources[3]); | |
| 2884 | GetExtendedResStateAndVerify(iStaticDependencyResources[5], 71, iStaticDependencyResources[3]); | |
| 2885 | //Change state of resource F to 1 and verify | |
| 2886 | r = lddChan.ChangeResourceStateSync(Clients[1].iClientId, iStaticDependencyResources[2], 1); | |
| 2887 | test(r == KErrNone); | |
| 2888 | r = lddChan.CheckNotifications(iStaticDependencyResources[2], 0, 0); | |
| 2889 | test(r == KErrNone); | |
| 2890 | GetExtendedResStateAndVerify(iStaticDependencyResources[2], 1, Clients[1].iClientId); | |
| 2891 | //Register client 3 | |
| 2892 | RmTest.RegisterClient(); | |
| 2893 | //Change state of resource E to 19 and verify | |
| 2894 | r = lddChan.ChangeResourceStateSync(Clients[2].iClientId, iStaticDependencyResources[3], 19); | |
| 2895 | test(r == KErrNone); | |
| 2896 | r = lddChan.CheckNotifications(iStaticDependencyResources[3], 1, 0); | |
| 2897 | test(r == KErrNone); | |
| 2898 | r = lddChan.CheckNotifications(iStaticDependencyResources[5], 1, 0); | |
| 2899 | test(r == KErrNone); | |
| 2900 | GetExtendedResStateAndVerify(iStaticDependencyResources[0], -49, Clients[1].iClientId); | |
| 2901 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[1], -13, iStaticDependencyResources[0]); | |
| 2902 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[2], 1, Clients[1].iClientId); | |
| 2903 | GetExtendedResStateAndVerify(iStaticDependencyResources[3], 19, Clients[2].iClientId); | |
| 2904 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 0, iStaticDependencyResources[3]); | |
| 2905 | GetExtendedResStateAndVerify(iStaticDependencyResources[5], 69, iStaticDependencyResources[3]); | |
| 2906 | //Register client 4 | |
| 2907 | RmTest.RegisterClient(); | |
| 2908 | //Change state of resource C to 0 and verify | |
| 2909 | r = lddChan.ChangeResourceStateSync(Clients[3].iClientId, iStaticDependencyResources[4], 0); | |
| 2910 | test(r == KErrNone); | |
| 2911 | r = lddChan.CheckNotifications(iStaticDependencyResources[4], 0, 0); | |
| 2912 | test(r == KErrNone); | |
| 2913 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 0, iStaticDependencyResources[3]); | |
| 2914 | //Change state of resource C to 1 and verify | |
| 2915 | r = lddChan.ChangeResourceStateSync(Clients[2].iClientId, iStaticDependencyResources[4], 1); | |
| 2916 | test(r == KErrNone); | |
| 2917 | r = lddChan.CheckNotifications(iStaticDependencyResources[4], 0, 0); | |
| 2918 | test(r == KErrNone); | |
| 2919 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 0, iStaticDependencyResources[3]); | |
| 2920 | //Change state of resource G to 67 and verify | |
| 2921 | r = lddChan.ChangeResourceStateSync(Clients[2].iClientId, iStaticDependencyResources[5], 67); | |
| 2922 | test(r == KErrNone); | |
| 2923 | r = lddChan.CheckNotifications(iStaticDependencyResources[5], 1, 0); | |
| 2924 | test(r == KErrNone); | |
| 2925 | GetExtendedResStateAndVerify(iStaticDependencyResources[0], -49, Clients[1].iClientId); | |
| 2926 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[1], -13, iStaticDependencyResources[0]); | |
| 2927 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[2], 1, Clients[1].iClientId); | |
| 2928 | GetExtendedResStateAndVerify(iStaticDependencyResources[3], 19, Clients[2].iClientId); | |
| 2929 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 0, iStaticDependencyResources[3]); | |
| 2930 | GetExtendedResStateAndVerify(iStaticDependencyResources[5], 67, Clients[2].iClientId); | |
| 2931 | //Change state of resource G to 67 and verify | |
| 2932 | r = lddChan.ChangeResourceStateSync(Clients[3].iClientId, iStaticDependencyResources[5], 67); | |
| 2933 | test(r == KErrNone); | |
| 2934 | r = lddChan.CheckNotifications(iStaticDependencyResources[5], 0, 0); | |
| 2935 | test(r == KErrNone); | |
| 2936 | GetExtendedResStateAndVerify(iStaticDependencyResources[0], -49, Clients[1].iClientId); | |
| 2937 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[1], -13, iStaticDependencyResources[0]); | |
| 2938 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[2], 1, Clients[1].iClientId); | |
| 2939 | GetExtendedResStateAndVerify(iStaticDependencyResources[3], 19, Clients[2].iClientId); | |
| 2940 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 0, iStaticDependencyResources[3]); | |
| 2941 | GetExtendedResStateAndVerify(iStaticDependencyResources[5], 67, Clients[2].iClientId); | |
| 2942 | ||
| 2943 | //Change the state of the resource E to 24 | |
| 2944 | state = 24; | |
| 2945 | //Register client 5 | |
| 2946 | RmTest.RegisterClient(); | |
| 2947 | lddChan.ChangeResourceStateAsync(Clients[4].iClientId, iStaticDependencyResources[3], state, reqSet); | |
| 2948 | User::WaitForRequest(reqSet); | |
| 2949 | test(reqSet.Int() == KErrNone); | |
| 2950 | r = lddChan.CheckNotifications(iStaticDependencyResources[3], 1, 0); | |
| 2951 | test(r == KErrNone); | |
| 2952 | r = lddChan.CheckNotifications(iStaticDependencyResources[5], 1, 0); | |
| 2953 | test(r == KErrNone); | |
| 2954 | GetExtendedResStateAndVerify(iStaticDependencyResources[0], -49, Clients[1].iClientId); | |
| 2955 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[1], -13, iStaticDependencyResources[0]); | |
| 2956 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[2], 1, Clients[1].iClientId); | |
| 2957 | GetExtendedResStateAndVerify(iStaticDependencyResources[3], 24, Clients[4].iClientId); | |
| 2958 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 0, iStaticDependencyResources[3]); | |
| 2959 | GetExtendedResStateAndVerify(iStaticDependencyResources[5], 65, iStaticDependencyResources[3]); | |
| 2960 | ||
| 2961 | //Change resource state of Resource D to -51 | |
| 2962 | r = lddChan.ChangeResourceStateSync(Clients[2].iClientId, iStaticDependencyResources[0], -51); | |
| 2963 | test(r == KErrAccessDenied); | |
| 2964 | GetExtendedResStateAndVerify(iStaticDependencyResources[0], -49, Clients[1].iClientId); | |
| 2965 | ||
| 2966 | //DeregisterClient 5 | |
| 2967 | r = lddChan.DeRegisterClient(Clients[4].iClientId); | |
| 2968 | test(r == KErrNone); | |
| 2969 | ||
| 2970 | r = lddChan.CheckNotifications(iStaticDependencyResources[3], 1, 0); | |
| 2971 | test(r == KErrNone); | |
| 2972 | r = lddChan.CheckNotifications(iStaticDependencyResources[5], 1, 0); | |
| 2973 | test(r == KErrNone); | |
| 2974 | ||
| 2975 | GetExtendedResStateAndVerify(iStaticDependencyResources[3], 19, Clients[2].iClientId); | |
| 2976 | GetExtendedResStateAndVerify(iStaticDependencyResources[5], 63, iStaticDependencyResources[3]); | |
| 2977 | ||
| 2978 | //Change resource state of resource D to 50 | |
| 2979 | state = 50; | |
| 2980 | lddChan.ChangeResourceStateAsync(Clients[1].iClientId, iStaticDependencyResources[0], state, reqSet); | |
| 2981 | User::WaitForRequest(reqSet); | |
| 2982 | test(reqSet.Int() == KErrNone); | |
| 2983 | r = lddChan.CheckNotifications(iStaticDependencyResources[0], 1, 0); | |
| 2984 | test(r == KErrNone); | |
| 2985 | r = lddChan.CheckNotifications(iStaticDependencyResources[1], 1, 0); | |
| 2986 | test(r == KErrNone); | |
| 2987 | r = lddChan.CheckNotifications(iStaticDependencyResources[3], 1, 0); | |
| 2988 | test(r == KErrNone); | |
| 2989 | r = lddChan.CheckNotifications(iStaticDependencyResources[5], 1, 0); | |
| 2990 | test(r == KErrNone); | |
| 2991 | ||
| 2992 | GetExtendedResStateAndVerify(iStaticDependencyResources[0], 50, Clients[1].iClientId); | |
| 2993 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[1], -14, iStaticDependencyResources[0]); | |
| 2994 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[2], 1, Clients[1].iClientId); | |
| 2995 | GetExtendedResStateAndVerify(iStaticDependencyResources[3], 22, iStaticDependencyResources[0]); | |
| 2996 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 0, iStaticDependencyResources[3]); | |
| 2997 | GetExtendedResStateAndVerify(iStaticDependencyResources[5], 61, iStaticDependencyResources[3]); | |
| 2998 | ||
| 2999 | //Change resource state of resource G to 61 | |
| 3000 | r = lddChan.ChangeResourceStateSync(Clients[3].iClientId, iStaticDependencyResources[5], 61); | |
| 3001 | test(r == KErrNone); | |
| 3002 | ||
| 3003 | r = lddChan.CheckNotifications(iStaticDependencyResources[5], 0, 0); | |
| 3004 | test(r == KErrNone); | |
| 3005 | ||
| 3006 | GetExtendedResStateAndVerify(iStaticDependencyResources[0], 50, Clients[1].iClientId); | |
| 3007 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[1], -14, iStaticDependencyResources[0]); | |
| 3008 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[2], 1, Clients[1].iClientId); | |
| 3009 | GetExtendedResStateAndVerify(iStaticDependencyResources[3], 22, iStaticDependencyResources[0]); | |
| 3010 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 0, iStaticDependencyResources[3]); | |
| 3011 | GetExtendedResStateAndVerify(iStaticDependencyResources[5], 61, iStaticDependencyResources[3]); | |
| 3012 | ||
| 3013 | //Deregister client 4; | |
| 3014 | r = lddChan.DeRegisterClient(Clients[3].iClientId); | |
| 3015 | test(r == KErrNone); | |
| 3016 | ||
| 3017 | r = lddChan.CheckNotifications(iStaticDependencyResources[5], 0, 0); | |
| 3018 | test(r == KErrNone); | |
| 3019 | ||
| 3020 | GetExtendedResStateAndVerify(iStaticDependencyResources[0], 50, Clients[1].iClientId); | |
| 3021 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[1], -14, iStaticDependencyResources[0]); | |
| 3022 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[2], 1, Clients[1].iClientId); | |
| 3023 | GetExtendedResStateAndVerify(iStaticDependencyResources[3], 22, iStaticDependencyResources[0]); | |
| 3024 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 0, iStaticDependencyResources[3]); | |
| 3025 | GetExtendedResStateAndVerify(iStaticDependencyResources[5], 61, iStaticDependencyResources[3]); | |
| 3026 | ||
| 3027 | //Deregister client 3. | |
| 3028 | r = lddChan.DeRegisterClient(Clients[2].iClientId); | |
| 3029 | test(r == KErrNone); | |
| 3030 | ||
| 3031 | GetExtendedResStateAndVerify(iStaticDependencyResources[0], 50, Clients[1].iClientId); | |
| 3032 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[1], -14, iStaticDependencyResources[0]); | |
| 3033 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[2], 1, Clients[1].iClientId); | |
| 3034 | GetExtendedResStateAndVerify(iStaticDependencyResources[3], 22, iStaticDependencyResources[0]); | |
| 3035 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 0, iStaticDependencyResources[3]); | |
| 3036 | GetExtendedResStateAndVerify(iStaticDependencyResources[5], 61, iStaticDependencyResources[3]); | |
| 3037 | ||
| 3038 | //Deregister client 0 from Resource A | |
| 3039 | r = lddChan.DeRegisterClientLevelFromResource(Clients[0].iClientId, iStaticDependencyResources[1]); | |
| 3040 | test(r == KErrNone); | |
| 3041 | ||
| 3042 | r = lddChan.CheckNotifications(iStaticDependencyResources[1], 0, 0); | |
| 3043 | test(r == KErrNone); | |
| 3044 | ||
| 3045 | GetExtendedResStateAndVerify(iStaticDependencyResources[0], 50, Clients[1].iClientId); | |
| 3046 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[1], -14, iStaticDependencyResources[0]); | |
| 3047 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[2], 1, Clients[1].iClientId); | |
| 3048 | GetExtendedResStateAndVerify(iStaticDependencyResources[3], 22, iStaticDependencyResources[0]); | |
| 3049 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 0, iStaticDependencyResources[3]); | |
| 3050 | GetExtendedResStateAndVerify(iStaticDependencyResources[5], 61, iStaticDependencyResources[3]); | |
| 3051 | ||
| 3052 | //Move Resource D to default | |
| 3053 | r = lddChan.ChangeResourceStateSync(Clients[1].iClientId, iStaticDependencyResources[0], -100); | |
| 3054 | test(r == KErrPermissionDenied); | |
| 3055 | ||
| 3056 | //Deregister client 1 from Resource F | |
| 3057 | r = lddChan.DeRegisterClientLevelFromResource(Clients[1].iClientId, iStaticDependencyResources[2]); | |
| 3058 | test(r == KErrNone); | |
| 3059 | ||
| 3060 | r = lddChan.CheckNotifications(iStaticDependencyResources[1], 0, 0); | |
| 3061 | test(r == KErrNone); | |
| 3062 | ||
| 3063 | GetExtendedResStateAndVerify(iStaticDependencyResources[0], 50, Clients[1].iClientId); | |
| 3064 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[1], -14, iStaticDependencyResources[0]); | |
| 3065 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[2], 1, iStaticDependencyResources[0]); | |
| 3066 | GetExtendedResStateAndVerify(iStaticDependencyResources[3], 22, iStaticDependencyResources[0]); | |
| 3067 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 0, iStaticDependencyResources[3]); | |
| 3068 | GetExtendedResStateAndVerify(iStaticDependencyResources[5], 61, iStaticDependencyResources[3]); | |
| 3069 | ||
| 3070 | //Deregister client 2 | |
| 3071 | r = lddChan.DeRegisterClient(Clients[1].iClientId); | |
| 3072 | test(r == KErrNone); | |
| 3073 | ||
| 3074 | GetExtendedResStateAndVerify(iStaticDependencyResources[0], -100, -1); | |
| 3075 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[1], -10, iStaticDependencyResources[0]); | |
| 3076 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[2], 0, iStaticDependencyResources[0]); | |
| 3077 | GetExtendedResStateAndVerify(iStaticDependencyResources[3], 10, iStaticDependencyResources[0]); | |
| 3078 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 1, iStaticDependencyResources[3]); | |
| 3079 | GetExtendedResStateAndVerify(iStaticDependencyResources[5], 75, iStaticDependencyResources[3]); | |
| 3080 | //Deregister client 1 | |
| 3081 | r = lddChan.DeRegisterClient(Clients[0].iClientId); | |
| 3082 | test(r == KErrNone); | |
| 3083 | Clients.Close(); //Close the array and release memory | |
| 3084 | ||
| 3085 | //Test parallel execution of RC and Dependency resource DFC's | |
| 3086 | //Register client 1 | |
| 3087 | RmTest.RegisterClient(); | |
| 3088 | //Register client 2 | |
| 3089 | RmTest.RegisterClient(); | |
| 3090 | ||
| 3091 | state = 50; | |
| 3092 | /* CheckParallelExecutionForResChageStateWithDependency */ | |
| 3093 | lddChan.CheckParallelExecutionForChangeResState(Clients[1].iClientId, | |
| 3094 | iStaticDependencyResources[0],state,5,0,reqSet); | |
| 3095 | ||
| 3096 | User::WaitForRequest(reqSet); | |
| 3097 | test(reqSet.Int() == KErrNone); | |
| 3098 | ||
| 3099 | GetExtendedResStateAndVerify(iStaticDependencyResources[0], 50, Clients[1].iClientId); | |
| 3100 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[1], -11, iStaticDependencyResources[0]); | |
| 3101 | GetExtendedResStateAndVerify(iStaticDependencyResources[2], 1, iStaticDependencyResources[0]); | |
| 3102 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[3], 13, iStaticDependencyResources[0]); | |
| 3103 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 0, iStaticDependencyResources[3]); | |
| 3104 | GetExtendedResStateAndVerify(iStaticDependencyResources[5], 73, iStaticDependencyResources[3]); | |
| 3105 | ||
| 3106 | TInt owner; | |
| 3107 | TBool cached = ETrue; | |
| 3108 | r = lddChan.GetResourceStateSync(Clients[1].iClientId, 4, cached, state, owner); | |
| 3109 | test(r == KErrNone); | |
| 3110 | test(state == 75); | |
| 3111 | test(owner == -1); | |
| 3112 | ||
| 3113 | r = lddChan.DeRegisterClient(Clients[1].iClientId); | |
| 3114 | test(r == KErrNone); | |
| 3115 | ||
| 3116 | GetExtendedResStateAndVerify(iStaticDependencyResources[0], -100, -1); | |
| 3117 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[1], -10, iStaticDependencyResources[0]); | |
| 3118 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[2], 0, iStaticDependencyResources[0]); | |
| 3119 | GetExtendedResStateAndVerify(iStaticDependencyResources[3], 10, iStaticDependencyResources[0]); | |
| 3120 | GetExtendedResStateAsyncAndVerify(iStaticDependencyResources[4], 1, iStaticDependencyResources[3]); | |
| 3121 | GetExtendedResStateAndVerify(iStaticDependencyResources[5], 75, iStaticDependencyResources[3]); | |
| 3122 | ||
| 3123 | r = lddChan.GetResourceStateSync(Clients[0].iClientId, 4, cached, state, owner); | |
| 3124 | test(r == KErrNone); | |
| 3125 | test(state == 75); | |
| 3126 | test(owner == -1); | |
| 3127 | ||
| 3128 | r = lddChan.DeRegisterClient(Clients[0].iClientId); | |
| 3129 | test(r == KErrNone); | |
| 3130 | ||
| 3131 | Clients.Close(); //Close the array and release memory | |
| 3132 | depResArray.Close(); //Close the array and release memory | |
| 3133 | } | |
| 3134 | #endif | |
| 3135 | ||
| 3136 | //This function validates each of the resource manager API's | |
| 3137 | void TestRM::APIValidationTest() | |
| 3138 | 	{
 | |
| 3139 | 	test.Next(_L("\nStarting API validation Test...."));
 | |
| 3140 | RmTest.RegisterClient(); | |
| 3141 | r = lddChan.GetResourceControllerVersion(Clients[0].iClientId, iTestingExtendedVersion); | |
| 3142 | test(r == KErrNone); | |
| 3143 | if(!iTestingExtendedVersion) | |
| 3144 | 		test.Printf(_L("Testing Basic Version only...."));
 | |
| 3145 | else | |
| 3146 | 		test.Printf(_L("Testing basic & extended version...."));
 | |
| 3147 | RmTest.ValidateClient(5, EOwnerProcess); | |
| 3148 | iCurrentClientId = -1; | |
| 3149 | RmTest.GetNumResourcesInUseByClient(iCurrentClientId); | |
| 3150 | RmTest.GetInfoOnResourcesInUseByClient(iCurrentClientId, iMaxStaticResources); | |
| 3151 | iCurrentClientId = 0; | |
| 3152 | NegativeTesting = ETrue; | |
| 3153 | if(Resources[0].iName.Compare(*(const TDesC8*)&SpecialResName)) | |
| 3154 | 		{
 | |
| 3155 | 		test.Printf(_L("Test runs only on simulated PSL\n"));
 | |
| 3156 | RmTest.DeRegisterClient(Clients[0].iClientId); | |
| 3157 | return; | |
| 3158 | } | |
| 3159 |  	TBuf8<32> PowerController = _L8("PowerController");
 | |
| 3160 | r = lddChan.GetClientId(Clients[0].iClientId, (TDesC8&)PowerController, iPowerControllerId); | |
| 3161 | test(r == KErrNone); | |
| 4 
56f325a607ea
Revision: 200951
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
0diff
changeset | 3162 | |
| 
56f325a607ea
Revision: 200951
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
0diff
changeset | 3163 | RBuf8 info; | 
| 
56f325a607ea
Revision: 200951
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
0diff
changeset | 3164 | TUint c; | 
| 
56f325a607ea
Revision: 200951
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
0diff
changeset | 3165 | r = info.Create((iMaxStaticResources) * sizeof(SIdleResourceInfo)); | 
| 
56f325a607ea
Revision: 200951
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
0diff
changeset | 3166 | test(r == KErrNone); | 
| 
56f325a607ea
Revision: 200951
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
0diff
changeset | 3167 | SIdleResourceInfo* pI = (SIdleResourceInfo*)info.Ptr(); | 
| 
56f325a607ea
Revision: 200951
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
0diff
changeset | 3168 | for(c = 0; c < iMaxStaticResources; c++) | 
| 
56f325a607ea
Revision: 200951
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
0diff
changeset | 3169 | 		{
 | 
| 
56f325a607ea
Revision: 200951
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
0diff
changeset | 3170 | pI->iResourceId = Resources[c].iResourceId; | 
| 
56f325a607ea
Revision: 200951
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
0diff
changeset | 3171 | pI++; | 
| 
56f325a607ea
Revision: 200951
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
0diff
changeset | 3172 | } | 
| 
56f325a607ea
Revision: 200951
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
0diff
changeset | 3173 | pI = (SIdleResourceInfo*)info.Ptr(); | 
| 
56f325a607ea
Revision: 200951
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
0diff
changeset | 3174 | |
| 
56f325a607ea
Revision: 200951
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
0diff
changeset | 3175 | r = lddChan.RegisterForIdleResourcesInfo(iPowerControllerId, iMaxStaticResources, (TAny*)info.Ptr()); | 
| 
56f325a607ea
Revision: 200951
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
0diff
changeset | 3176 | |
| 0 | 3177 | test(r == KErrNone); | 
| 3178 | RmTest.GetClientName(iCurrentClientId); | |
| 3179 | RmTest.GetClientId(iCurrentClientId); | |
| 3180 | RmTest.GetResourceId(2); | |
| 3181 | RmTest.GetResourceInfo(19); | |
| 3182 | RmTest.GetNumResourcesInUseByClient(iCurrentClientId); | |
| 3183 | RmTest.GetInfoOnResourcesInUseByClient(iCurrentClientId, 3); | |
| 3184 | RmTest.GetNumClientsUsingResource(iCurrentClientId, (TUint)-1); | |
| 3185 | RmTest.GetNumClientsUsingResource(iCurrentClientId, 10); | |
| 3186 | RmTest.GetInfoOnClientsUsingResource((TUint)-1, 4); | |
| 3187 | RmTest.GetInfoOnClientsUsingResource(5, 3); | |
| 3188 | ||
| 3189 | for(c = 0; c < iMaxStaticResources; c++) | |
| 3190 | 		{
 | |
| 3191 | if(Resources[c].iSense == ECustom) | |
| 3192 | continue; | |
| 3193 | RmTest.GetResourceStateAsync(c, ETrue); | |
| 3194 | } | |
| 3195 | User::After(2000000); //Add delay to make sure that the asynchronous request is processed in controller thread | |
| 3196 | ||
| 3197 | for(c = 0; c < iMaxStaticResources; c++) | |
| 3198 | 		{
 | |
| 3199 | if(Resources[c].iSense == ECustom) | |
| 3200 | continue; | |
| 3201 | iCurrentClientId = c; | |
| 3202 | RmTest.RegisterClient(); | |
| 3203 | RmTest.AllocReserve(c); | |
| 3204 | RmTest.GetResourceStateAsync(c); | |
| 3205 | RmTest.RequestNotification(c); | |
| 3206 | RmTest.RequestNotificationCon(c); | |
| 3207 | } | |
| 3208 | ||
| 3209 | for(c=0; c< iMaxStaticResources; c++) | |
| 3210 | 		{
 | |
| 3211 | if(Resources[c].iSense == ECustom) | |
| 3212 | continue; | |
| 3213 | iCurrentClientId = c; | |
| 3214 | RmTest.ChangeResourceStateAsync(c); | |
| 3215 | RmTest.GetResourceStateAsync(c); | |
| 3216 | RmTest.GetResourceStateSync(c); | |
| 3217 | RmTest.ChangeResourceStateSync(c); | |
| 3218 | } | |
| 3219 | for(c = 0; c < iMaxStaticResources; c++) | |
| 3220 | 		{
 | |
| 3221 | if(Resources[c].iSense == ECustom) | |
| 3222 | continue; | |
| 3223 | iCurrentClientId = c; | |
| 3224 | RmTest.GetClientName(c); | |
| 3225 | RmTest.GetClientId(c); | |
| 3226 | RmTest.GetResourceId(c); | |
| 3227 | RmTest.GetResourceInfo(c); | |
| 3228 | RmTest.GetNumResourcesInUseByClient(c); | |
| 3229 | RmTest.GetInfoOnResourcesInUseByClient(c, Clients[c].iNumResources); | |
| 3230 | RmTest.GetNumClientsUsingResource(c, c); | |
| 3231 | RmTest.GetInfoOnClientsUsingResource(c, Resources[c].iNumClients); | |
| 3232 | RmTest.CancelNotification(c, ETrue); | |
| 3233 | RmTest.CancelNotification(c, EFalse); | |
| 3234 | } | |
| 3235 | ||
| 3236 | TInt clientCount = Clients.Count(); | |
| 3237 | for(c = clientCount-1; ((TInt)c) >=0; c--) | |
| 3238 | 	{ 
 | |
| 3239 | 		test.Printf(_L("DeRegister ClientId %d\n"), Clients[c].iClientId);
 | |
| 3240 | RmTest.DeRegisterClient(c); | |
| 3241 | } | |
| 3242 | Clients.Close(); | |
| 3243 | //Find any shared binary resource | |
| 3244 | for(c = 0; c < iMaxStaticResources; c++) | |
| 3245 | 		{
 | |
| 3246 | if(Resources[c].iSense == ECustom) | |
| 3247 | continue; | |
| 3248 | if((Resources[c].iUsage == EShared) && (Resources[c].iSense == ENegative)) | |
| 3249 | 			{
 | |
| 3250 | if(Resources[c].iType == 0x0) //Binary Resource | |
| 3251 | RmTest.SharedBinaryNegativeResourceTesting(c); | |
| 3252 | else | |
| 3253 | RmTest.SharedMultilevelNegativeResourceTesting(c); | |
| 3254 | } | |
| 3255 | else if((Resources[c].iUsage == EShared) && (Resources[c].iSense == EPositive)) | |
| 3256 | 			{
 | |
| 3257 | if(Resources[c].iType == 0x0) //Binary Resource | |
| 3258 | RmTest.SharedBinaryPositiveResourceTesting(c); | |
| 3259 | else | |
| 3260 | RmTest.SharedMultilevelPositiveResourceTesting(c); | |
| 3261 | } | |
| 3262 | } | |
| 3263 | ||
| 3264 | RmTest.CustomResourceTesting(CUSTOM_RESOURCE_NUMBER); | |
| 3265 | ||
| 3266 | //Testing of Deregistration of client level for binary resource | |
| 3267 | RmTest.RegisterClient(); | |
| 3268 | for(c = 0; c < iMaxStaticResources; c++) | |
| 3269 | 		{
 | |
| 3270 | if(Resources[c].iSense == ECustom) | |
| 3271 | continue; | |
| 3272 | RmTest.DeRegisterClientLevelFromResource(-1, c); | |
| 3273 | } | |
| 3274 | for(c = 0; c < iMaxStaticResources; c++) | |
| 3275 | 		{
 | |
| 3276 | iCurrentClientId = 0; | |
| 3277 | RmTest.ChangeResourceStateSync(c); | |
| 3278 | RmTest.DeRegisterClientLevelFromResource(0, c); | |
| 3279 | } | |
| 3280 | RmTest.RegisterClient(); | |
| 3281 | for(c = 0; c < iMaxStaticResources; c++) //Test valid only for shared resources. | |
| 3282 | 		{
 | |
| 3283 | if((Resources[c].iSense == ECustom) || (Resources[c].iUsage == ESingle)) | |
| 3284 | continue; | |
| 3285 | iCurrentClientId = 0; | |
| 3286 | RmTest.ChangeResourceStateSync(c); | |
| 3287 | iCurrentClientId = 1; | |
| 3288 | RmTest.ChangeResourceStateSync(c); | |
| 3289 | if(Resources[c].iCurrentClient == 0) | |
| 3290 | 			{
 | |
| 3291 | RmTest.DeRegisterClientLevelFromResource(0, c); | |
| 3292 | RmTest.DeRegisterClientLevelFromResource(1, c); | |
| 3293 | } | |
| 3294 | else | |
| 3295 | 			{
 | |
| 3296 | RmTest.DeRegisterClientLevelFromResource(1, c); | |
| 3297 | RmTest.DeRegisterClientLevelFromResource(0, c); | |
| 3298 | } | |
| 3299 | } | |
| 3300 | //Testing of Deregistration of client level for shared resource | |
| 3301 | for(c = 0; c < iMaxStaticResources; c++) | |
| 3302 | 		{
 | |
| 3303 | if((Resources[c].iSense == ECustom) || (!Resources[c].iUsage)) | |
| 3304 | continue; | |
| 3305 | RmTest.DeRegisterClientLevelFromResource(-1, c); | |
| 3306 | } | |
| 3307 | ||
| 3308 | RmTest.DeRegisterClient(1); | |
| 3309 | RmTest.DeRegisterClient(0); | |
| 3310 | info.Create(15 * sizeof(SIdleResourceInfo)); | |
| 3311 | r = lddChan.GetIdleResourcesInfo(15, (TAny*)(TDes8*)&info); | |
| 3312 | test(r == KErrNone); | |
| 4 
56f325a607ea
Revision: 200951
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
0diff
changeset | 3313 | pI = (SIdleResourceInfo*)info.Ptr(); | 
| 0 | 3314 | for(c = 0; c< 15; c++) | 
| 3315 | 	{
 | |
| 3316 | test(Resources[c].iCurrentClient == pI->iLevelOwnerId); | |
| 3317 | test(Resources[c].iCurrentLevel == pI->iCurrentLevel); | |
| 3318 | test(Resources[c].iResourceId == pI->iResourceId); | |
| 3319 | pI++; | |
| 3320 | } | |
| 3321 | info.Close(); | |
| 3322 | Clients.Close(); | |
| 3323 | #ifdef PRM_ENABLE_EXTENDED_VERSION | |
| 3324 | if(iTestingExtendedVersion) | |
| 3325 | 		{
 | |
| 3326 | TestStaticResourceWithDependency(); | |
| 3327 | TestDynamicResource(); | |
| 3328 | TestDynamicResourceDependency(); | |
| 3329 | } | |
| 3330 | #endif | |
| 3331 | Clients.Close(); | |
| 3332 | return; | |
| 3333 | } | |
| 3334 | ||
| 3335 | //---------------------------------------------------------------------------------------------- | |
| 3336 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0592 | |
| 3337 | //! @SYMTestType UT | |
| 3338 | //! @SYMPREQ PREQ1398 | |
| 3339 | //! @SYMTestCaseDesc This test case tests deregistration of client level functionality. | |
| 3340 | //! @SYMTestActions 0 Register client | |
| 3341 | //! 1 Change Resource State | |
| 3342 | //! 2 Deregister client level | |
| 3343 | //! 3 Deregister client | |
| 3344 | //! | |
| 3345 | //! @SYMTestExpectedResults 0 API should return with KErrNone, panics otherwise. | |
| 3346 | //! 1 API should return with KErrNone, panics otherwise. | |
| 3347 | //! 2 API should return with KErrNone, panics otherwise. | |
| 3348 | //! 3 API should return with KErrNone, panics otherwise. | |
| 3349 | //! @SYMTestPriority High | |
| 3350 | //! @SYMTestStatus Implemented | |
| 3351 | //---------------------------------------------------------------------------------------------- | |
| 3352 | void TestRM::DeRegisterClientLevelFromResource(TInt aClientId, TUint aResId) | |
| 3353 | 	{
 | |
| 3354 | TInt state; | |
| 3355 | TInt newState; | |
| 3356 | TInt levelOwnerId; | |
| 3357 | r = lddChan.GetResourceStateSync(Clients[0].iClientId, Resources[aResId].iResourceId, ETrue, newState, levelOwnerId); | |
| 3358 | test(r == KErrNone); | |
| 3359 | if((levelOwnerId != -1) && (levelOwnerId != (TInt)Clients[aClientId].iClientId)) | |
| 3360 | 		{
 | |
| 3361 | 		test.Printf(_L("Client Id does not match so not testing Deregistration of client level\n"));
 | |
| 3362 | return; | |
| 3363 | } | |
| 3364 | if(Resources[aResId].iUsage == ESingle) //Single user resource | |
| 3365 | 		{
 | |
| 3366 | if(levelOwnerId == -1) | |
| 3367 | 			{
 | |
| 3368 | TUint ClientId; | |
| 3369 | 			ClientName[6] = (TUint8)('0' + iMaxClientId+1);
 | |
| 3370 | r = lddChan.RegisterClient(ClientId, (const TDesC*)&ClientName); | |
| 3371 | test(r == KErrNone); | |
| 3372 | newState = Resources[aResId].iMaxLevel; | |
| 3373 | r = lddChan.ChangeResourceStateSync(ClientId, Resources[aResId].iResourceId, newState); | |
| 3374 | test(r == KErrNone); | |
| 3375 | r = lddChan.GetResourceStateSync(ClientId, Resources[aResId].iResourceId, ETrue, state, levelOwnerId); | |
| 3376 | test(r == KErrNone); | |
| 3377 | test(state == newState); | |
| 3378 | test(levelOwnerId == (TInt)ClientId); | |
| 3379 | r = lddChan.DeRegisterClientLevelFromResource(ClientId, Resources[aResId].iResourceId); | |
| 3380 | test(r == KErrNone); | |
| 3381 | r = lddChan.GetResourceStateSync(ClientId, Resources[aResId].iResourceId, ETrue, state, levelOwnerId); | |
| 3382 | test(r == KErrNone); | |
| 3383 | test(levelOwnerId == -1); | |
| 3384 | r = lddChan.DeRegisterClient(ClientId); | |
| 3385 | test(r == KErrNone); | |
| 3386 | return; | |
| 3387 | } | |
| 3388 | r = lddChan.DeRegisterClientLevelFromResource(Clients[aClientId].iClientId, Resources[aResId].iResourceId); | |
| 3389 | test(r == KErrNone); | |
| 3390 | r = lddChan.GetResourceStateSync(Clients[aClientId].iClientId, Resources[aResId].iResourceId, ETrue, state, levelOwnerId); | |
| 3391 | test(r == KErrNone); | |
| 3392 | test(levelOwnerId == -1); | |
| 3393 | //Update the local | |
| 3394 | Resources[aResId].iCurrentClient = -1; | |
| 3395 | Resources[aResId].iCurrentLevel = state; | |
| 3396 | Resources[aResId].iNumClients = 0; | |
| 3397 | delete Resources[aResId].iLevel; | |
| 3398 | Resources[aResId].iLevel = NULL; | |
| 3399 | return; | |
| 3400 | } | |
| 3401 | //Handle for Shared resources | |
| 3402 | if(levelOwnerId == -1) | |
| 3403 | 		{
 | |
| 3404 | TUint ClientId[2]; | |
| 3405 | 		ClientName[6] = (TUint8)('0' + iMaxClientId+1);
 | |
| 3406 | r = lddChan.RegisterClient(ClientId[0], (const TDesC*)&ClientName); | |
| 3407 | test(r == KErrNone); | |
| 3408 | 		ClientName[6] = (TUint8)('0' + iMaxClientId+2);
 | |
| 3409 | r = lddChan.RegisterClient(ClientId[1], (const TDesC*)&ClientName); | |
| 3410 | test(r == KErrNone); | |
| 3411 | newState = Resources[aResId].iMinLevel; | |
| 3412 | r = lddChan.ChangeResourceStateSync(ClientId[0], Resources[aResId].iResourceId, newState); | |
| 3413 | test(r == KErrNone); | |
| 3414 | r = lddChan.GetResourceStateSync(ClientId[0], Resources[aResId].iResourceId, ETrue, state, levelOwnerId); | |
| 3415 | test(r == KErrNone); | |
| 3416 | test(levelOwnerId == (TInt)ClientId[0]); | |
| 3417 | r = lddChan.ChangeResourceStateSync(ClientId[1], Resources[aResId].iResourceId, newState); | |
| 3418 | test(r == KErrNone); | |
| 3419 | r = lddChan.DeRegisterClientLevelFromResource(ClientId[0], Resources[aResId].iResourceId); | |
| 3420 | test(r == KErrNone); | |
| 3421 | r = lddChan.GetResourceStateSync(ClientId[0], Resources[aResId].iResourceId, ETrue, state, levelOwnerId); | |
| 3422 | test(r == KErrNone); | |
| 3423 | test(levelOwnerId == (TInt)ClientId[1]); | |
| 3424 | r = lddChan.DeRegisterClientLevelFromResource(ClientId[1], Resources[aResId].iResourceId); | |
| 3425 | test(r == KErrNone); | |
| 3426 | r = lddChan.GetResourceStateSync(ClientId[0], Resources[aResId].iResourceId, ETrue, state, levelOwnerId); | |
| 3427 | test(r == KErrNone); | |
| 3428 | test(levelOwnerId == -1); | |
| 3429 | r = lddChan.DeRegisterClient(ClientId[0]); | |
| 3430 | test(r == KErrNone); | |
| 3431 | r = lddChan.DeRegisterClient(ClientId[1]); | |
| 3432 | test(r == KErrNone); | |
| 3433 | return; | |
| 3434 | } | |
| 3435 | r = lddChan.DeRegisterClientLevelFromResource(Clients[aClientId].iClientId, Resources[aResId].iResourceId); | |
| 3436 | test(r == KErrNone); | |
| 3437 | r = lddChan.GetResourceStateSync(Clients[aClientId].iClientId, Resources[aResId].iResourceId, ETrue, state, levelOwnerId); | |
| 3438 | test(r == KErrNone); | |
| 3439 | test(levelOwnerId != (TInt)Clients[aClientId].iClientId); | |
| 3440 | if(Resources[aResId].iNumClients == 1) | |
| 3441 | 		{
 | |
| 3442 | Resources[aResId].iNumClients--; | |
| 3443 | Resources[aResId].iCurrentClient = -1; | |
| 3444 | r = lddChan.GetResourceStateSync(Clients[aClientId].iClientId, Resources[aResId].iResourceId, ETrue, state, levelOwnerId); | |
| 3445 | test(r == KErrNone); | |
| 3446 | Resources[aResId].iCurrentLevel = state; | |
| 3447 | delete Resources[aResId].iLevel; | |
| 3448 | Resources[aResId].iLevel = NULL; | |
| 3449 | } | |
| 3450 | else | |
| 3451 | 		{
 | |
| 3452 | Resources[aResId].iNumClients--; | |
| 3453 | SPowerResourceClientLevel *pCL = NULL; | |
| 3454 | TInt level = KMinTInt; | |
| 3455 | TInt clientId = 0; | |
| 3456 | for(SPowerResourceClientLevel* pL = Resources[aResId].iLevel; pL != NULL; pL = pL->iNextInList) | |
| 3457 | 			{
 | |
| 3458 | if(pL->iClientId == Clients[aClientId].iClientId) | |
| 3459 | 				{
 | |
| 3460 | pCL = pL; | |
| 3461 | continue; | |
| 3462 | } | |
| 3463 | if(level == KMinTInt) | |
| 3464 | 				{
 | |
| 3465 | level = pL->iLevel; | |
| 3466 | clientId = pL->iClientId; | |
| 3467 | continue; | |
| 3468 | } | |
| 3469 | if(((Resources[aResId].iSense == EPositive) && (pL->iLevel > level)) || ((Resources[aResId].iSense == ENegative) && (pL->iLevel < level))) | |
| 3470 | 				{
 | |
| 3471 | level = pL->iLevel; | |
| 3472 | clientId = pL->iClientId; | |
| 3473 | } | |
| 3474 | } | |
| 3475 | delete pCL; | |
| 3476 | Resources[aResId].iCurrentClient = clientId; | |
| 3477 | Resources[aResId].iCurrentLevel = level; | |
| 3478 | } | |
| 3479 | return; | |
| 3480 | } | |
| 3481 | ||
| 3482 | //---------------------------------------------------------------------------------------------- | |
| 3483 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0593 | |
| 3484 | //! @SYMTestType UT | |
| 3485 | //! @SYMPREQ PREQ1398 | |
| 3486 | //! @SYMTestCaseDesc This test case tests changing resource state of shared positive resource. | |
| 3487 | //! @SYMTestActions 0 Register client1 | |
| 3488 | //! 1 Register client2 | |
| 3489 | //! 2 Register client3 | |
| 3490 | //! 3 Register client4 | |
| 3491 | //! 4 Client1 change resource state. | |
| 3492 | //! 5 Client2 change resource state. | |
| 3493 | //! 6 Client3 change resource state. | |
| 3494 | //! 7 Client4 change resource state. | |
| 3495 | //! 8 Client1 change resource state. | |
| 3496 | //! 9 Client2 change resource state. | |
| 3497 | //! 10 Deregister client2 | |
| 3498 | //! 11 Client3 change resource state. | |
| 3499 | //! 12 Deregister client1 | |
| 3500 | //! 13 Deregister client3 | |
| 3501 | //! 14 Deregister client4 | |
| 3502 | //! | |
| 3503 | //! @SYMTestExpectedResults 0 Client registered | |
| 3504 | //! 1 Client registered | |
| 3505 | //! 2 Client registered | |
| 3506 | //! 3 Client registered | |
| 3507 | //! 4 Resource state changed | |
| 3508 | //! 5 Resource state changed | |
| 3509 | //! 6 Resource state changed | |
| 3510 | //! 7 Resource state changed | |
| 3511 | //! 8 Resource state changed | |
| 3512 | //! 9 Resource state changed | |
| 3513 | //! 10 Client2 deregistered | |
| 3514 | //! 11 Resource state changed | |
| 3515 | //! 12 Client1 deregistered | |
| 3516 | //! 13 Client3 deregistered | |
| 3517 | //! 14 Client4 deregistered | |
| 3518 | //! @SYMTestPriority High | |
| 3519 | //! @SYMTestStatus Implemented | |
| 3520 | //---------------------------------------------------------------------------------------------- | |
| 3521 | void TestRM::SharedBinaryPositiveResourceTesting(TUint aResId) | |
| 3522 | 	{
 | |
| 3523 | TInt newState, levelOwnerId; | |
| 3524 | TRequestStatus req; | |
| 3525 | TUint ClientId[5]; | |
| 3526 | ||
| 3527 | 	ClientName[6] = (TUint8)('0' + iMaxClientId+1);
 | |
| 3528 | r = lddChan.RegisterClient(ClientId[0], (const TDesC*)&ClientName); | |
| 3529 | test(r == KErrNone); | |
| 3530 | ||
| 3531 | r = lddChan.GetResourceStateSync(ClientId[0], Resources[aResId].iResourceId, ETrue, newState, levelOwnerId); | |
| 3532 | test(r == KErrNone); | |
| 3533 | if(levelOwnerId != -1) | |
| 3534 | 		{
 | |
| 3535 | 		test.Printf(_L("Not testing the shared resource as some other client is currently holding the resource\n"));
 | |
| 3536 | r = lddChan.DeRegisterClient(ClientId[0]); | |
| 3537 | test(r == KErrNone); | |
| 3538 | return; | |
| 3539 | } | |
| 3540 | ||
| 3541 | 	ClientName[6] = (TUint8)('0' + iMaxClientId +2);
 | |
| 3542 | r = lddChan.RegisterClient(ClientId[1], (const TDesC*)&ClientName); | |
| 3543 | test(r == KErrNone); | |
| 3544 | 	ClientName[6] = (TUint8)('0' + iMaxClientId +3);
 | |
| 3545 | r = lddChan.RegisterClient(ClientId[2], (const TDesC*)&ClientName); | |
| 3546 | test(r == KErrNone); | |
| 3547 | 	ClientName[6] = (TUint8)('0' + iMaxClientId +4);
 | |
| 3548 | r = lddChan.RegisterClient(ClientId[3], (const TDesC*)&ClientName); | |
| 3549 | test(r == KErrNone); | |
| 3550 | 	ClientName[6] = (TUint8)('0' + iMaxClientId +5);
 | |
| 3551 | r = lddChan.RegisterClient(ClientId[4], (const TDesC*)&ClientName); | |
| 3552 | test(r == KErrNone); | |
| 3553 | ||
| 3554 | newState = 1; | |
| 3555 | r = lddChan.ChangeResourceStateSync(ClientId[0], Resources[aResId].iResourceId, newState); | |
| 3556 | test(r == KErrNone); | |
| 3557 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 0, 0); | |
| 3558 | test(r == KErrNone); | |
| 3559 | r = lddChan.RequestNotification(ClientId[1], Resources[aResId].iResourceId); | |
| 3560 | test(r == KErrNone); | |
| 3561 | r = lddChan.RequestNotification(ClientId[2], Resources[aResId].iResourceId); | |
| 3562 | test(r == KErrNone); | |
| 3563 | r = lddChan.RequestNotification(ClientId[3], Resources[aResId].iResourceId, 1, ETrue); | |
| 3564 | test(r == KErrNone); | |
| 3565 | r = lddChan.RequestNotification(ClientId[2], Resources[aResId].iResourceId, 0, EFalse); | |
| 3566 | test(r == KErrNone); | |
| 3567 | newState = !newState; //State 0 | |
| 3568 | r = lddChan.ChangeResourceStateSync(ClientId[0], Resources[aResId].iResourceId, newState); | |
| 3569 | test(r == KErrNone); | |
| 3570 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 2, 1); | |
| 3571 | test(r == KErrNone); | |
| 3572 | newState = !newState; //State 1 | |
| 3573 | r = lddChan.ChangeResourceStateSync(ClientId[1], Resources[aResId].iResourceId, newState); | |
| 3574 | test(r == KErrNone); | |
| 3575 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 2, 1); | |
| 3576 | test(r == KErrNone); | |
| 3577 | lddChan.ChangeResourceStateAsync(ClientId[2], Resources[aResId].iResourceId, newState, req); | |
| 3578 | User::WaitForRequest(req); //State 1 | |
| 3579 | test(req.Int() == KErrNone); | |
| 3580 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 0, 0); | |
| 3581 | test(r == KErrNone); | |
| 3582 | newState = !newState; //State 0 | |
| 3583 | r = lddChan.ChangeResourceStateSync(ClientId[3], Resources[aResId].iResourceId, newState); | |
| 3584 | test(r == KErrNone); | |
| 3585 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 0, 0); | |
| 3586 | test(r == KErrNone); | |
| 3587 | newState = !newState; //state 1 | |
| 3588 | r = lddChan.ChangeResourceStateSync(ClientId[0], Resources[aResId].iResourceId, newState); | |
| 3589 | test(r == KErrNone); | |
| 3590 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 0, 0); | |
| 3591 | newState = !newState; //state 0 | |
| 3592 | r = lddChan.ChangeResourceStateSync(ClientId[1], Resources[aResId].iResourceId, newState); | |
| 3593 | test(r == KErrNone); | |
| 3594 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 0,0); | |
| 3595 | test(r == KErrNone); | |
| 3596 | r = lddChan.DeRegisterClient(ClientId[1]); | |
| 3597 | test(r == KErrNone); | |
| 3598 | newState = 0; | |
| 3599 | r = lddChan.ChangeResourceStateSync(ClientId[2], Resources[aResId].iResourceId, newState); | |
| 3600 | test(r == KErrNone); | |
| 3601 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 0,0); | |
| 3602 | test(r == KErrNone); | |
| 3603 | r = lddChan.ChangeResourceStateSync(ClientId[0], Resources[aResId].iResourceId, newState); | |
| 3604 | test(r == KErrNone); | |
| 3605 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 1,1); | |
| 3606 | test(r == KErrNone); | |
| 3607 | r = lddChan.CancelNotification(ClientId[2], Resources[aResId].iResourceId, EFalse); | |
| 3608 | test(r == KErrCancel); | |
| 3609 | r = lddChan.CancelNotification(ClientId[3], Resources[aResId].iResourceId, ETrue); | |
| 3610 | test(r == KErrCancel); | |
| 3611 | newState = 1; | |
| 3612 | r = lddChan.ChangeResourceStateSync(ClientId[0], Resources[aResId].iResourceId, newState); | |
| 3613 | test(r == KErrNone); | |
| 3614 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 0, 0); | |
| 3615 | test(r == KErrNone); | |
| 3616 | r = lddChan.CancelNotification(ClientId[2], Resources[aResId].iResourceId, ETrue); | |
| 3617 | test(r == KErrCancel); | |
| 3618 | newState = 1; | |
| 3619 | r = lddChan.ChangeResourceStateSync(ClientId[0], Resources[aResId].iResourceId, newState); | |
| 3620 | test(r == KErrNone); | |
| 3621 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 0, 0); | |
| 3622 | test(r == KErrNone); | |
| 3623 | r = lddChan.DeRegisterClient(ClientId[0]); | |
| 3624 | test(r == KErrNone); | |
| 3625 | r = lddChan.DeRegisterClient(ClientId[2]); | |
| 3626 | test(r == KErrNone); | |
| 3627 | r = lddChan.DeRegisterClient(ClientId[3]); | |
| 3628 | test(r == KErrNone); | |
| 3629 | r = lddChan.GetResourceStateSync(ClientId[4], Resources[aResId].iResourceId, ETrue, newState, levelOwnerId); | |
| 3630 | test(r == KErrNone); | |
| 3631 | test(levelOwnerId == -1); | |
| 3632 | r = lddChan.DeRegisterClient(ClientId[4]); | |
| 3633 | test(r == KErrNone); | |
| 3634 | return; | |
| 3635 | } | |
| 3636 | ||
| 3637 | //---------------------------------------------------------------------------------------------- | |
| 3638 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0594 | |
| 3639 | //! @SYMTestType UT | |
| 3640 | //! @SYMPREQ PREQ1398 | |
| 3641 | //! @SYMTestCaseDesc This test case tests changing resource state of shared negative resource. | |
| 3642 | //! @SYMTestActions 0 Register client1 | |
| 3643 | //! 1 Register client2 | |
| 3644 | //! 2 Register client3 | |
| 3645 | //! 3 Register client4 | |
| 3646 | //! 4 Client1 change resource state. | |
| 3647 | //! 5 Client2 change resource state. | |
| 3648 | //! 6 Client3 change resource state. | |
| 3649 | //! 7 Client4 change resource state. | |
| 3650 | //! 8 Client1 change resource state. | |
| 3651 | //! 9 Client2 change resource state. | |
| 3652 | //! 10 Deregister client2 | |
| 3653 | //! 11 Client3 change resource state. | |
| 3654 | //! 12 Deregister client1 | |
| 3655 | //! 13 Deregister client3 | |
| 3656 | //! 14 Deregister client4 | |
| 3657 | //! | |
| 3658 | //! @SYMTestExpectedResults 0 Client registered | |
| 3659 | //! 1 Client registered | |
| 3660 | //! 2 Client registered | |
| 3661 | //! 3 Client registered | |
| 3662 | //! 4 Resource state changed | |
| 3663 | //! 5 Resource state changed | |
| 3664 | //! 6 Resource state changed | |
| 3665 | //! 7 Resource state changed | |
| 3666 | //! 8 Resource state changed | |
| 3667 | //! 9 Resource state changed | |
| 3668 | //! 10 Client2 deregistered | |
| 3669 | //! 11 Resource state changed | |
| 3670 | //! 12 Client1 deregistered | |
| 3671 | //! 13 Client3 deregistered | |
| 3672 | //! 14 Client4 deregistered | |
| 3673 | //! @SYMTestPriority High | |
| 3674 | //! @SYMTestStatus Implemented | |
| 3675 | //---------------------------------------------------------------------------------------------- | |
| 3676 | void TestRM::SharedBinaryNegativeResourceTesting(TUint aResId) | |
| 3677 | 	{
 | |
| 3678 | TInt newState; | |
| 3679 | TInt levelOwnerId; | |
| 3680 | TRequestStatus req; | |
| 3681 | TUint ClientId[5]; | |
| 3682 | ||
| 3683 | 	ClientName[6] = (TUint8)('0' + iMaxClientId+1);
 | |
| 3684 | r = lddChan.RegisterClient(ClientId[0], (const TDesC*)&ClientName); | |
| 3685 | test(r == KErrNone); | |
| 3686 | ||
| 3687 | r = lddChan.GetResourceStateSync(ClientId[0], Resources[aResId].iResourceId, ETrue, newState, levelOwnerId); | |
| 3688 | test(r == KErrNone); | |
| 3689 | if(levelOwnerId != -1) | |
| 3690 | 		{
 | |
| 3691 | 		test.Printf(_L("Not testing the shared resource as some other client is currently holding the resource\n"));
 | |
| 3692 | r = lddChan.DeRegisterClient(ClientId[0]); | |
| 3693 | test(r == KErrNone); | |
| 3694 | return; | |
| 3695 | } | |
| 3696 | ||
| 3697 | 	ClientName[6] = (TUint8)('0' + iMaxClientId +2);
 | |
| 3698 | r = lddChan.RegisterClient(ClientId[1], (const TDesC*)&ClientName); | |
| 3699 | test(r == KErrNone); | |
| 3700 | 	ClientName[6] = (TUint8)('0' + iMaxClientId +3);
 | |
| 3701 | r = lddChan.RegisterClient(ClientId[2], (const TDesC*)&ClientName); | |
| 3702 | test(r == KErrNone); | |
| 3703 | 	ClientName[6] = (TUint8)('0' + iMaxClientId +4);
 | |
| 3704 | r = lddChan.RegisterClient(ClientId[3], (const TDesC*)&ClientName); | |
| 3705 | test(r == KErrNone); | |
| 3706 | 	ClientName[6] = (TUint8)('0' + iMaxClientId +5);
 | |
| 3707 | r = lddChan.RegisterClient(ClientId[4], (const TDesC*)&ClientName); | |
| 3708 | test(r == KErrNone); | |
| 3709 | ||
| 3710 | newState = 0; | |
| 3711 | r = lddChan.ChangeResourceStateSync(ClientId[0], Resources[aResId].iResourceId, newState); | |
| 3712 | test(r == KErrNone); | |
| 3713 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 0, 0); | |
| 3714 | test(r == KErrNone); | |
| 3715 | r = lddChan.RequestNotification(ClientId[1], Resources[aResId].iResourceId); | |
| 3716 | test(r == KErrNone); | |
| 3717 | r = lddChan.RequestNotification(ClientId[2], Resources[aResId].iResourceId); | |
| 3718 | test(r == KErrNone); | |
| 3719 | r = lddChan.RequestNotification(ClientId[3], Resources[aResId].iResourceId, 1, ETrue); | |
| 3720 | test(r == KErrNone); | |
| 3721 | r = lddChan.RequestNotification(ClientId[2], Resources[aResId].iResourceId, 0, EFalse); | |
| 3722 | test(r == KErrNone); | |
| 3723 | newState = !newState; //State 1 | |
| 3724 | r = lddChan.ChangeResourceStateSync(ClientId[0], Resources[aResId].iResourceId, newState); | |
| 3725 | test(r == KErrNone); | |
| 3726 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 2, 1); | |
| 3727 | test(r == KErrNone); | |
| 3728 | newState = !newState; //State 0 | |
| 3729 | r = lddChan.ChangeResourceStateSync(ClientId[1], Resources[aResId].iResourceId, newState); | |
| 3730 | test(r == KErrNone); | |
| 3731 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 2, 1); | |
| 3732 | test(r == KErrNone); | |
| 3733 | lddChan.ChangeResourceStateAsync(ClientId[2], Resources[aResId].iResourceId, newState, req); | |
| 3734 | User::WaitForRequest(req); //State 0 | |
| 3735 | test(req.Int() == KErrNone); | |
| 3736 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 0, 0); | |
| 3737 | test(r == KErrNone); | |
| 3738 | newState = !newState; //State 1 | |
| 3739 | r = lddChan.ChangeResourceStateSync(ClientId[3], Resources[aResId].iResourceId, newState); | |
| 3740 | test(r == KErrNone); | |
| 3741 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 0, 0); | |
| 3742 | test(r == KErrNone); | |
| 3743 | newState = !newState; //state 0 | |
| 3744 | r = lddChan.ChangeResourceStateSync(ClientId[0], Resources[aResId].iResourceId, newState); | |
| 3745 | test(r == KErrNone); | |
| 3746 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 0, 0); | |
| 3747 | newState = !newState; //state 1 | |
| 3748 | r = lddChan.ChangeResourceStateSync(ClientId[1], Resources[aResId].iResourceId, newState); | |
| 3749 | test(r == KErrNone); | |
| 3750 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 0,0); | |
| 3751 | test(r == KErrNone); | |
| 3752 | r = lddChan.DeRegisterClient(ClientId[1]); | |
| 3753 | test(r == KErrNone); | |
| 3754 | newState = 1; | |
| 3755 | r = lddChan.ChangeResourceStateSync(ClientId[2], Resources[aResId].iResourceId, newState); | |
| 3756 | test(r == KErrNone); | |
| 3757 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 0,0); | |
| 3758 | test(r == KErrNone); | |
| 3759 | r = lddChan.ChangeResourceStateSync(ClientId[0], Resources[aResId].iResourceId, newState); | |
| 3760 | test(r == KErrNone); | |
| 3761 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 1,1); | |
| 3762 | test(r == KErrNone); | |
| 3763 | r = lddChan.CancelNotification(ClientId[2], Resources[aResId].iResourceId, EFalse); | |
| 3764 | test(r == KErrCancel); | |
| 3765 | r = lddChan.CancelNotification(ClientId[3], Resources[aResId].iResourceId, ETrue); | |
| 3766 | test(r == KErrCancel); | |
| 3767 | newState = 1; | |
| 3768 | r = lddChan.ChangeResourceStateSync(ClientId[0], Resources[aResId].iResourceId, newState); | |
| 3769 | test(r == KErrNone); | |
| 3770 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 0, 0); | |
| 3771 | test(r == KErrNone); | |
| 3772 | r = lddChan.CancelNotification(ClientId[2], Resources[aResId].iResourceId, ETrue); | |
| 3773 | test(r == KErrCancel); | |
| 3774 | newState = 1; | |
| 3775 | r = lddChan.ChangeResourceStateSync(ClientId[0], Resources[aResId].iResourceId, newState); | |
| 3776 | test(r == KErrNone); | |
| 3777 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 0, 0); | |
| 3778 | test(r == KErrNone); | |
| 3779 | r = lddChan.DeRegisterClient(ClientId[0]); | |
| 3780 | test(r == KErrNone); | |
| 3781 | r = lddChan.DeRegisterClient(ClientId[2]); | |
| 3782 | test(r == KErrNone); | |
| 3783 | r = lddChan.DeRegisterClient(ClientId[3]); | |
| 3784 | test(r == KErrNone); | |
| 3785 | r = lddChan.GetResourceStateSync(ClientId[4], Resources[aResId].iResourceId, ETrue, newState, levelOwnerId); | |
| 3786 | test(r == KErrNone); | |
| 3787 | test(levelOwnerId == -1); | |
| 3788 | r = lddChan.DeRegisterClient(ClientId[4]); | |
| 3789 | test(r == KErrNone); | |
| 3790 | return; | |
| 3791 | } | |
| 3792 | ||
| 3793 | //Test cases to test the shared multilevel negative resources | |
| 3794 | void TestRM::SharedMultilevelNegativeResourceTesting(TUint aResId) | |
| 3795 | 	{
 | |
| 3796 | TInt newState; | |
| 3797 | TInt levelOwnerId; | |
| 3798 | TRequestStatus req; | |
| 3799 | TUint ClientId[2]; | |
| 3800 | ||
| 3801 | //Register 1st client | |
| 3802 | 	ClientName[6] = (TUint8)('0' + iMaxClientId+1);
 | |
| 3803 | r = lddChan.RegisterClient(ClientId[0], (const TDesC*)&ClientName); | |
| 3804 | test(r == KErrNone); | |
| 3805 | ||
| 3806 | r = lddChan.GetResourceStateSync(ClientId[0], Resources[aResId].iResourceId, ETrue, newState, levelOwnerId); | |
| 3807 | test(r == KErrNone); | |
| 3808 | if(levelOwnerId != -1) | |
| 3809 | 		{
 | |
| 3810 | 		test.Printf(_L("Not testing the shared resource as some other client is currently holding the resource\n"));
 | |
| 3811 | r = lddChan.DeRegisterClient(ClientId[0]); | |
| 3812 | test(r == KErrNone); | |
| 3813 | return; | |
| 3814 | } | |
| 3815 | ||
| 3816 | 	test.Printf(_L("Testing %d Shared Multilevel Negative Resource\n"), Resources[aResId].iResourceId);
 | |
| 3817 | ||
| 3818 | //Register 2nd client | |
| 3819 | 	ClientName[6] = (TUint8)('0' + iMaxClientId+2);
 | |
| 3820 | r = lddChan.RegisterClient(ClientId[1], (const TDesC*)&ClientName); | |
| 3821 | test(r == KErrNone); | |
| 3822 | ||
| 3823 | //Change the resource and ClientId[0] becomes the owner of the resource | |
| 3824 | newState = Resources[aResId].iMaxLevel + 10; | |
| 3825 | ||
| 3826 | r = lddChan.ChangeResourceStateSync(ClientId[0], Resources[aResId].iResourceId, newState); | |
| 3827 | test(r == KErrNone); | |
| 3828 | ||
| 3829 | TInt state; | |
| 3830 | r = lddChan.GetResourceStateSync(ClientId[0], Resources[aResId].iResourceId, ETrue, state, levelOwnerId); | |
| 3831 | test(r == KErrNone); | |
| 3832 | test(state == newState); | |
| 3833 | test(levelOwnerId = (TInt)ClientId[0]); | |
| 3834 | ||
| 3835 | //Second client(clientId[1]) trying to change the resource, but still | |
| 3836 | newState = state +5; | |
| 3837 | lddChan.ChangeResourceStateAsync(ClientId[1], Resources[aResId].iResourceId, newState, req); | |
| 3838 | User::WaitForRequest(req); | |
| 3839 | test(req.Int() == KErrNone); | |
| 3840 | ||
| 3841 | lddChan.GetResourceStateAsync(ClientId[0], Resources[aResId].iResourceId, EFalse, req, newState, levelOwnerId); | |
| 3842 | User::WaitForRequest(req); | |
| 3843 | test(req.Int() == KErrNone); | |
| 3844 | test(state = newState); | |
| 3845 | test(levelOwnerId == (TInt)ClientId[0]); | |
| 3846 | ||
| 3847 | newState = state + 10; | |
| 3848 | r = lddChan.ChangeResourceStateSync(ClientId[0], Resources[aResId].iResourceId, newState); | |
| 3849 | test(r == KErrNone); | |
| 3850 | ||
| 3851 | r = lddChan.GetResourceStateSync(ClientId[0], Resources[aResId].iResourceId, EFalse, state, levelOwnerId); | |
| 3852 | test(r == KErrNone); | |
| 3853 | newState = Resources[aResId].iMaxLevel + 15; | |
| 3854 | test(state == newState); | |
| 3855 | test(levelOwnerId == (TInt)ClientId[1]); | |
| 3856 | ||
| 3857 | r = lddChan.DeRegisterClientLevelFromResource(ClientId[1], Resources[aResId].iResourceId); | |
| 3858 | test(r == KErrNone); | |
| 3859 | ||
| 3860 | state = Resources[aResId].iMaxLevel + 20; | |
| 3861 | lddChan.GetResourceStateAsync(ClientId[1], Resources[aResId].iResourceId, ETrue, req, newState, levelOwnerId); | |
| 3862 | User::WaitForRequest(req); | |
| 3863 | test(req.Int() == KErrNone); | |
| 3864 | test(state == newState); | |
| 3865 | test(levelOwnerId == (TInt)ClientId[0]); | |
| 3866 | ||
| 3867 | newState = Resources[aResId].iMaxLevel + 10; | |
| 3868 | lddChan.ChangeResourceStateAsync(ClientId[1], Resources[aResId].iResourceId, newState, req); | |
| 3869 | User::WaitForRequest(req); | |
| 3870 | test(req.Int() == KErrNone); | |
| 3871 | ||
| 3872 | ||
| 3873 | lddChan.GetResourceStateAsync(ClientId[0], Resources[aResId].iResourceId, EFalse, req, state, levelOwnerId); | |
| 3874 | User::WaitForRequest(req); | |
| 3875 | test(req.Int() == KErrNone); | |
| 3876 | test(state == newState); | |
| 3877 | test(levelOwnerId == (TInt)ClientId[1]); | |
| 3878 | ||
| 3879 | r = lddChan.DeRegisterClient(ClientId[1]); | |
| 3880 | test(r == KErrNone); | |
| 3881 | ||
| 3882 | r = lddChan.DeRegisterClientLevelFromResource(ClientId[0], Resources[aResId].iResourceId); | |
| 3883 | test(r == KErrNone); | |
| 3884 | ||
| 3885 | r = lddChan.GetResourceStateSync(ClientId[0], Resources[aResId].iResourceId, EFalse, state, levelOwnerId); | |
| 3886 | test(r == KErrNone); | |
| 3887 | test(state == Resources[aResId].iDefaultLevel); | |
| 3888 | test(levelOwnerId == -1); | |
| 3889 | ||
| 3890 | r = lddChan.DeRegisterClient(ClientId[0]); | |
| 3891 | test(r == KErrNone); | |
| 3892 | ||
| 3893 | return; | |
| 3894 | } | |
| 3895 | ||
| 3896 | //Test cases to test the shared multilevel positive resources | |
| 3897 | void TestRM::SharedMultilevelPositiveResourceTesting(TUint aResId) | |
| 3898 | 	{
 | |
| 3899 | TInt newState; | |
| 3900 | TInt levelOwnerId; | |
| 3901 | TRequestStatus req; | |
| 3902 | TUint ClientId[2]; | |
| 3903 | ||
| 3904 | //Register 1st client | |
| 3905 | 	ClientName[6] = (TUint8)('0' + iMaxClientId+1);
 | |
| 3906 | r = lddChan.RegisterClient(ClientId[0], (const TDesC*)&ClientName); | |
| 3907 | test(r == KErrNone); | |
| 3908 | ||
| 3909 | r = lddChan.GetResourceStateSync(ClientId[0], Resources[aResId].iResourceId, ETrue, newState, levelOwnerId); | |
| 3910 | test(r == KErrNone); | |
| 3911 | if(levelOwnerId != -1) | |
| 3912 | 		{
 | |
| 3913 | 		test.Printf(_L("Not testing the shared resource as some other client is currently holding the resource\n"));
 | |
| 3914 | r = lddChan.DeRegisterClient(ClientId[0]); | |
| 3915 | test(r == KErrNone); | |
| 3916 | return; | |
| 3917 | } | |
| 3918 | ||
| 3919 | 	test.Printf(_L("Testing %d Shared Multilevel positive Resource\n"), Resources[aResId].iResourceId);
 | |
| 3920 | ||
| 3921 | //Register 2nd client | |
| 3922 | 	ClientName[6] = (TUint8)('0' + iMaxClientId+2);
 | |
| 3923 | r = lddChan.RegisterClient(ClientId[1], (const TDesC*)&ClientName); | |
| 3924 | test(r == KErrNone); | |
| 3925 | ||
| 3926 | //Change the resource and ClientId[0] becomes the owner of the resource | |
| 3927 | newState = Resources[aResId].iMinLevel + 20; | |
| 3928 | ||
| 3929 | r = lddChan.ChangeResourceStateSync(ClientId[0], Resources[aResId].iResourceId, newState); | |
| 3930 | test(r == KErrNone); | |
| 3931 | ||
| 3932 | TInt state; | |
| 3933 | r = lddChan.GetResourceStateSync(ClientId[0], Resources[aResId].iResourceId, ETrue, state, levelOwnerId); | |
| 3934 | test(r == KErrNone); | |
| 3935 | test(state == newState); | |
| 3936 | test(levelOwnerId = (TInt)ClientId[0]); | |
| 3937 | ||
| 3938 | //Second client(clientId[1]) trying to change the resource, but still | |
| 3939 | newState = Resources[aResId].iMinLevel +10; | |
| 3940 | lddChan.ChangeResourceStateAsync(ClientId[1], Resources[aResId].iResourceId, newState, req); | |
| 3941 | User::WaitForRequest(req); | |
| 3942 | test(req.Int() == KErrNone); | |
| 3943 | ||
| 3944 | lddChan.GetResourceStateAsync(ClientId[0], Resources[aResId].iResourceId, EFalse, req, newState, levelOwnerId); | |
| 3945 | User::WaitForRequest(req); | |
| 3946 | test(req.Int() == KErrNone); | |
| 3947 | test(state = newState); | |
| 3948 | test(levelOwnerId == (TInt)ClientId[0]); | |
| 3949 | ||
| 3950 | newState = Resources[aResId].iMinLevel + 5; | |
| 3951 | r = lddChan.ChangeResourceStateSync(ClientId[0], Resources[aResId].iResourceId, newState); | |
| 3952 | test(r == KErrNone); | |
| 3953 | ||
| 3954 | r = lddChan.GetResourceStateSync(ClientId[0], Resources[aResId].iResourceId, EFalse, state, levelOwnerId); | |
| 3955 | test(r == KErrNone); | |
| 3956 | test(state == Resources[aResId].iMinLevel+10); | |
| 3957 | test(levelOwnerId == (TInt)ClientId[1]); | |
| 3958 | ||
| 3959 | r = lddChan.DeRegisterClientLevelFromResource(ClientId[1], Resources[aResId].iResourceId); | |
| 3960 | test(r == KErrNone); | |
| 3961 | ||
| 3962 | newState = Resources[aResId].iMinLevel + 5; | |
| 3963 | lddChan.GetResourceStateAsync(ClientId[1], Resources[aResId].iResourceId, ETrue, req, state, levelOwnerId); | |
| 3964 | User::WaitForRequest(req); | |
| 3965 | test(req.Int() == KErrNone); | |
| 3966 | test(state == newState); | |
| 3967 | test(levelOwnerId == (TInt)ClientId[0]); | |
| 3968 | ||
| 3969 | newState = Resources[aResId].iMinLevel + 10; | |
| 3970 | lddChan.ChangeResourceStateAsync(ClientId[1], Resources[aResId].iResourceId, newState, req); | |
| 3971 | User::WaitForRequest(req); | |
| 3972 | test(req.Int() == KErrNone); | |
| 3973 | ||
| 3974 | ||
| 3975 | lddChan.GetResourceStateAsync(ClientId[0], Resources[aResId].iResourceId, EFalse, req, state, levelOwnerId); | |
| 3976 | User::WaitForRequest(req); | |
| 3977 | test(req.Int() == KErrNone); | |
| 3978 | test(state == newState); | |
| 3979 | test(levelOwnerId == (TInt)ClientId[1]); | |
| 3980 | ||
| 3981 | r = lddChan.DeRegisterClient(ClientId[1]); | |
| 3982 | test(r == KErrNone); | |
| 3983 | ||
| 3984 | r = lddChan.DeRegisterClientLevelFromResource(ClientId[0], Resources[aResId].iResourceId); | |
| 3985 | test(r == KErrNone); | |
| 3986 | ||
| 3987 | r = lddChan.GetResourceStateSync(ClientId[0], Resources[aResId].iResourceId, EFalse, state, levelOwnerId); | |
| 3988 | test(r == KErrNone); | |
| 3989 | test(state == Resources[aResId].iDefaultLevel); | |
| 3990 | test(levelOwnerId == -1); | |
| 3991 | ||
| 3992 | r = lddChan.DeRegisterClient(ClientId[0]); | |
| 3993 | test(r == KErrNone); | |
| 3994 | ||
| 3995 | return; | |
| 3996 | } | |
| 3997 | ||
| 3998 | //Custom resource testing. This testing is done only with simulated resources. | |
| 3999 | //Testing of shared binary positive resource. | |
| 4000 | //---------------------------------------------------------------------------------------------- | |
| 4001 | //! @SYMTestCaseID KBASE-T_RESCONTROLCLI-0593 | |
| 4002 | //! @SYMTestType UT | |
| 4003 | //! @SYMPREQ PREQ1398 | |
| 4004 | //! @SYMTestCaseDesc This test case tests changing resource state of shared positive resource. | |
| 4005 | //! @SYMTestActions 0 Register client1 | |
| 4006 | //! 1 Register client2 | |
| 4007 | //! 2 Register client3 | |
| 4008 | //! 3 Register client4 | |
| 4009 | //! 4 Client1 change resource state. | |
| 4010 | //! 5 Client2 change resource state. | |
| 4011 | //! 6 Client3 get resource state. | |
| 4012 | //! 7 Client4 get resource state. | |
| 4013 | //! 8 Client1 change resource state. | |
| 4014 | //! 9 Client2 get resource state. | |
| 4015 | //! 10 Deregister client2 | |
| 4016 | //! 11 Deregister client1 | |
| 4017 | //! 12 Deregister client3 | |
| 4018 | //! 13 Deregister client4 | |
| 4019 | //! | |
| 4020 | //! @SYMTestExpectedResults 0 Client registered | |
| 4021 | //! 1 Client registered | |
| 4022 | //! 2 Client registered | |
| 4023 | //! 3 Client registered | |
| 4024 | //! 4 Resource state changed | |
| 4025 | //! 5 Resource state changed | |
| 4026 | //! 6 Resource state read and compared for correctness | |
| 4027 | //! 7 Resource state read and compared for correctness | |
| 4028 | //! 8 Resource state changed | |
| 4029 | //! 9 Resource state read and compared for correctness | |
| 4030 | //! 10 Client2 deregistered | |
| 4031 | //! 11 Client1 deregistered | |
| 4032 | //! 12 Client3 deregistered | |
| 4033 | //! 13 Client4 deregistered | |
| 4034 | //! @SYMTestPriority High | |
| 4035 | //! @SYMTestStatus Implemented | |
| 4036 | //---------------------------------------------------------------------------------------------- | |
| 4037 | void TestRM::CustomResourceTesting(TUint aResId) | |
| 4038 | 	{
 | |
| 4039 | 	test.Printf(_L("Testing custom function\n"));
 | |
| 4040 | TInt r = KErrNone; | |
| 4041 | TRequestStatus req; | |
| 4042 | TInt state; | |
| 4043 | TInt newState; | |
| 4044 | TInt levelOwnerId; | |
| 4045 | TUint ClientId[4]; | |
| 4046 | 	ClientName[6] = (TUint8)('0' + iMaxClientId +1);
 | |
| 4047 | r = lddChan.RegisterClient(ClientId[0], (const TDesC*)&ClientName); | |
| 4048 | test(r == KErrNone); | |
| 4049 | 	ClientName[6] = (TUint8)('0' + iMaxClientId +2);
 | |
| 4050 | r = lddChan.RegisterClient(ClientId[1], (const TDesC*)&ClientName); | |
| 4051 | test(r == KErrNone); | |
| 4052 | 	ClientName[6] = (TUint8)('0' + iMaxClientId +3);
 | |
| 4053 | r = lddChan.RegisterClient(ClientId[2], (const TDesC*)&ClientName); | |
| 4054 | test(r == KErrNone); | |
| 4055 | 	ClientName[6] = (TUint8)('0' + iMaxClientId +4);
 | |
| 4056 | r = lddChan.RegisterClient(ClientId[3], (const TDesC*)&ClientName); | |
| 4057 | test(r == KErrNone); | |
| 4058 | r = lddChan.RequestNotification(ClientId[0], Resources[aResId].iResourceId); | |
| 4059 | test(r == KErrNone); | |
| 4060 | r = lddChan.RequestNotification(ClientId[1], Resources[aResId].iResourceId); | |
| 4061 | test(r == KErrNone); | |
| 4062 | newState = 1; | |
| 4063 | state = 1; | |
| 4064 | lddChan.ChangeResourceStateAsync(ClientId[2], Resources[aResId].iResourceId, state, req); | |
| 4065 | User::WaitForRequest(req); //State 1 | |
| 4066 | test(req.Int() == KErrNone); | |
| 4067 | test(state == newState); | |
| 4068 | test(r == KErrNone); | |
| 4069 | r = lddChan.CheckNotifications(Resources[aResId].iResourceId, 2, 0); | |
| 4070 | test(r == KErrNone); | |
| 4071 | state = 0; | |
| 4072 | lddChan.ChangeResourceStateAsync(ClientId[1], Resources[aResId].iResourceId, state, req); | |
| 4073 | User::WaitForRequest(req); | |
| 4074 | test(req.Int() == KErrNone); | |
| 4075 | test(state == newState); | |
| 4076 | r = lddChan.GetResourceStateSync(ClientId[0], Resources[aResId].iResourceId, EFalse, state, levelOwnerId); | |
| 4077 | test(r == KErrNone); | |
| 4078 | test(state == 1); | |
| 4079 | lddChan.ChangeResourceStateAsync(ClientId[0], Resources[aResId].iResourceId, state, req); | |
| 4080 | User::WaitForRequest(req); | |
| 4081 | test(req.Int() == KErrNone); | |
| 4082 | test(state == newState); | |
| 4083 | r = lddChan.GetResourceStateSync(ClientId[0], Resources[aResId].iResourceId, ETrue, state, levelOwnerId); | |
| 4084 | test(r == KErrNone); | |
| 4085 | test((TUint)levelOwnerId == ClientId[2]); | |
| 4086 | r = lddChan.ChangeResourceStateSync(ClientId[2], Resources[aResId].iResourceId, 0); | |
| 4087 | test(r == KErrNone); | |
| 4088 | r = lddChan.GetResourceStateSync(ClientId[0], Resources[aResId].iResourceId, EFalse, state, levelOwnerId); | |
| 4089 | test(r == KErrNone); | |
| 4090 | test(state == 1); | |
| 4091 | test((TUint)levelOwnerId == ClientId[0]); | |
| 4092 | r = lddChan.DeRegisterClient(ClientId[0]); | |
| 4093 | test(r == KErrNone); | |
| 4094 | r = lddChan.DeRegisterClientLevelFromResource(ClientId[1], Resources[aResId].iResourceId); | |
| 4095 | test(r == KErrNone); | |
| 4096 | r= lddChan.DeRegisterClient(ClientId[2]); | |
| 4097 | test(r == KErrNone); | |
| 4098 | r = lddChan.GetResourceStateSync(ClientId[3], Resources[aResId].iResourceId, ETrue, state, levelOwnerId); | |
| 4099 | test(r == KErrNone); | |
| 4100 | test(levelOwnerId == -1); | |
| 4101 | r = lddChan.DeRegisterClient(ClientId[3]); | |
| 4102 | test(r == KErrNone); | |
| 4103 | r = lddChan.DeRegisterClient(ClientId[1]); | |
| 4104 | test(r == KErrNone); | |
| 4105 | return; | |
| 4106 | } | |
| 4107 | ||
| 4108 | //Resource manager operations are chosen randomly and tested for correctness. This is done only in | |
| 4109 | //simulated resources. Currently this runs for 500 iteration. | |
| 4110 | //NOTE: Increasing the iteration to more than 500 may fail due to insufficient internal buffers. | |
| 4111 | void TestRM::RegressionTest() | |
| 4112 | 	{
 | |
| 4113 | TUint operation = 0; | |
| 4114 | TUint resourceId; | |
| 4115 | TUint count; | |
| 4116 | NegativeTesting = 0; | |
| 4117 | iMaxClientId = 0; | |
| 4118 | iMaxStaticResources = 0; | |
| 4119 | iMaxStaticDependentResources = 0; | |
| 4120 | iMaxClients = 0; | |
| 4121 | RmTest.RegisterClient(); | |
| 4122 | iCurrentClientId = -1; | |
| 4123 | r = lddChan.GetResourceControllerVersion(Clients[0].iClientId, iTestingExtendedVersion); | |
| 4124 | if(r != KErrNone) | |
| 4125 | 		test.Printf(_L("Return value of GetResourceControllerVersion %d\n"), r);
 | |
| 4126 | test(r == KErrNone); | |
| 4127 | if(!iTestingExtendedVersion) | |
| 4128 | 		test.Printf(_L("Testing Basic Version only...."));
 | |
| 4129 | else | |
| 4130 | 		test.Printf(_L("Testing basic & extended version...."));
 | |
| 4131 | RmTest.GetNumResourcesInUseByClient(iCurrentClientId); | |
| 4132 | RmTest.GetInfoOnResourcesInUseByClient(iCurrentClientId, iMaxStaticResources); | |
| 4133 | if(!(Resources[0].iName.Compare(*(const TDesC8*)&SpecialResName))) | |
| 4134 | 		{
 | |
| 4135 | 		TBuf8<32> PowerController = _L8("PowerController");
 | |
| 4136 | r = lddChan.GetClientId(Clients[0].iClientId, (TDesC8&)PowerController, iPowerControllerId); | |
| 4137 | test(r == KErrNone); | |
| 4138 | } | |
| 4139 | else | |
| 4140 | 		{
 | |
| 4141 | 		test.Printf(_L("Regression testing is run only on simulator"));
 | |
| 4142 | return; | |
| 4143 | } | |
| 4144 | ||
| 4145 | for(count = 0; count < 500; count++) | |
| 4146 | 		{
 | |
| 4147 | operation = Math::Random() % EOperationEnd; | |
| 4148 | iCurrentClientId = Math::Random() % iMaxClients; | |
| 4149 | resourceId = Math::Random() % iMaxStaticResources; | |
| 4150 | if(operation != ERegisterClient) | |
| 4151 | 			{
 | |
| 4152 | if(Clients[iCurrentClientId].iClientId == 0) //Not a valid client | |
| 4153 | continue; | |
| 4154 | } | |
| 4155 | if(Resources[resourceId].iSense == ECustom) | |
| 4156 | continue; | |
| 4157 | 		test.Printf(_L("\nOperation = %d, ClientId = %d, ResourceId = %d\n"), operation, iCurrentClientId, resourceId);
 | |
| 4158 | switch (operation) | |
| 4159 | 			{
 | |
| 4160 | case ERegisterClient: | |
| 4161 | RmTest.RegisterClient(); | |
| 4162 | break; | |
| 4163 | case EGetClientName: | |
| 4164 | RmTest.GetClientName(iCurrentClientId); | |
| 4165 | break; | |
| 4166 | case EGetAllClientName: | |
| 4167 | RmTest.GetClientName(0); | |
| 4168 | break; | |
| 4169 | case EGetClientId: | |
| 4170 | RmTest.GetClientId(iCurrentClientId); | |
| 4171 | break; | |
| 4172 | case EGetResourceId: | |
| 4173 | RmTest.GetResourceId(resourceId); | |
| 4174 | break; | |
| 4175 | case EGetResourceInfo: | |
| 4176 | RmTest.GetResourceInfo(resourceId); | |
| 4177 | break; | |
| 4178 | case EGetNumReosourceInUseByClient: | |
| 4179 | RmTest.GetNumResourcesInUseByClient(iCurrentClientId); | |
| 4180 | break; | |
| 4181 | case EGetInfoOnResourceInUseByClient: | |
| 4182 | 				test.Printf(_L("NumResources = %d\n"), Clients[iCurrentClientId].iNumResources);
 | |
| 4183 | RmTest.GetInfoOnResourcesInUseByClient(iCurrentClientId, Clients[iCurrentClientId].iNumResources); | |
| 4184 | break; | |
| 4185 | case EGetNumClientsUsingResource: | |
| 4186 | if(resourceId == 0) | |
| 4187 | 					{
 | |
| 4188 | RmTest.GetNumClientsUsingResource(iCurrentClientId, (TUint)-1); | |
| 4189 | } | |
| 4190 | else | |
| 4191 | 					{
 | |
| 4192 | RmTest.GetNumClientsUsingResource(iCurrentClientId, resourceId); | |
| 4193 | } | |
| 4194 | break; | |
| 4195 | case EGetInfoOnClientsUsingResource: | |
| 4196 | if(resourceId == 0) | |
| 4197 | RmTest.GetInfoOnClientsUsingResource((TUint)-1, iMaxClients+1); | |
| 4198 | else | |
| 4199 | 					{
 | |
| 4200 | 					test.Printf(_L("NumResources = %d\n"), Resources[resourceId].iNumClients);
 | |
| 4201 | RmTest.GetInfoOnClientsUsingResource(resourceId, Resources[resourceId].iNumClients); | |
| 4202 | } | |
| 4203 | break; | |
| 4204 | case EChangeResourceStateSync: | |
| 4205 | RmTest.ChangeResourceStateSync(resourceId); | |
| 4206 | break; | |
| 4207 | case EChangeResourceStateAsync: | |
| 4208 | RmTest.ChangeResourceStateAsync(resourceId); | |
| 4209 | break; | |
| 4210 | case EGetResourceStateSync: | |
| 4211 | RmTest.GetResourceStateSync(resourceId); | |
| 4212 | break; | |
| 4213 | case EGetResourceStateAsync: | |
| 4214 | RmTest.GetResourceStateAsync(resourceId); | |
| 4215 | break; | |
| 4216 | case ERequestNotificationCond: | |
| 4217 | RmTest.RequestNotificationCon(resourceId); | |
| 4218 | break; | |
| 4219 | case ERequestNotificationUnCond: | |
| 4220 | RmTest.RequestNotification(resourceId); | |
| 4221 | break; | |
| 4222 | case ECancelNotificationCond: | |
| 4223 | RmTest.CancelNotification(resourceId, ETrue); | |
| 4224 | break; | |
| 4225 | case ECancelNotificationUnCond: | |
| 4226 | RmTest.CancelNotification(resourceId, EFalse); | |
| 4227 | break; | |
| 4228 | } | |
| 4229 | } | |
| 4230 | //CleanUp | |
| 4231 | 	test.Printf(_L("Cleanup of all Clients\n"));
 | |
| 4232 | TInt clientCount = Clients.Count(); | |
| 4233 | for(count = clientCount-1; ((TInt)count) >=0; count--) | |
| 4234 | 		{
 | |
| 4235 | if(Clients[count].iClientId == 0) | |
| 4236 | continue; | |
| 4237 | 		test.Printf(_L("ClientId deregistration of %d\n"), Clients[count].iClientId);
 | |
| 4238 | RmTest.DeRegisterClient(count); | |
| 4239 | } | |
| 4240 | Clients.Close(); | |
| 4241 | } | |
| 4242 | ||
| 43 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4243 | void TestClientSettings(TInt aClientToken, TUint aExpectedBase) | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4244 | 	{
 | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4245 | TUint clientBase = ElementId_ClientSettingBase(aClientToken); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4246 | test(clientBase == aExpectedBase); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4247 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4248 | HCR::TElementId Id; | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4249 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4250 | Id = ElementId_ClientName(aClientToken); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4251 | test(Id == aExpectedBase); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4252 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4253 | Id = ElementId_ClientPropertyFlag(aClientToken); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4254 | test(Id == (aExpectedBase + 1)); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4255 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4256 | Id = ElementId_ClientPreallocation(aClientToken); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4257 | test(Id == (aExpectedBase + 2)); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4258 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4259 | TInt firstResource = 0; | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4260 | Id = ElementId_ClientStaticResource(aClientToken, firstResource); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4261 | test(Id == (aExpectedBase + 3)); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4262 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4263 | TInt thirdResource = 2; | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4264 | Id = ElementId_ClientStaticResource(aClientToken, thirdResource); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4265 | test(Id == (aExpectedBase + 5)); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4266 | } | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4267 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4268 | void TestDynamicResourceSettings(TInt aDynamicResource, TUint aExpectedBase) | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4269 | 	{
 | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4270 | TUint dynamicResourceBase = ElementId_DynamicResourceBase(aDynamicResource); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4271 | test(dynamicResourceBase == aExpectedBase); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4272 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4273 | HCR::TElementId Id; | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4274 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4275 | Id = ElementId_DynamicResourceName(aDynamicResource); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4276 | test(Id == aExpectedBase); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4277 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4278 | Id = ElementId_DynamicResourcePropertyFlag(aDynamicResource); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4279 | test(Id == (aExpectedBase + 1)); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4280 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4281 | Id = ElementId_DynamicResourceMaxLevel(aDynamicResource); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4282 | test(Id == (aExpectedBase + 2)); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4283 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4284 | Id = ElementId_DynamicResourceMinLevel(aDynamicResource); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4285 | test(Id == (aExpectedBase + 3)); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4286 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4287 | Id = ElementId_DynamicResourceDefaultLevel(aDynamicResource); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4288 | test(Id == (aExpectedBase + 4)); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4289 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4290 | Id = ElementId_DynamicResourceDependencyMask1(aDynamicResource); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4291 | test(Id == (aExpectedBase + 5)); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4292 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4293 | Id = ElementId_DynamicResourceDependencyMask2(aDynamicResource); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4294 | test(Id == (aExpectedBase + 6)); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4295 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4296 | Id = ElementId_DynamicResourceDependencyMask3(aDynamicResource); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4297 | test(Id == (aExpectedBase + 7)); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4298 | } | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4299 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4300 | void TestClientHCRSettingMacros() | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4301 | 	{
 | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4302 | TInt clientToken = 2; // Random token number | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4303 | TUint expectedBase = 80; // refer resourcecontrol_clientsettings.h for calculations | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4304 | TestClientSettings(clientToken, expectedBase); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4305 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4306 | clientToken = 0; | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4307 | expectedBase = 16; // refer resourcecontrol_clientsettings.h for calculations | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4308 | TestClientSettings(clientToken, expectedBase); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4309 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4310 | // Dynamic Resource settings | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4311 | TUint dynamicResource = 3; // Random token number | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4312 | expectedBase = 131168; // refer resourcecontrol_clientsettings.h for calculations | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4313 | TestDynamicResourceSettings(dynamicResource, expectedBase); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4314 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4315 | 	test.Printf(_L("Testing HCR client setting Macro's for Resource Manager successful \n"));
 | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4316 | } | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4317 | |
| 0 | 4318 | GLDEF_C TInt E32Main() | 
| 4319 | 	{
 | |
| 4320 | test.Title(); | |
| 4321 | 	test.Start(_L("Testing Resource Manager...\n"));
 | |
| 43 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4322 | 	test.Printf(_L("Testing HCR client setting Macro's for Resource Manager \n"));
 | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4323 | TestClientHCRSettingMacros(); | 
| 0 | 4324 | 	test.Next(_L("Load Physical device"));
 | 
| 4325 | #ifndef PRM_ENABLE_EXTENDED_VERSION | |
| 4326 | r = User::LoadPhysicalDevice(KPddFileName); | |
| 4327 | test(r==KErrNone || r==KErrAlreadyExists); | |
| 4328 | 	test.Next(_L("Load Logical Device"));
 | |
| 4329 | r=User::LoadLogicalDevice(KLddFileName); | |
| 4330 | test(r==KErrNone || r==KErrAlreadyExists); | |
| 4331 | __KHEAP_MARK; //Heap testing is done only for basic version | |
| 4332 | #else | |
| 4333 | r = User::LoadPhysicalDevice(KExtPddFileName); | |
| 4334 | test(r==KErrNone || r==KErrAlreadyExists); | |
| 4335 | 	test.Next(_L("Load Logical Device"));
 | |
| 4336 | r=User::LoadLogicalDevice(KExtLddFileName); | |
| 4337 | test(r==KErrNone || r==KErrAlreadyExists); | |
| 4338 | #endif | |
| 43 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4339 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4340 | RDevice d; | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4341 | TPckgBuf<RTestResMan::TCaps> caps; | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4342 | r = d.Open(KLddName); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4343 | test(r == KErrNone); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4344 | d.GetCaps(caps); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4345 | d.Close(); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4346 | |
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4347 | TVersion ver = caps().iVersion; | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4348 | test(ver.iMajor == 1); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4349 | test(ver.iMinor == 0); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4350 | test(ver.iBuild == KE32BuildVersionNumber); | 
| 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4351 | |
| 0 | 4352 | r = lddChan.Open(); | 
| 4353 | test(r==KErrNone || r==KErrAlreadyExists); | |
| 43 
c1f20ce4abcf
Revision: 201035
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
4diff
changeset | 4354 | |
| 0 | 4355 | //Check whether the notifications recieved as a result of postboot level setting is as expected. | 
| 4356 | r = lddChan.CheckPostBootLevelNotifications(); | |
| 4357 | test(r == KErrNone); | |
| 4358 | TBool regressionTesting = EFalse; | |
| 4359 | //Parse the command line arguments. | |
| 4360 | TBuf<0x50> cmd; | |
| 4361 | User::CommandLine(cmd); | |
| 4362 | TLex lex(cmd); | |
| 4363 | lex.SkipSpace(); | |
| 4364 | if(lex.Get() == '-') | |
| 4365 | 		{
 | |
| 4366 | TChar letter = lex.Get(); | |
| 4367 | if((letter == 'R') || (letter == 'r')) | |
| 4368 | regressionTesting = ETrue; | |
| 4369 | } | |
| 4370 | if(regressionTesting) | |
| 4371 | RmTest.RegressionTest(); | |
| 4372 | else | |
| 4373 | RmTest.APIValidationTest(); | |
| 4374 | 	test.Printf(_L("Closing the channel\n"));
 | |
| 4375 | lddChan.Close(); | |
| 4376 | 	test.Printf(_L("Freeing logical device\n"));
 | |
| 4377 | #ifndef PRM_ENABLE_EXTENDED_VERSION | |
| 4378 | __KHEAP_MARKEND; | |
| 4379 | r = User::FreeLogicalDevice(KLddFileName); | |
| 4380 | test(r==KErrNone); | |
| 4381 | r = User::FreePhysicalDevice(KPddFileName); | |
| 4382 | test(r==KErrNone); | |
| 4383 | #else | |
| 4384 | r = User::FreeLogicalDevice(KExtLddFileName); | |
| 4385 | test(r==KErrNone); | |
| 4386 | r = User::FreePhysicalDevice(KExtPddFileName); | |
| 4387 | test(r==KErrNone); | |
| 4388 | #endif | |
| 4389 | User::After(100000); | |
| 4390 | test.End(); | |
| 4391 | test.Close(); | |
| 4392 | return KErrNone; | |
| 4393 | } | |
| 4394 |