| author | Mark Wilcox <markw@symbian.org> | 
| Tue, 25 May 2010 13:20:47 +0100 | |
| changeset 116 | 57eea1054f46 | 
| parent 109 | b3a1d9898418 | 
| child 257 | 3e88ff8f41d5 | 
| child 271 | dc268b18d709 | 
| permissions | -rw-r--r-- | 
| 0 | 1 | // Copyright (c) 2002-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\secure\t_shal.cpp | |
| 15 | // Overview: | |
| 16 | // Test the security aspects of the HAL class. | |
| 17 | // API Information: | |
| 18 | // HAL | |
| 19 | // Details: | |
| 20 | // - For a variety of capability sets, get and set HAL hardware attributes | |
| 21 | // and check that the results are as expected. | |
| 22 | // - Set and restore the XYInputCalibration. | |
| 23 | // - Add an event using UserSvr::AddEvent() and verify the resulting capability | |
| 24 | // status. | |
| 25 | // Platforms/Drives/Compatibility: | |
| 26 | // All. | |
| 27 | // Assumptions/Requirement/Pre-requisites: | |
| 28 | // Failures and causes: | |
| 29 | // Base Port information: | |
| 30 | // | |
| 31 | // | |
| 32 | ||
| 33 | #define __INCLUDE_CAPABILITY_NAMES__ | |
| 34 | ||
| 35 | #include <e32test.h> | |
| 36 | #include <e32hal.h> | |
| 37 | #include <hal.h> | |
| 38 | #include <e32svr.h> | |
| 39 | ||
| 40 | LOCAL_D RTest test(_L("T_SHAL"));
 | |
