| author | Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> | 
| Tue, 14 Sep 2010 23:56:21 +0300 | |
| branch | RCL_3 | 
| changeset 45 | 9e2d4f7f5028 | 
| parent 44 | 3e88ff8f41d5 | 
| permissions | -rw-r--r-- | 
| 0 | 1 | // Copyright (c) 1998-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 | // f32test\scndrv\t_scn32dr3.cpp | |
| 15 | // | |
| 16 | // | |
| 17 | ||
| 18 | #include <f32file.h> | |
| 19 | #include <e32test.h> | |
| 6 
0173bcd7697c
Revision: 201001
 Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com> parents: 
0diff
changeset | 20 | #include <e32svr.h> | 
| 0 | 21 | #include "t_server.h" | 
| 22 | ||
| 23 | #include "fat_utils.h" | |
| 24 | using namespace Fat_Test_Utils; | |
| 25 | ||
| 26 | ||
| 27 | /* Tests rugged fat filing system for epoc platforms. Copies \t_scn32dr3.exe to | |
| 28 | \sys\bin\eshell.exe to enable the test to carry on after a reset. | |
| 29 | See t_tscan for a fuller description of the tests carried out. Good idea to | |
| 30 | disable crash debugger via \e32\inc\m32std.h. Drive to be tested is selected at | |
| 31 | the command line. Also useful to disable beep in \e32\kpepoc\kp_ini.cpp to | |
| 32 | avoid excessive noise.*/ | |
| 33 | ||
| 34 | GLDEF_D RTest test(_L("T_SCN32DR3"));
 | |
