persistentstorage/centralrepository/test/testexecute/performance/src/TE_NotifyMemTestStep.cpp
branchRCL_3
changeset 24 cc28652e0254
parent 0 08ec8eefde2f
equal deleted inserted replaced
23:26645d81f48d 24:cc28652e0254
       
     1 // Copyright (c) 2006-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 "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 //
       
    15 
       
    16 #include "TE_NotifyMemTestStep.h"
       
    17 #include "TE_PerfTestUtilities.h"
       
    18 #include "t_cenrep_helper.h"
       
    19 #include <centralrepository.h>
       
    20 #include "srvreqs.h"
       
    21 #include "srvPerf.h"
       
    22 #include "srvdefs.h"
       
    23 #include "cachemgr.h"
       
    24 
       
    25 //--------------------------------
       
    26 // class CNotifyMemTestStep
       
    27 //--------------------------------
       
    28 
       
    29 #if defined(__CENTREP_SERVER_MEMTEST__) 
       
    30 const TUid KUidTestRepository1 				= { 0x00000001 };
       
    31 const TUid KUidCacheTestRepositorySmTxt		= { 0x00000100 };
       
    32 const TUid KUidCacheTestRepositoryMedTxt    = { 0x10057522 };
       
    33 const TUid KUidCacheTestRepositorySmCre		= { 0x22222221 };
       
    34 const TUid KUidCacheTestRepositoryLrgCre	= { 0xCCCCCC02 };
       
    35 
       
    36 const TInt KKey1 = 1;
       
    37 const TInt KKey2 = 0x201;
       
    38 const TInt KKey3 = 8585472;
       
    39 const TInt KKey4 = 22;
       
    40 #endif
       
    41 
       
    42 #ifdef __CENTREP_SERVER_MEMTEST__
       
    43 void CNotifyMemTestStep::ProcessMemTestResults(TAny* aRawData, TInt32 aRawCount, RArray<TMemTestResult>& aMemTestResults)
       
    44 	{
       
    45 	ASSERT(aRawCount);
       
    46 	ASSERT(aRawCount>=3);
       
    47 	
       
    48 	for(TInt i=0; i+2<aRawCount;)
       
    49 		{
       
    50 		TInt32 value1 = static_cast<TInt32*>(aRawData)[i++];
       
    51 		TInt32 value2 = static_cast<TInt32*>(aRawData)[i++];
       
    52 		TInt32 value3 = static_cast<TInt32*>(aRawData)[i++];
       
    53 		
       
    54 		if(value1 == KMagicMemTestOutOfBounds && value2 == KMagicMemTestOutOfBounds && value2 == KMagicMemTestOutOfBounds)
       
    55 			{
       
    56 			WARN_PRINTF1(_L("Memory test was not able to store all the requested values. Only the stored values will be reported."));
       
    57 			}
       
    58 		else
       
    59 			{
       
    60 			TMemTestResult result(value1, value2, ETrue);
       
    61 			if(result.iLocation == EMemLcnOnDemand)
       
    62 				{
       
    63 				result.iInitHeapSize = 0;
       
    64 				result.iFinalHeapSize = value3;
       
    65 				aMemTestResults.Append(result);
       
    66 				}
       
    67 			}
       
    68 		}
       
    69 	}
       
    70 #endif //__CENTREP_SERVER_MEMTEST__
       
    71 
       
    72 /**
       
    73 @SYMTestCaseID		SYSLIBS-CENTRALREPOSITORY-PT-1658
       
    74 @SYMTestCaseDesc	Notify-only client optimization RAM usage test
       
    75 @SYMTestPriority	High
       
    76 @SYMTestActions		Retrieve memory usage data collected by CentRep server, analyze, and
       
    77 	print out a summary during certain stages of the lifetime of session objects.
       
    78 @SYMTestExpectedResults This test always pass. Engineers working on CentRep 
       
    79 	improvement will run this suite before and after submission to gauge actual
       
    80 	savings in RAM usage of repositories.
       
    81 @SYMPREQ			PREQ 1228 Symbian OS v9.3 System Quality: Performance, ROM and RAM targets 
       
    82 */	
       
    83 TVerdict CNotifyMemTestStep::doTestStepL()
       
    84 	{
       
    85 #if defined(__CENTREP_SERVER_MEMTEST__)
       
    86 
       
    87 	SetTestStepResult(EFail);
       
    88 
       
    89 	TInt testSteps = 0;
       
    90 	TInt r;
       
    91 	
       
    92 	// Make sure cache is empty before we start
       
    93 #ifdef __CENTREP_SERVER_CACHETEST__
       
    94 	r = SetGetParameters(TIpcArgs(EDisableCache));
       
    95 	TESTL(r==KErrNone);
       
    96 	r = SetGetParameters(TIpcArgs(EEnableCache, KDefaultEvictionTimeout, KDefaultCacheSize));
       
    97 	TESTL(r==KErrNone);
       
    98 #else //__CENTREP_SERVER_CACHETEST__
       
    99 	CleanupRepositoryCache();
       
   100 #endif //__CENTREP_SERVER_CACHETEST__
       
   101 	//Reset RAM test data
       
   102 	r = SetGetParameters(TIpcArgs(ERestartMemTests));
       
   103 	TESTL(r==KErrNone);
       
   104 
       
   105 	// Start of test
       
   106 	Logger().WriteFormat(_L("Step %d, RAM at the beginning of test"),testSteps);
       
   107 	r = SetGetParameters(TIpcArgs(ESingleMemTest, testSteps++));
       
   108 	TESTL(r==KErrNone);
       
   109 
       
   110 	CRepository* repository1;
       
   111 	User::LeaveIfNull(repository1 = CRepository::NewLC(KUidTestRepository1));
       
   112 	CRepository* repository2;
       
   113 	User::LeaveIfNull(repository2 = CRepository::NewLC(KUidCacheTestRepositorySmTxt));
       
   114 	CRepository* repository3;
       
   115 	User::LeaveIfNull(repository3 = CRepository::NewLC(KUidCacheTestRepositoryMedTxt));
       
   116 	CRepository* repository4;
       
   117 	User::LeaveIfNull(repository4 = CRepository::NewLC(KUidCacheTestRepositorySmCre));
       
   118 	CRepository* repository5;
       
   119 	User::LeaveIfNull(repository5 = CRepository::NewLC(KUidCacheTestRepositoryLrgCre));
       
   120 
       
   121 	// Reps automatically loaded by Init
       
   122 	Logger().WriteFormat(_L("Step %d, RAM after sessions created"),testSteps);	
       
   123 	r = SetGetParameters(TIpcArgs(ESingleMemTest, testSteps++));
       
   124 	TESTL(r==KErrNone);
       
   125 
       
   126 	TInt i;
       
   127 	r = repository1->Get(KKey1, i);
       
   128 	TESTL(r==KErrNone);
       
   129 	r = repository2->Get(KKey2, i);
       
   130 	TESTL(r==KErrNone);
       
   131 	r = repository3->Get(KKey4, i);
       
   132 	TESTL(r==KErrNone);
       
   133 	r = repository4->Get(KKey1, i);
       
   134 	TESTL(r==KErrNone);
       
   135 	r = repository5->Get(KKey3, i);
       
   136 	TESTL(r==KErrNone);
       
   137 
       
   138 	// Get's don't change memory usage because reps are already loaded/in cache
       
   139 	Logger().WriteFormat(_L("Step %d, RAM after Get() calls"),testSteps);		
       
   140 	r = SetGetParameters(TIpcArgs(ESingleMemTest, testSteps++));
       
   141 	TESTL(r==KErrNone);
       
   142 
       
   143 #ifdef __CENTREP_SERVER_CACHETEST__
       
   144 	r = SetGetParameters(TIpcArgs(EDisableCache));
       
   145 	TESTL(r==KErrNone);
       
   146 	r = SetGetParameters(TIpcArgs(EEnableCache, KDefaultEvictionTimeout, KDefaultCacheSize));
       
   147 	TESTL(r==KErrNone);
       
   148 #else //__CENTREP_SERVER_CACHETEST__
       
   149 	CleanupRepositoryCache();
       
   150 #endif //__CENTREP_SERVER_CACHETEST__
       
   151 
       
   152 	// Memory freed after reps are evicted
       
   153 	Logger().WriteFormat(_L("Step %d, RAM after delaying for eviction"),testSteps);			
       
   154 	r = SetGetParameters(TIpcArgs(ESingleMemTest, testSteps++));
       
   155 	TESTL(r==KErrNone);
       
   156 	
       
   157 	r = repository1->Get(KKey1, i);
       
   158 	TESTL(r==KErrNone);
       
   159 	r = repository2->Get(KKey2, i);
       
   160 	TESTL(r==KErrNone);
       
   161 	r = repository3->Get(KKey4, i);
       
   162 	TESTL(r==KErrNone);
       
   163 	r = repository4->Get(KKey1, i);
       
   164 	TESTL(r==KErrNone);
       
   165 	r = repository5->Get(KKey3, i);
       
   166 	TESTL(r==KErrNone);
       
   167 
       
   168 	// This time Get's trigger loads 
       
   169 	Logger().WriteFormat(_L("Step %d, RAM after Get() calls"),testSteps);			
       
   170 	r = SetGetParameters(TIpcArgs(ESingleMemTest, testSteps++));
       
   171 	TESTL(r==KErrNone);
       
   172 
       
   173 	CleanupStack::PopAndDestroy(5);
       
   174 
       
   175 	// Closing sessions don't unload the reps because of coarse grained caching
       
   176 	Logger().WriteFormat(_L("Step %d, RAM after sessions are closed"),testSteps);				
       
   177 	r = SetGetParameters(TIpcArgs(ESingleMemTest, testSteps++));
       
   178 	TESTL(r==KErrNone);
       
   179 
       
   180 #ifdef __CENTREP_SERVER_CACHETEST__
       
   181 	r = SetGetParameters(TIpcArgs(EDisableCache));
       
   182 	TESTL(r==KErrNone);
       
   183 	r = SetGetParameters(TIpcArgs(EEnableCache, KDefaultEvictionTimeout, KDefaultCacheSize));
       
   184 	TESTL(r==KErrNone);
       
   185 #else //__CENTREP_SERVER_CACHETEST__
       
   186 	CleanupRepositoryCache();
       
   187 #endif //__CENTREP_SERVER_CACHETEST__
       
   188 
       
   189 	// Reps are unloaded by cache manager
       
   190 	Logger().WriteFormat(_L("Step %d, RAM after delaying for eviction"),testSteps);					
       
   191 	r = SetGetParameters(TIpcArgs(ESingleMemTest, testSteps++));
       
   192 	TESTL(r==KErrNone);
       
   193 
       
   194 	// call inherited function to get the results
       
   195 	SetTestStepResult(CMemTestStep::doTestStepL());
       
   196 	
       
   197 	return TestStepResult();
       
   198 #else // defined(__CENTREP_SERVER_MEMTEST__)
       
   199 
       
   200 	_LIT(KWarnMemTestMacroOff, "Memory test macro __CENTREP_SERVER_MEMTEST__ is disabled. Test not run.");
       
   201 	WARN_PRINTF1(KWarnMemTestMacroOff);
       
   202  
       
   203 	return EPass;	
       
   204 # endif  // defined(__CENTREP_SERVER_MEMTEST__)
       
   205 
       
   206 
       
   207 
       
   208 	}