| 41 | ||
| 42 | TCapabilitySet Capabilities; | |
| 43 | ||
| 44 | TInt PolicingVerified = 0; | |
| 45 | ||
| 46 | LOCAL_C TBool Check(TInt aResult,TCapability aCap) | |
| 47 | 	{
 | |
| 48 | switch(aResult) | |
| 49 | 		{
 | |
| 50 | case KErrNotSupported: | |
| 51 | 		RDebug::Print(_L("  Not Supported"));
 | |
| 52 | return ETrue; | |
| 53 | case KErrNone: | |
| 54 | 		RDebug::Print(_L("  No Error"));
 | |
| 55 | break; | |
| 56 | case KErrPermissionDenied: | |
| 57 | 		RDebug::Print(_L("  Permission Denied"));
 | |
| 58 | break; | |
| 59 | default: | |
| 60 | 		RDebug::Print(_L("  Error %d"),aResult);
 | |
| 61 | break; | |
| 62 | } | |
| 63 | ||
| 64 | if(Capabilities.HasCapability(aCap)) | |
| 65 | return aResult==KErrNone; | |
| 66 | else if(PlatSec::IsCapabilityEnforced(aCap)) | |
| 67 | return aResult==KErrPermissionDenied; | |
| 68 | else | |
| 69 | return aResult==KErrNone; | |
| 70 | } | |
| 71 | ||
| 72 | LOCAL_C void GetSetCheck(const char* aText,HALData::TAttribute aAttribute,TCapability aCap) | |
| 73 | 	{
 | |
| 74 | 	TBuf8<256> text=(const TUint8*)"HAL::Set(";
 | |
| 75 | text.Append((const TUint8*)aText,User::StringLength((const TUint8*)aText)); | |
| 76 | 	text.Append(')'); 
 | |
| 77 | test.Next(text.Expand()); | |
| 78 | TInt x = 0; | |
| 79 | HAL::Get(aAttribute,x); | |
| 80 | TInt r = HAL::Set(aAttribute,x); | |
| 81 | test(Check(r,aCap)); | |
| 82 | } | |
| 83 | ||
| 84 | #define SET_CHECK(a,c) GetSetCheck(#a,a,c); | |
| 85 | ||
| 86 | LOCAL_C TInt DoTests() | |
| 87 | 	{
 | |
| 88 | TInt r; | |
| 89 | // TInt x = 0; | |
| 90 | ||
| 91 | // | |
| 92 | // ECapabilityReadDeviceData | |
| 93 | // | |
| 94 | ||
| 95 | #if 0 | |
| 96 | 	test.Start(_L("UserHal::MachineInfo()"));
 | |
| 97 | TMachineInfoV2Buf info; | |
| 98 | r = UserHal::MachineInfo(info); | |
| 99 | test(Check(r,ECapabilityReadDeviceData)); | |
| 100 | #endif | |
| 101 | ||
| 102 | // | |
| 103 | // ECapabilityWriteDeviceData | |
| 104 | // | |
| 105 | ||
| 106 | SET_CHECK(HAL::EKeyboardClickState,ECapabilityWriteDeviceData); | |
| 107 | SET_CHECK(HAL::EKeyboardClickVolume,ECapabilityWriteDeviceData); | |
| 108 | SET_CHECK(HAL::EPenClickState,ECapabilityWriteDeviceData); | |
| 109 | SET_CHECK(HAL::EPenClickVolume,ECapabilityWriteDeviceData); | |
| 110 | SET_CHECK(HAL::ELanguageIndex,ECapabilityWriteDeviceData); | |
| 111 | SET_CHECK(HAL::EKeyboardIndex,ECapabilityWriteDeviceData); | |
| 112 | SET_CHECK(HAL::ESystemDrive,ECapabilityWriteDeviceData); | |
| 113 | SET_CHECK(HAL::ECaseSwitchDisplayOn,ECapabilityWriteDeviceData); | |
| 114 | SET_CHECK(HAL::ECaseSwitchDisplayOff,ECapabilityWriteDeviceData); | |
| 115 | SET_CHECK(HAL::EDisplayContrast,ECapabilityWriteDeviceData); | |
| 116 | SET_CHECK(HAL::EDisplayBrightness,ECapabilityWriteDeviceData); | |
| 117 | SET_CHECK(HAL::EBacklightState,ECapabilityWriteDeviceData); | |
| 118 | SET_CHECK(HAL::EPenDisplayOn,ECapabilityWriteDeviceData); | |
| 119 | SET_CHECK(HAL::ELocaleLoaded,ECapabilityWriteDeviceData); | |
| 120 | SET_CHECK(HAL::ECustomResourceDrive,ECapabilityWriteDeviceData); | |
| 121 | ||
| 122 | 	test.Next(_L("UserHal::CalibrationPoints()"));
 | |
| 123 | TDigitizerCalibration xy; | |
| 124 | UserHal::CalibrationPoints(xy); | |
| 125 | r = UserHal::SetXYInputCalibration(xy); | |
| 126 | test(Check(r,ECapabilityWriteDeviceData)); | |
| 127 | ||
| 128 | 	test.Next(_L("UserHal::RestoreXYInputCalibration()"));
 | |
| 129 | UserHal::SaveXYInputCalibration(); | |
| 130 | r = UserHal::RestoreXYInputCalibration(ESaved); | |
| 131 | test(Check(r,ECapabilityWriteDeviceData)); | |
| 132 | ||
| 133 | // | |
| 134 | // ECapabilityMultimediaDD | |
| 135 | // | |
| 136 | ||
| 137 | SET_CHECK(HAL::EMouseState,ECapabilityMultimediaDD); | |
| 138 | SET_CHECK(HAL::EMouseSpeed,ECapabilityMultimediaDD); | |
| 139 | SET_CHECK(HAL::EMouseAcceleration,ECapabilityMultimediaDD); | |
| 140 | // SET_CHECK(HAL::EDisplayMode,ECapabilityMultimediaDD); | |
| 141 | // SET_CHECK(HAL::EDisplayPaletteEntry,ECapabilityMultimediaDD); | |
| 142 | ||
| 143 | // | |
| 144 | // ECapabilityPowerMgmt | |
| 145 | // | |
| 146 | ||
| 147 | SET_CHECK(HAL::EKeyboardBacklightState,ECapabilityPowerMgmt); | |
| 148 | SET_CHECK(HAL::EAccessoryPower,ECapabilityPowerMgmt); | |
| 149 | SET_CHECK(HAL::EDisplayState,ECapabilityPowerMgmt); | |
| 150 | SET_CHECK(HAL::EKeyboardState,ECapabilityPowerMgmt); | |
| 151 | SET_CHECK(HAL::EPenState,ECapabilityPowerMgmt); | |
| 152 | /* | |
| 153 | 	test.Next(_L("UserHal::SwitchOff()"));
 | |
| 154 | RTimer timer; | |
| 155 | TRequestStatus done; | |
| 156 | timer.CreateLocal(); | |
| 157 | TTime wakeup; | |
| 158 | wakeup.HomeTime(); | |
| 159 | wakeup+=TTimeIntervalSeconds(4); | |
| 160 | timer.At(done,wakeup); | |
| 161 | r = UserHal::SwitchOff(); // May not actually turn off due to imminent RTimer.At() | |
| 162 | test(Check(r,ECapabilityPowerMgmt)); | |
| 163 | User::WaitForRequest(done); | |
| 164 | */ | |
| 165 | // | |
| 166 | // ECapabilitySwEvent | |
| 167 | // | |
| 168 | ||
| 169 | 	test.Next(_L("UserSvr::AddEvent()"));
 | |
| 170 | TRawEvent event; | |
| 171 | r = UserSvr::AddEvent(event); | |
| 172 | test(Check(r,ECapabilitySwEvent)); | |
| 173 | ||
| 174 | // | |
| 175 | ||
| 176 | test.End(); | |
| 177 | ||
| 178 | return 0x55555555; | |
| 179 | } | |
| 180 | ||
| 181 | ||
| 182 | enum TTestProcessFunctions | |
| 183 | 	{
 | |
| 184 | ETestProcessDoTests, | |
| 185 | }; | |
| 186 | ||
| 187 | #include "testprocess.h" | |
| 188 | ||
| 189 | ||
| 190 | ||
| 191 | GLDEF_C TInt E32Main() | |
| 192 |     {
 | |
| 193 | Capabilities = TSecurityInfo(RProcess()).iCaps; | |
| 194 | ||
| 195 | test.Title(); | |
| 196 | ||
| 197 | if(User::CommandLineLength()) | |
| 198 | 		{
 | |
| 199 | TBuf<128> message; | |
| 200 | __ASSERT_COMPILE(ECapability_Limit<64); | |
| 201 | 		message.AppendFormat(_L("Tests with capabilities %08x%08x"),((TUint32*)&Capabilities)[1],((TUint32*)&Capabilities)[0]);
 | |
| 202 | test.Start(message); | |
| 203 | TInt result = DoTests(); | |
| 204 | // Don't test.End() so we don't get lots of 'Success's in logs | |
| 205 | return(result); | |
| 206 | } | |
| 207 | ||
| 208 | test.Title(); | |
| 209 | 	test.Start(_L("Start"));
 | |
| 210 | TInt c; | |
| 211 | for(c=0; c<1+ECapability_Limit; c++) | |
| 212 | 		{
 | |
| 213 | RTestProcess p; | |
| 214 | TRequestStatus s; | |
| 215 | TBuf<128> message; | |
| 216 | TCapabilitySet caps; | |
| 217 | caps.SetAllSupported(); | |
| 218 | if(!caps.HasCapability((TCapability)c)) | |
| 219 | continue; | |
| 220 | caps.RemoveCapability((TCapability)c); | |
| 221 | TBuf8<128> capNameBuf; | |
| 222 | capNameBuf.Copy((const TUint8*)CapabilityNames[c]); | |
| 223 | TPtr capName(capNameBuf.Expand()); | |
| 224 | 		message.AppendFormat(_L("Tests with all capabilities except %S"),&capName);
 | |
| 225 | test.Next(message); | |
| 226 | p.Create(*(TUint32*)&caps,ETestProcessDoTests); | |
| 227 | p.Logon(s); | |
| 228 | p.Resume(); | |
| 229 | User::WaitForRequest(s); | |
| 230 | test(p.ExitType()==EExitKill); | |
| 231 | TInt result=s.Int()^0x55555555; | |
| 232 | test(result==0); | |
| 233 | CLOSE_AND_WAIT(p); | |
| 234 | } | |
| 235 | ||
| 236 | // Show results requiring manual inspection | |
| 237 | _LIT(KSeperatorText,"----------------------------------------------------------------------------\n"); | |
| 238 | 	test.Printf(_L("\n"));
 | |
| 239 | 	test.Printf(_L("RESULTS\n")); 
 | |
| 240 | test.Printf(KSeperatorText); | |
| 241 | TInt verified=1; | |
| 242 | for(c=0; c<ECapability_Limit; c++) | |
| 243 | if(!PlatSec::IsCapabilityEnforced((TCapability)c)) | |
| 244 | verified = 0; | |
| 245 | ||
| 246 | if(!verified) | |
| 247 | 		test.Printf(_L("*  Did NOT verify security checking\n"));
 | |
| 248 | else | |
| 249 | 		test.Printf(_L("*  Verified security checking\n"));
 | |
| 250 | test.Printf(KSeperatorText); | |
| 251 | ||
| 252 | // Wait for a while, or for a key press | |
| 253 | 	test.Printf(_L("Waiting a short while for key press...\n"));
 | |
| 254 | TRequestStatus keyStat; | |
| 255 | test.Console()->Read(keyStat); | |
| 256 | RTimer timer; | |
| 257 | test(timer.CreateLocal()==KErrNone); | |
| 258 | TRequestStatus timerStat; | |
| 259 | timer.After(timerStat,20*1000000); | |
| 260 | User::WaitForRequest(timerStat,keyStat); | |
| 261 | if(keyStat!=KRequestPending) | |
| 109 
b3a1d9898418
Revision: 201019
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
0diff
changeset | 262 | (void)test.Console()->KeyCode(); | 
| 0 | 263 | timer.Cancel(); | 
| 264 | test.Console()->ReadCancel(); | |
| 265 | User::WaitForAnyRequest(); | |
| 266 | ||
| 267 | test.End(); | |
| 268 | return(0); | |
| 269 | } | |
| 270 |