| 35 | ||
| 36 | GLREF_D TInt TheFunctionNumber; | |
| 37 | GLREF_D TInt TheOpNumber; | |
| 38 | GLREF_D TInt TheFailCount; | |
| 39 | GLREF_D TBool IsReset; | |
| 40 | GLREF_D RFs TheFs; | |
| 41 | GLREF_D TFileName TestExeName; | |
| 42 | GLREF_D TFileName StartupExeName; | |
| 43 | GLREF_D TFileName LogFileName; | |
| 44 | ||
| 45 | #if defined( _DEBUG) && !defined(__WINS__) | |
| 46 | const TInt KControlIoRuggedOn=2; | |
| 47 | const TInt KControlIoRuggedOff=3; | |
| 48 | const TInt KControlIoIsRugged=4; | |
| 49 | #endif | |
| 50 | GLREF_D TInt WriteFailValue; | |
| 51 | GLREF_C void ReadLogFile(); | |
| 52 | GLREF_C void DoTests(); | |
| 53 | ||
| 54 | #if defined(_DEBUG) | |
| 55 | LOCAL_C void OverrideEShell(void) | |
| 56 | // | |
| 57 | // Copies the executable file as the eshell so that it is automatically run | |
| 58 | // | |
| 59 |     {
 | |
| 60 |     test.Next(_L("OverideEShell"));
 | |
| 61 | RProcess myProc; | |
| 62 | if (myProc.FileName().CompareF(StartupExeName) == 0) | |
| 63 |         test.Printf(_L("OverrideEShell: running as eshell\n"));
 | |
| 64 | else | |
| 65 |         {
 | |
| 66 | RFile logFile; | |
| 67 | TInt r; | |
| 68 |         TFileName tempDirName=_L("");
 | |
| 69 | // Copy over this executable and create a progress file. | |
| 70 |         test.Printf(_L("Copying %S to %S\n"), &TestExeName, &StartupExeName);
 | |
| 71 | if(PlatSec::ConfigSetting(PlatSec::EPlatSecEnforceSysBin)) | |
| 72 |             tempDirName = _L("?:\\SYS\\BIN\\");
 | |
| 73 | else | |
| 74 |             tempDirName = _L("?:\\SYSTEM\\BIN\\");
 | |
| 75 | tempDirName[0] = gSessionPath[0]; | |
| 76 | r=TheFs.MkDirAll(tempDirName); | |
| 44 | 77 | test(r==KErrNone||r==KErrAlreadyExists); | 
| 0 | 78 | CFileMan* fileMan=NULL; | 
| 79 | TRAP(r,fileMan = CFileMan::NewL(TheFs)); | |
| 44 | 80 | test(r==KErrNone); | 
| 0 | 81 | //Copy the test from Z drive. | 
| 82 |         TFileName temp=_L("Z:\\SYS\\BIN\\T_SCN32DR3.EXE");
 | |
| 83 | r = fileMan->Copy(temp, TestExeName, CFileMan::EOverWrite); | |
| 44 | 84 | test(r==KErrNone); | 
| 0 | 85 | r = fileMan->Copy(TestExeName, StartupExeName, CFileMan::EOverWrite); | 
| 44 | 86 | test(r == KErrNone); | 
| 0 | 87 | //Mask read attribute. Fix for DEF081323 | 
| 88 | r = fileMan->Attribs(StartupExeName, 0, KEntryAttReadOnly, 0); | |
| 44 | 89 | test(r == KErrNone); | 
| 0 | 90 | r = fileMan->Attribs(TestExeName, 0, KEntryAttReadOnly, 0); | 
| 44 | 91 | test(r == KErrNone); | 
| 0 | 92 | r = logFile.Replace(TheFs,LogFileName,EFileShareExclusive|EFileWrite); | 
| 44 | 93 | test(r == KErrNone); | 
| 0 | 94 | logFile.Close(); | 
| 95 | delete fileMan; | |
| 96 | } | |
| 97 | } | |
| 98 | #endif | |
| 99 | ||
| 100 | GLDEF_C void CallTestsL() | |
| 101 | // | |
| 102 | // | |
| 103 | // | |
| 104 |     {
 | |
| 105 | if(PlatSec::ConfigSetting(PlatSec::EPlatSecEnforceSysBin)) | |
| 106 |         StartupExeName=_L("?:\\SYS\\BIN\\ESHELL.EXE");
 | |
| 107 | else | |
| 108 |         StartupExeName=_L("?:\\SYSTEM\\BIN\\ESHELL.EXE");
 | |
| 109 | //RFs::ControlIo only supported in debug build | |
| 110 | #ifndef _DEBUG | |
| 111 |     test.Printf(_L("Error: Supported only debug testing\n"));
 | |
| 112 | return; | |
| 113 | #else | |
| 114 | #if defined(__WINS__) | |
| 115 |     test.Printf(_L("WINS not tested\n"));
 | |
| 116 | return; | |
| 117 | #else | |
| 118 | const TInt KWriteFailReset=-99; // soft reset after write fail | |
| 119 | ||
| 120 | TInt r; | |
| 121 | TestExeName[0]=StartupExeName[0]=LogFileName[0]=gSessionPath[0]; | |
| 122 | // ensure file system is rugged | |
| 123 | TUint8 oldFsys; | |
| 124 | TPtr8 pRugged(&oldFsys,1,1); | |
| 125 | r=TheFs.ControlIo(gSessionPath[0]-'A',KControlIoIsRugged,pRugged); | |
| 44 | 126 | test(r==KErrNone); | 
| 0 | 127 | if(oldFsys==0) | 
| 128 |         {
 | |
| 129 | r=TheFs.ControlIo(gSessionPath[0]-'A',KControlIoRuggedOn); | |
| 44 | 130 | test(r==KErrNone); | 
| 0 | 131 | } | 
| 132 | TheFunctionNumber=0; | |
| 133 | TheOpNumber=0; | |
| 134 | TheFailCount=0; | |
| 135 | IsReset=ETrue; | |
| 136 | WriteFailValue=KWriteFailReset; | |
| 137 |     test.Printf(_L("IsReset=%d\n"),IsReset);
 | |
| 138 | OverrideEShell(); | |
| 139 | ReadLogFile(); | |
| 140 | r=TheFs.ScanDrive(gSessionPath); | |
| 44 | 141 | test(r==KErrNone); | 
| 0 | 142 | r=TheFs.CheckDisk(gSessionPath); | 
| 44 | 143 | test(r==KErrNone); | 
| 0 | 144 | DoTests(); | 
| 145 | r=TheFs.Delete(LogFileName); | |
| 44 | 146 | test(r==KErrNone); | 
| 0 | 147 | r=TheFs.Delete(StartupExeName); | 
| 44 | 148 | test(r==KErrNone); | 
| 0 | 149 | // return file system to original state | 
| 150 | if(oldFsys==0) | |
| 151 | r=TheFs.ControlIo(gSessionPath[0]-'A',KControlIoRuggedOff); | |
| 152 | UserSvr::ResetMachine(EStartupWarmReset); | |
| 153 | return; | |
| 154 | #endif | |
| 155 | #endif | |
| 156 | } | |
| 157 | ||
| 158 |