loggingservices/eventlogger/test/src/T_LogSecurity.cpp
changeset 0 08ec8eefde2f
child 11 667e88a979d7
equal deleted inserted replaced
-1:000000000000 0:08ec8eefde2f
       
     1 // Copyright (c) 2005-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 <e32test.h>
       
    17 #include <f32file.h>
       
    18 #include "logservsecurity.h"
       
    19 #include "LogServResourceInterpreter.h"
       
    20 #include <logeng.h>
       
    21 #include <logengevents.h>
       
    22 #include "SecurityPolicy.h"
       
    23 
       
    24 static RTest TheTest(_L("T_LogSecurity"));
       
    25 static RFs TheFileSess;
       
    26 
       
    27 ///////////////////////////////////////////////////////////////////////////////////////
       
    28 ///////////////////////////////////////////////////////////////////////////////////////
       
    29 //Test macross and functions
       
    30 
       
    31 static void Check(TInt aValue, TInt aLine)
       
    32 	{
       
    33 	if(!aValue)
       
    34 		{
       
    35 		TheTest(EFalse, aLine);
       
    36 		}
       
    37 	}
       
    38 static  void Check(TInt aValue, TInt aExpected, TInt aLine)
       
    39 	{
       
    40 	if(aValue != aExpected)
       
    41 		{
       
    42 		RDebug::Print(_L("*** Expected error: %d, got: %d\r\n"), aExpected, aValue);
       
    43 		TheTest(EFalse, aLine);
       
    44 		}
       
    45 	}
       
    46 #define TEST(arg) ::Check((arg), __LINE__)
       
    47 #define TEST2(aValue, aExpected) ::Check(aValue, aExpected, __LINE__)
       
    48 	
       
    49 ///////////////////////////////////////////////////////////////////////////////////////
       
    50 //
       
    51 
       
    52 //Check if supplied aPolicy parameter has aCapability capability.
       
    53 static TBool HasCapability(const TCompiledSecurityPolicy& aPolicy, TCapability aCapability)
       
    54 	{
       
    55 	TInt maxCount = 0;
       
    56 	if(aPolicy.Type() == TSecurityPolicy::ETypeS3 || 
       
    57 	   aPolicy.Type() == TSecurityPolicy::ETypeV3 ||
       
    58 	   aPolicy.Type() == TSecurityPolicy::ETypeC3)
       
    59 		{
       
    60 		maxCount = 3;	
       
    61 		}
       
    62 	else if(aPolicy.Type() == TSecurityPolicy::ETypeC7)
       
    63 		{
       
    64 		maxCount = 7;	
       
    65 		}
       
    66 	else
       
    67 		{
       
    68 		TEST(0);
       
    69 		}
       
    70 	for(TInt i=0;i<maxCount;++i)
       
    71 		{
       
    72 		if(aPolicy.Capability(i) == aCapability)
       
    73 			{
       
    74 			return ETrue;	
       
    75 			}
       
    76 		}
       
    77 	return EFalse;
       
    78 	}
       
    79 
       
    80 ///////////////////////////////////////////////////////////////////////////////////////
       
    81 //
       
    82 
       
    83 //Checks that all supported LogEngServer event types have the expected capabilities.
       
    84 //See LogWrap.rss file
       
    85 static void CheckEventSecurityPolicies(CLogServSecurity& aLogServSecurity)
       
    86 	{
       
    87 	TSecurityPolicy plc1r = aLogServSecurity.SecurityPolicy(KLogCallEventTypeUid, EReadOp);
       
    88 	TEST(::HasCapability(plc1r, ECapabilityReadUserData));
       
    89 	
       
    90 	TSecurityPolicy plc1w = aLogServSecurity.SecurityPolicy(KLogCallEventTypeUid, EWriteOp);
       
    91 	TEST(::HasCapability(plc1w, ECapabilityWriteUserData));
       
    92 	
       
    93 	TSecurityPolicy plc2r = aLogServSecurity.SecurityPolicy(KLogDataEventTypeUid, EReadOp);
       
    94 	TEST(::HasCapability(plc2r, ECapabilityReadUserData));
       
    95 	
       
    96 	TSecurityPolicy plc2w = aLogServSecurity.SecurityPolicy(KLogDataEventTypeUid, EWriteOp);
       
    97 	TEST(::HasCapability(plc2w, ECapabilityWriteUserData));
       
    98 	
       
    99 	TSecurityPolicy plc3r = aLogServSecurity.SecurityPolicy(KLogFaxEventTypeUid, EReadOp);
       
   100 	TEST(::HasCapability(plc3r, ECapabilityReadUserData));
       
   101 	
       
   102 	TSecurityPolicy plc3w = aLogServSecurity.SecurityPolicy(KLogFaxEventTypeUid, EWriteOp);
       
   103 	TEST(::HasCapability(plc3w, ECapabilityWriteUserData));
       
   104 	
       
   105 	TSecurityPolicy plc4r = aLogServSecurity.SecurityPolicy(KLogShortMessageEventTypeUid, EReadOp);
       
   106 	TEST(::HasCapability(plc4r, ECapabilityReadUserData));
       
   107 	
       
   108 	TSecurityPolicy plc4w = aLogServSecurity.SecurityPolicy(KLogShortMessageEventTypeUid, EWriteOp);
       
   109 	TEST(::HasCapability(plc4w, ECapabilityWriteUserData));
       
   110 	
       
   111 	TSecurityPolicy plc5r = aLogServSecurity.SecurityPolicy(KLogMailEventTypeUid, EReadOp);
       
   112 	TEST(TCompiledSecurityPolicy(plc5r).Type() == TSecurityPolicy::EAlwaysPass);
       
   113 	
       
   114 	TSecurityPolicy plc5w = aLogServSecurity.SecurityPolicy(KLogMailEventTypeUid, EWriteOp);
       
   115 	TEST(TCompiledSecurityPolicy(plc5w).Type() == TSecurityPolicy::EAlwaysPass);
       
   116 	
       
   117 	TSecurityPolicy plc6r = aLogServSecurity.SecurityPolicy(KLogTaskSchedulerEventTypeUid, EReadOp);
       
   118 	TEST(::HasCapability(plc6r, ECapabilityReadUserData));
       
   119 	
       
   120 	TSecurityPolicy plc6w = aLogServSecurity.SecurityPolicy(KLogTaskSchedulerEventTypeUid, EWriteOp);
       
   121 	TEST(!::HasCapability(plc6w, ECapabilityWriteUserData));
       
   122 	
       
   123 	TSecurityPolicy plc7r = aLogServSecurity.SecurityPolicy(KLogPacketDataEventTypeUid, EReadOp);
       
   124 	TEST(::HasCapability(plc7r, ECapabilityReadUserData));
       
   125 	
       
   126 	TSecurityPolicy plc7w = aLogServSecurity.SecurityPolicy(KLogPacketDataEventTypeUid, EWriteOp);
       
   127 	TEST(::HasCapability(plc7w, ECapabilityWriteUserData));
       
   128 	
       
   129 	
       
   130 	TSecurityPolicy plc8r = aLogServSecurity.SecurityPolicy(KLogLbsSelfLocateEventTypeUid, EReadOp);
       
   131 	TEST(::HasCapability(plc8r, ECapabilityReadDeviceData));
       
   132 	
       
   133 	TSecurityPolicy plc8w = aLogServSecurity.SecurityPolicy(KLogLbsSelfLocateEventTypeUid, EWriteOp);
       
   134 	TEST(::HasCapability(plc8w, ECapabilityWriteDeviceData));
       
   135 	
       
   136 	TSecurityPolicy plc9r = aLogServSecurity.SecurityPolicy(KLogLbsExternalLocateEventTypeUid, EReadOp);
       
   137 	TEST(::HasCapability(plc9r, ECapabilityReadDeviceData));
       
   138 	
       
   139 	TSecurityPolicy plc9w = aLogServSecurity.SecurityPolicy(KLogLbsExternalLocateEventTypeUid, EWriteOp);
       
   140 	TEST(::HasCapability(plc9w, ECapabilityWriteDeviceData));
       
   141 	
       
   142 	TSecurityPolicy plc10r = aLogServSecurity.SecurityPolicy(KLogLbsTransmitLocationEventTypeUid, EReadOp);
       
   143 	TEST(::HasCapability(plc10r, ECapabilityReadDeviceData));
       
   144 	
       
   145 	TSecurityPolicy plc10w = aLogServSecurity.SecurityPolicy(KLogLbsTransmitLocationEventTypeUid, EWriteOp);
       
   146 	TEST(::HasCapability(plc10w, ECapabilityWriteDeviceData));
       
   147 	
       
   148 	TSecurityPolicy plc11r = aLogServSecurity.SecurityPolicy(KLogLbsNetworkLocateEventTypeUid, EReadOp);
       
   149 	TEST(::HasCapability(plc11r, ECapabilityReadDeviceData));
       
   150 	
       
   151 	TSecurityPolicy plc11w = aLogServSecurity.SecurityPolicy(KLogLbsNetworkLocateEventTypeUid, EWriteOp);
       
   152 	TEST(::HasCapability(plc11w, ECapabilityWriteDeviceData));
       
   153 	
       
   154 	TSecurityPolicy plc12r = aLogServSecurity.SecurityPolicy(KLogLbsAssistanceDataEventTypeUid, EReadOp);
       
   155 	TEST(::HasCapability(plc12r, ECapabilityReadDeviceData));
       
   156 	
       
   157 	TSecurityPolicy plc12w = aLogServSecurity.SecurityPolicy(KLogLbsAssistanceDataEventTypeUid, EWriteOp);
       
   158 	TEST(::HasCapability(plc12w, ECapabilityWriteDeviceData));
       
   159 	}
       
   160 
       
   161 
       
   162 static void DoOOMTestL()
       
   163 	{
       
   164 	CLogServResourceInterpreter* logServRsc = CLogServResourceInterpreter::NewL(TheFileSess);
       
   165 	CleanupStack::PushL(logServRsc);
       
   166 	
       
   167 	CLogServSecurity* logServSecurity = CLogServSecurity::NewL(*logServRsc);
       
   168 	CleanupStack::PushL(logServSecurity);
       
   169 
       
   170 	::CheckEventSecurityPolicies(*logServSecurity);
       
   171 
       
   172 	CleanupStack::PopAndDestroy(logServSecurity);
       
   173 	CleanupStack::PopAndDestroy(logServRsc);
       
   174 	}
       
   175 
       
   176 // CLogServSecurity instance creation - OOM test
       
   177 static void OOMTest()
       
   178 	{
       
   179 	for(TInt count=1;;++count)
       
   180 		{
       
   181 		__UHEAP_FAILNEXT(count);
       
   182 		__UHEAP_MARK;
       
   183 		
       
   184 		TRAPD(err, ::DoOOMTestL());
       
   185 
       
   186 		if(err == KErrNoMemory)
       
   187 			{
       
   188 			__UHEAP_MARKEND;
       
   189 			}
       
   190 		else if(err == KErrNone)
       
   191 			{
       
   192 			__UHEAP_MARKEND;
       
   193 			RDebug::Print(_L("The test succeeded at heap failure rate=%d.\n"), count);
       
   194 			break;
       
   195 			}
       
   196 		else 
       
   197 			{
       
   198 			__UHEAP_MARKEND;
       
   199 			TEST2(err, KErrNone);
       
   200 			}
       
   201 		}
       
   202 	__UHEAP_RESET;
       
   203 	}
       
   204 	
       
   205 ///////////////////////////////////////////////////////////////////////////////////////
       
   206 //
       
   207 
       
   208 static void MainL()
       
   209 	{
       
   210 	TheTest.Start(_L(" @SYMTestCaseID:SYSLIBS-LOGENG-LEGACY-T_LOGSECURITY-0001 OOM test "));
       
   211 	::OOMTest();
       
   212 	}
       
   213 
       
   214 TInt E32Main()
       
   215 	{
       
   216 	__UHEAP_MARK;
       
   217 
       
   218 	CTrapCleanup* tc = CTrapCleanup::New();
       
   219 	TEST(tc != NULL);
       
   220 	
       
   221 	TEST2(TheFileSess.Connect(), KErrNone);
       
   222 
       
   223 	TheTest.Title();
       
   224 	TRAPD(err, ::MainL());
       
   225 	TEST2(err, KErrNone);
       
   226 	
       
   227 	TheTest.End();
       
   228 	TheTest.Close();
       
   229 
       
   230 	TheFileSess.Close();
       
   231 	
       
   232 	delete tc;
       
   233 
       
   234 	__UHEAP_MARKEND;
       
   235 
       
   236 	User::Heap().Check();
       
   237 	return KErrNone;
       
   238 	}