kerneltest/f32test/server/t_ext1.cpp
branchRCL_3
changeset 44 3e88ff8f41d5
parent 43 c1f20ce4abcf
equal deleted inserted replaced
43:c1f20ce4abcf 44:3e88ff8f41d5
    13 // Description:
    13 // Description:
    14 // f32test\ext\t_ext1.cpp
    14 // f32test\ext\t_ext1.cpp
    15 // 
    15 // 
    16 //
    16 //
    17 
    17 
    18 #define __E32TEST_EXTENSION__
       
    19 #include <f32file.h>
    18 #include <f32file.h>
    20 #include <e32test.h>
    19 #include <e32test.h>
    21 #include <e32svr.h>
    20 #include <e32svr.h>
    22 #include "t_server.h"
    21 #include "t_server.h"
    23 #include "f32_test_utils.h"
    22 #include "f32_test_utils.h"
    45 //
    44 //
    46 	{
    45 	{
    47 	test.Next(_L("TestSecondaryExtensions()"));
    46 	test.Next(_L("TestSecondaryExtensions()"));
    48 	TInt drive;
    47 	TInt drive;
    49 	TInt err=RFs::CharToDrive(gDriveToTest,drive);
    48 	TInt err=RFs::CharToDrive(gDriveToTest,drive);
    50 	test_KErrNone(err);
    49 	test(err==KErrNone);
    51 	
    50 	
    52 	TPckgBuf<TBool> drvSyncBuf;
    51 	TPckgBuf<TBool> drvSyncBuf;
    53 	err = TheFs.QueryVolumeInfoExt(drive, EIsDriveSync, drvSyncBuf);
    52 	err = TheFs.QueryVolumeInfoExt(drive, EIsDriveSync, drvSyncBuf);
    54 	test_KErrNone(err);
    53 	test(err==KErrNone);
    55 	const TBool bDrvSync = drvSyncBuf();
    54 	const TBool bDrvSync = drvSyncBuf();
    56 			
    55 			
    57 
    56 
    58 	TFullName fsName;
    57 	TFullName fsName;
    59 	TInt r=TheFs.FileSystemName(fsName,drive);
    58 	TInt r=TheFs.FileSystemName(fsName,drive);
    60 	test_KErrNone(r);
    59 	test(r==KErrNone);
    61 	test.Printf(_L("fsName=%S\n"),&fsName);
    60 	test.Printf(_L("fsName=%S\n"),&fsName);
    62 
    61 
    63 	if (Is_SimulatedSystemDrive(TheFs, drive))
    62 #if defined(__WINS__)
       
    63 	if(drive==EDriveC)
    64 		{
    64 		{
    65 		// check that the extension cannot be mounted since it is not supported by the file system
    65 		// check that the extension cannot be mounted since not supported by the file system
    66 		test.Printf(_L("Test extension cannot be mounted"));
       
    67 		r=TheFs.AddExtension(KExtensionLog);
    66 		r=TheFs.AddExtension(KExtensionLog);
    68 		test_KErrNone(r);
    67 		test(r==KErrNone);
    69 		r=TheFs.MountExtension(KExtensionLogName,drive);
    68 		r=TheFs.MountExtension(KExtensionLogName,drive);
    70 		test_Value(r, r == KErrNotSupported);
    69 		test(r==KErrNotSupported);
    71 		r=TheFs.RemoveExtension(KExtensionLogName);
    70 		r=TheFs.RemoveExtension(KExtensionLogName);
    72 		test_KErrNone(r);
    71 		test(r==KErrNone);
    73 		return;
    72 		return;
    74 		}
    73 		}
       
    74 #endif
    75 
    75 
    76 	test.Next(_L("RFs::AddExtension()"));
    76 	test.Next(_L("RFs::AddExtension()"));
    77 	r=TheFs.AddExtension(KExtensionLog);
    77 	r=TheFs.AddExtension(KExtensionLog);
    78 	RDebug::Print(_L("addext=%d"),r);
    78 	RDebug::Print(_L("addext=%d"),r);
    79 	test_KErrNone(r);
    79 	test(r==KErrNone);
    80 	r=TheFs.AddExtension(KExtensionLog);
    80 	r=TheFs.AddExtension(KExtensionLog);
    81 	test_Value(r, r == KErrAlreadyExists);
    81 	test(r==KErrAlreadyExists);
    82 	r=TheFs.AddExtension(KExtensionRubbish);
    82 	r=TheFs.AddExtension(KExtensionRubbish);
    83 	test_Value(r, r == KErrNotFound);
    83 	test(r==KErrNotFound);
    84 	r=TheFs.AddExtension(KExtensionEmpty);
    84 	r=TheFs.AddExtension(KExtensionEmpty);
    85 	test_KErrNone(r);
    85 	test(r==KErrNone);
    86 
    86 
    87 	test.Next(_L("RFs::MountExtension()"));
    87 	test.Next(_L("RFs::MountExtension()"));
    88 #if !defined(__WINS__)
    88 #if !defined(__WINS__)
    89 	// check that the extension cannot be mounted on file system that does not support extensions
    89 	// check that the extension cannot be mounted on file system that does not support extensions
    90 	r=TheFs.MountExtension(KExtensionLogName,EDriveZ);
    90 	r=TheFs.MountExtension(KExtensionLogName,EDriveZ);
    91 	test_Value(r, r == KErrNotSupported);
    91 	test(r==KErrNotSupported);
    92 #endif
    92 #endif
    93 	// test mounting on drive with no file system
    93 	// test mounting on drive with no file system
    94 	r=TheFs.DismountFileSystem(fsName,drive);
    94 	r=TheFs.DismountFileSystem(fsName,drive);
    95 	test_KErrNone(r);
    95 	test(r==KErrNone);
    96 	r=TheFs.MountExtension(KExtensionLogName,drive);
    96 	r=TheFs.MountExtension(KExtensionLogName,drive);
    97 	test_Value(r, r == KErrNotReady);
    97 	test(r==KErrNotReady);
    98 	r=TheFs.MountFileSystem(fsName,drive,bDrvSync);
    98 	r=TheFs.MountFileSystem(fsName,drive,bDrvSync);
    99 	test_KErrNone(r);
    99 	test(r==KErrNone);
   100 	// test with a resource open
   100 	// test with a resource open
   101 	_LIT(KFileName,"testing.doc");
   101 	_LIT(KFileName,"testing.doc");
   102 	RFile file;
   102 	RFile file;
   103 	r=file.Replace(TheFs,KFileName,EFileShareExclusive);
   103 	r=file.Replace(TheFs,KFileName,EFileShareExclusive);
   104 	test_KErrNone(r);
   104 	test(r==KErrNone);
   105 	r=TheFs.MountExtension(KExtensionLogName,drive);
   105 	r=TheFs.MountExtension(KExtensionLogName,drive);
   106 	test_Value(r, r == KErrInUse);
   106 	test(r==KErrInUse);
   107 	file.Close();
   107 	file.Close();
   108 	r=TheFs.Delete(KFileName);
   108 	r=TheFs.Delete(KFileName);
   109 	test_KErrNone(r);
   109 	test(r==KErrNone);
   110 	// test with a format open
   110 	// test with a format open
   111 	TBuf<4> driveBuf=_L("?:\\");
   111 	TBuf<4> driveBuf=_L("?:\\");
   112 	driveBuf[0]=(TText)(drive+'A');
   112 	driveBuf[0]=(TText)(drive+'A');
   113 	RFormat format;
   113 	RFormat format;
   114 	TInt count;
   114 	TInt count;
   115 	r=format.Open(TheFs,driveBuf,EHighDensity,count);
   115 	r=format.Open(TheFs,driveBuf,EHighDensity,count);
   116 	test_KErrNone(r);
   116 	test(r==KErrNone);
   117 	r=TheFs.MountExtension(KExtensionLogName,drive);
   117 	r=TheFs.MountExtension(KExtensionLogName,drive);
   118 	test_Value(r, r == KErrInUse);
   118 	test(r==KErrInUse);
   119 	format.Close();
   119 	format.Close();
   120 	// get the extension name
   120 	// get the extension name
   121 	TFullName extName;
   121 	TFullName extName;
   122 	r=TheFs.ExtensionName(extName,drive,0);
   122 	r=TheFs.ExtensionName(extName,drive,0);
   123 	test_Value(r, r == KErrNotFound);
   123 	test(r==KErrNotFound);
   124 	// now load the extension
   124 	// now load the extension
   125 	r=TheFs.MountExtension(KExtensionLogName,drive);
   125 	r=TheFs.MountExtension(KExtensionLogName,drive);
   126 	test_KErrNone(r);
   126 	test(r==KErrNone);
   127 	r=TheFs.ExtensionName(extName,drive,0);
   127 	r=TheFs.ExtensionName(extName,drive,0);
   128 	test_Value(r, r == KErrNone && extName==KExtensionLogName);
   128 	test(r==KErrNone && extName==KExtensionLogName);
   129 	r=TheFs.ExtensionName(extName,drive,1);
   129 	r=TheFs.ExtensionName(extName,drive,1);
   130 	test_Value(r, r == KErrNotFound);
   130 	test(r==KErrNotFound);
   131 	// try remounting the same extension
   131 	// try remounting the same extension
   132 	r=TheFs.MountExtension(KExtensionLogName,drive);
   132 	r=TheFs.MountExtension(KExtensionLogName,drive);
   133 	test_Value(r, r == KErrAlreadyExists);
   133 	test(r==KErrAlreadyExists);
   134 	// mount a second extension
   134 	// mount a second extension
   135 	r=TheFs.MountExtension(KExtensionEmptyName,drive);
   135 	r=TheFs.MountExtension(KExtensionEmptyName,drive);
   136 	test_KErrNone(r);
   136 	test(r==KErrNone);
   137 	r=TheFs.ExtensionName(extName,drive,0);
   137 	r=TheFs.ExtensionName(extName,drive,0);
   138 	test_Value(r, r == KErrNone && extName==KExtensionLogName);
   138 	test(r==KErrNone && extName==KExtensionLogName);
   139 	r=TheFs.ExtensionName(extName,drive,1);
   139 	r=TheFs.ExtensionName(extName,drive,1);
   140 	test_Value(r, r == KErrNone && extName==KExtensionEmptyName);
   140 	test(r==KErrNone && extName==KExtensionEmptyName);
   141 	
   141 	
   142     // force a remount on a removable media and check that extensions both exist
   142     // force a remount on a removable media and check that extensions both exist
   143     test.Printf(_L("Test forcing remount\n"));
   143     test.Printf(_L("Test forcing remount\n"));
   144     TDriveInfo info;
   144     TDriveInfo info;
   145 	r=TheFs.Drive(info,drive);
   145 	r=TheFs.Drive(info,drive);
   151         TRequestStatus changeStatus;
   151         TRequestStatus changeStatus;
   152         TheFs.NotifyChange(ENotifyAll, changeStatus);
   152         TheFs.NotifyChange(ENotifyAll, changeStatus);
   153 
   153 
   154         test.Printf(_L("Remounting the drive\n"), r);
   154         test.Printf(_L("Remounting the drive\n"), r);
   155         r = TheFs.RemountDrive(drive, NULL, (TUint) KMediaRemountForceMediaChange);
   155         r = TheFs.RemountDrive(drive, NULL, (TUint) KMediaRemountForceMediaChange);
   156         test_Value(r, r == KErrNotReady || r == KErrNone);
   156         test(r == KErrNotReady || r == KErrNone);
   157         
   157         
   158         do
   158         do
   159         {
   159         {
   160         test.Printf(_L("Waiting for media change...\n"));
   160         test.Printf(_L("Waiting for media change...\n"));
   161         User::WaitForRequest(changeStatus);
   161         User::WaitForRequest(changeStatus);
   179 
   179 
   180         test.Printf(_L("Force media change\n"));
   180         test.Printf(_L("Force media change\n"));
   181     	RLocalDrive d;
   181     	RLocalDrive d;
   182 		TBool flag=EFalse;
   182 		TBool flag=EFalse;
   183 		r=d.Connect(1,flag);
   183 		r=d.Connect(1,flag);
   184 		test_KErrNone(r);
   184 		test(r==KErrNone);
   185 		d.ForceMediaChange();
   185 		d.ForceMediaChange();
   186 		d.Close();
   186 		d.Close();
   187 //#if defined(__WINS__)
   187 //#if defined(__WINS__)
   188 		// ??? seems to work, find out why
   188 		// ??? seems to work, find out why
   189 		//User::After(500000);
   189 		//User::After(500000);
   193 		}
   193 		}
   194 
   194 
   195 
   195 
   196 
   196 
   197 	r=TheFs.ExtensionName(extName,drive,0);
   197 	r=TheFs.ExtensionName(extName,drive,0);
   198 	test_Value(r, r == KErrNone && extName==KExtensionLogName);
   198 	test(r==KErrNone && extName==KExtensionLogName);
   199 	r=TheFs.ExtensionName(extName,drive,1);
   199 	r=TheFs.ExtensionName(extName,drive,1);
   200 	test_Value(r, r == KErrNone && extName==KExtensionEmptyName);
   200 	test(r==KErrNone && extName==KExtensionEmptyName);
   201 
   201 
   202     test.Printf(_L("Accessing media...\n"));
   202     test.Printf(_L("Accessing media...\n"));
   203 	// and now do some file system operations
   203 	// and now do some file system operations
   204 	TBuf8<16> readBuf;
   204 	TBuf8<16> readBuf;
   205 	r=TheFs.MkDir(dir1);
   205 	r=TheFs.MkDir(dir1);
   206     
   206     
   207     test.Printf(_L("res=%d\n"), r);
   207     test.Printf(_L("res=%d\n"), r);
   208 
   208 
   209 
   209 
   210 	test_Value(r, r == KErrNone||r==KErrAlreadyExists);
   210 	test(r==KErrNone||r==KErrAlreadyExists);
   211 	RFile file1;
   211 	RFile file1;
   212 	r=file1.Replace(TheFs,file1Name,EFileShareExclusive);
   212 	r=file1.Replace(TheFs,file1Name,EFileShareExclusive);
   213 	test_KErrNone(r);
   213 	test(r==KErrNone);
   214 	r=file1.Write(toWrite);
   214 	r=file1.Write(toWrite);
   215 	test_KErrNone(r);
   215 	test(r==KErrNone);
   216 	r=file1.Read(0,readBuf);
   216 	r=file1.Read(0,readBuf);
   217 	test(readBuf==toWrite);
   217 	test(readBuf==toWrite);
   218 	r=file1.SetSize(0);
   218 	r=file1.SetSize(0);
   219 	test_KErrNone(r);
   219 	test(r==KErrNone);
   220 	file1.Close();
   220 	file1.Close();
   221 	r=TheFs.Delete(file1Name);
   221 	r=TheFs.Delete(file1Name);
   222 	test_KErrNone(r);
   222 	test(r==KErrNone);
   223 	r=TheFs.RmDir(dir1);
   223 	r=TheFs.RmDir(dir1);
   224 	test_KErrNone(r);
   224 	test(r==KErrNone);
   225 
   225 
   226 	test.Next(_L("RFs::DismountExtension()"));
   226 	test.Next(_L("RFs::DismountExtension()"));
   227 	// test with a resource open
   227 	// test with a resource open
   228 	r=file.Replace(TheFs,KFileName,EFileShareExclusive);
   228 	r=file.Replace(TheFs,KFileName,EFileShareExclusive);
   229 	test_KErrNone(r);
   229 	test(r==KErrNone);
   230 	r=TheFs.DismountExtension(KExtensionLogName,drive);
   230 	r=TheFs.DismountExtension(KExtensionLogName,drive);
   231 	test_Value(r, r == KErrInUse);
   231 	test(r==KErrInUse);
   232 	file.Close();
   232 	file.Close();
   233 	r=TheFs.Delete(KFileName);
   233 	r=TheFs.Delete(KFileName);
   234 	test_KErrNone(r);
   234 	test(r==KErrNone);
   235 	// test with a format open
   235 	// test with a format open
   236 	r=format.Open(TheFs,driveBuf,EHighDensity,count);
   236 	r=format.Open(TheFs,driveBuf,EHighDensity,count);
   237 	test_KErrNone(r);
   237 	test(r==KErrNone);
   238 	r=TheFs.DismountExtension(KExtensionLogName,drive);
   238 	r=TheFs.DismountExtension(KExtensionLogName,drive);
   239 	test_Value(r, r == KErrInUse);
   239 	test(r==KErrInUse);
   240 	format.Close();
   240 	format.Close();
   241 	// now dismount an extension
   241 	// now dismount an extension
   242 	r=TheFs.DismountExtension(KExtensionLogName,drive);
   242 	r=TheFs.DismountExtension(KExtensionLogName,drive);
   243 	test_KErrNone(r);
   243 	test(r==KErrNone);
   244 	r=TheFs.ExtensionName(extName,drive,0);
   244 	r=TheFs.ExtensionName(extName,drive,0);
   245 	test_Value(r, r == KErrNone && extName==KExtensionEmptyName);
   245 	test(r==KErrNone && extName==KExtensionEmptyName);
   246 	r=TheFs.ExtensionName(extName,drive,1);
   246 	r=TheFs.ExtensionName(extName,drive,1);
   247 	test_Value(r, r == KErrNotFound);
   247 	test(r==KErrNotFound);
   248 	// try to dismount an extension that is not mounted
   248 	// try to dismount an extension that is not mounted
   249 	r=TheFs.DismountExtension(KExtensionLogName,drive);
   249 	r=TheFs.DismountExtension(KExtensionLogName,drive);
   250 	test_Value(r, r == KErrNotFound);
   250 	test(r==KErrNotFound);
   251 	r=TheFs.ExtensionName(extName,drive,0);
   251 	r=TheFs.ExtensionName(extName,drive,0);
   252 	test_Value(r, r == KErrNone && extName==KExtensionEmptyName);
   252 	test(r==KErrNone && extName==KExtensionEmptyName);
   253 	r=TheFs.ExtensionName(extName,drive,1);
   253 	r=TheFs.ExtensionName(extName,drive,1);
   254 	test_Value(r, r == KErrNotFound);
   254 	test(r==KErrNotFound);
   255 	// dismount the remaining extension
   255 	// dismount the remaining extension
   256 	r=TheFs.DismountExtension(KExtensionEmptyName,drive);
   256 	r=TheFs.DismountExtension(KExtensionEmptyName,drive);
   257 	test_KErrNone(r);
   257 	test(r==KErrNone);
   258 	r=TheFs.ExtensionName(extName,drive,0);
   258 	r=TheFs.ExtensionName(extName,drive,0);
   259 	test_Value(r, r == KErrNotFound);
   259 	test(r==KErrNotFound);
   260 	r=TheFs.ExtensionName(extName,drive,1);
   260 	r=TheFs.ExtensionName(extName,drive,1);
   261 	test_Value(r, r == KErrNotFound);
   261 	test(r==KErrNotFound);
   262 
   262 
   263 	test.Next(_L("RFs::RemoveExtension()"));
   263 	test.Next(_L("RFs::RemoveExtension()"));
   264 	r=TheFs.RemoveExtension(KExtensionLogName);
   264 	r=TheFs.RemoveExtension(KExtensionLogName);
   265 	test_KErrNone(r);
   265 	test(r==KErrNone);
   266 	r=TheFs.RemoveExtension(KExtensionEmptyName);
   266 	r=TheFs.RemoveExtension(KExtensionEmptyName);
   267 	test_KErrNone(r);
   267 	test(r==KErrNone);
   268 	}
   268 	}
   269 
   269 
   270 void TestPrimaryExtensions()
   270 void TestPrimaryExtensions()
   271 //
   271 //
   272 // a primary extension is one that is added to a drive before a file system is mounted
   272 // a primary extension is one that is added to a drive before a file system is mounted
   274 //
   274 //
   275 	{
   275 	{
   276 	test.Next(_L("TestPrimaryExtensions()"));
   276 	test.Next(_L("TestPrimaryExtensions()"));
   277 	TInt drive;
   277 	TInt drive;
   278 	TInt err=RFs::CharToDrive(gDriveToTest,drive);
   278 	TInt err=RFs::CharToDrive(gDriveToTest,drive);
   279 	test_KErrNone(err);
   279 	test(err==KErrNone);
   280 
   280 
   281 	if(Is_SimulatedSystemDrive(TheFs, drive))
   281 #if defined(__WINS__)
   282 	    {
   282 	if(drive==EDriveC)
   283 		test.Printf(_L("Skipping TestPrimaryExtensions on PlatSim/Emulator drive %C:\n"), gSessionPath[0]);
       
   284 		return;
   283 		return;
   285 	    }
   284 #endif
   286 
   285 
   287 	TPckgBuf<TBool> drvSyncBuf;
   286 	TPckgBuf<TBool> drvSyncBuf;
   288 	err = TheFs.QueryVolumeInfoExt(drive, EIsDriveSync, drvSyncBuf);
   287 	err = TheFs.QueryVolumeInfoExt(drive, EIsDriveSync, drvSyncBuf);
   289 	test_KErrNone(err);
   288 	test(err==KErrNone);
   290     const TBool bDrvSync = drvSyncBuf();
   289     const TBool bDrvSync = drvSyncBuf();
   291 
   290 
   292 	// don't test on ram drive since accesses memory directly
   291 	// don't test on ram drive since accesses memory directly
   293 	TDriveInfo info;
   292 	TDriveInfo info;
   294 	TInt r=TheFs.Drive(info,drive);
   293 	TInt r=TheFs.Drive(info,drive);
   295 	if(info.iMediaAtt&KMediaAttVariableSize)
   294 	if(info.iMediaAtt&KMediaAttVariableSize)
   296 		return;
   295 		return;
   297 
   296 
   298 	TFullName fsName;
   297 	TFullName fsName;
   299 	r=TheFs.FileSystemName(fsName,drive);
   298 	r=TheFs.FileSystemName(fsName,drive);
   300 	test_KErrNone(r);
   299 	test(r==KErrNone);
   301 	test.Printf(_L("fsName=%S\n"),&fsName);
   300 	test.Printf(_L("fsName=%S\n"),&fsName);
   302 
   301 
   303 	test.Next(_L("RFs::AddExtension()"));
   302 	test.Next(_L("RFs::AddExtension()"));
   304 	r=TheFs.AddExtension(KExtensionLog);
   303 	r=TheFs.AddExtension(KExtensionLog);
   305 	test_KErrNone(r);
   304 	test(r==KErrNone);
   306 	r=TheFs.AddExtension(KExtensionEmpty);
   305 	r=TheFs.AddExtension(KExtensionEmpty);
   307 	test_KErrNone(r);
   306 	test(r==KErrNone);
   308 	r=TheFs.AddExtension(KExtensionBit);
   307 	r=TheFs.AddExtension(KExtensionBit);
   309 	test_KErrNone(r);
   308 	test(r==KErrNone);
   310 
   309 
   311 	test.Next(_L("RFs::MountFileSystem()"));
   310 	test.Next(_L("RFs::MountFileSystem()"));
   312 	// test with file system that already exists
   311 	// test with file system that already exists
   313 	r=TheFs.MountFileSystem(fsName,KExtensionBitName,drive,bDrvSync);
   312 	r=TheFs.MountFileSystem(fsName,KExtensionBitName,drive,bDrvSync);
   314 	test_Value(r, r == KErrAccessDenied);
   313 	test(r==KErrAccessDenied);
   315 	// unmount drive and mount primary extension along with file system
   314 	// unmount drive and mount primary extension along with file system
   316 	r=TheFs.DismountFileSystem(fsName,drive);
   315 	r=TheFs.DismountFileSystem(fsName,drive);
   317 	test_KErrNone(r);
   316 	test(r==KErrNone);
   318 
   317 
   319     //-- !! N.B this extension mangles data read/written ftom/to the media, for some file systems it is OK and mounting succeeds
   318     //-- !! N.B this extension mangles data read/written ftom/to the media, for some file systems it is OK and mounting succeeds
   320     //-- for others - this will result in KErrCorrupt
   319     //-- for others - this will result in KErrCorrupt
   321 	r=TheFs.MountFileSystem(fsName,KExtensionBitName,drive,bDrvSync);
   320 	r=TheFs.MountFileSystem(fsName,KExtensionBitName,drive,bDrvSync);
   322 	test_Value(r, r == KErrNone||r==KErrCorrupt);
   321 	test(r==KErrNone||r==KErrCorrupt);
   323 	
   322 	
   324     // and now format
   323     // and now format
   325 	Format(drive);
   324 	Format(drive);
   326 	TFullName extName;
   325 	TFullName extName;
   327 	r=TheFs.ExtensionName(extName,drive,0);
   326 	r=TheFs.ExtensionName(extName,drive,0);
   328 	test_Value(r, r == KErrNone && extName==KExtensionBitName);
   327 	test(r==KErrNone && extName==KExtensionBitName);
   329 	r=TheFs.ExtensionName(extName,drive,1);
   328 	r=TheFs.ExtensionName(extName,drive,1);
   330 	test_Value(r, r == KErrNotFound);
   329 	test(r==KErrNotFound);
   331 	
   330 	
   332 	// and now do some file system operations
   331 	// and now do some file system operations
   333 	TBuf8<16> readBuf;
   332 	TBuf8<16> readBuf;
   334 	r=TheFs.MkDir(dir1);
   333 	r=TheFs.MkDir(dir1);
   335 	test_Value(r, r == KErrNone||r==KErrAlreadyExists);
   334 	test(r==KErrNone||r==KErrAlreadyExists);
   336 	RFile file1;
   335 	RFile file1;
   337 	r=file1.Replace(TheFs,file1Name,EFileShareExclusive);
   336 	r=file1.Replace(TheFs,file1Name,EFileShareExclusive);
   338 	test_KErrNone(r);
   337 	test(r==KErrNone);
   339 	r=file1.Write(toWrite);
   338 	r=file1.Write(toWrite);
   340 	test_KErrNone(r);
   339 	test(r==KErrNone);
   341 	r=file1.Read(0,readBuf);
   340 	r=file1.Read(0,readBuf);
   342 	test(readBuf==toWrite);
   341 	test(readBuf==toWrite);
   343 	r=file1.SetSize(0);
   342 	r=file1.SetSize(0);
   344 	test_KErrNone(r);
   343 	test(r==KErrNone);
   345 	file1.Close();
   344 	file1.Close();
   346 	r=TheFs.Delete(file1Name);
   345 	r=TheFs.Delete(file1Name);
   347 	test_KErrNone(r);
   346 	test(r==KErrNone);
   348 	r=TheFs.RmDir(dir1);
   347 	r=TheFs.RmDir(dir1);
   349 	test_KErrNone(r);
   348 	test(r==KErrNone);
   350 
   349 
   351 	// add a secondary extension
   350 	// add a secondary extension
   352 	test.Printf(_L("RFs::MountExtension()"));
   351 	test.Printf(_L("RFs::MountExtension()"));
   353 	r=TheFs.MountExtension(KExtensionLogName,drive);
   352 	r=TheFs.MountExtension(KExtensionLogName,drive);
   354 	test_KErrNone(r);
   353 	test(r==KErrNone);
   355 	r=TheFs.ExtensionName(extName,drive,0);
   354 	r=TheFs.ExtensionName(extName,drive,0);
   356 	test_Value(r, r == KErrNone && extName==KExtensionBitName);
   355 	test(r==KErrNone && extName==KExtensionBitName);
   357 	r=TheFs.ExtensionName(extName,drive,1);
   356 	r=TheFs.ExtensionName(extName,drive,1);
   358 	test_Value(r, r == KErrNone && extName==KExtensionLogName);
   357 	test(r==KErrNone && extName==KExtensionLogName);
   359 	// try to add the same extension
   358 	// try to add the same extension
   360 	r=TheFs.MountExtension(KExtensionBitName,drive);
   359 	r=TheFs.MountExtension(KExtensionBitName,drive);
   361 	test_Value(r, r == KErrAlreadyExists);
   360 	test(r==KErrAlreadyExists);
   362 	r=TheFs.ExtensionName(extName,drive,0);
   361 	r=TheFs.ExtensionName(extName,drive,0);
   363 	test_Value(r, r == KErrNone && extName==KExtensionBitName);
   362 	test(r==KErrNone && extName==KExtensionBitName);
   364 	r=TheFs.ExtensionName(extName,drive,1);
   363 	r=TheFs.ExtensionName(extName,drive,1);
   365 	test_Value(r, r == KErrNone && extName==KExtensionLogName);
   364 	test(r==KErrNone && extName==KExtensionLogName);
   366 	// try to add a third extension
   365 	// try to add a third extension
   367 	r=TheFs.MountExtension(KExtensionEmptyName,drive);
   366 	r=TheFs.MountExtension(KExtensionEmptyName,drive);
   368 	test_Value(r, r == KErrAccessDenied);
   367 	test(r==KErrAccessDenied);
   369 	r=TheFs.ExtensionName(extName,drive,0);
   368 	r=TheFs.ExtensionName(extName,drive,0);
   370 	test_Value(r, r == KErrNone && extName==KExtensionBitName);
   369 	test(r==KErrNone && extName==KExtensionBitName);
   371 	r=TheFs.ExtensionName(extName,drive,1);
   370 	r=TheFs.ExtensionName(extName,drive,1);
   372 	test_Value(r, r == KErrNone && extName==KExtensionLogName);
   371 	test(r==KErrNone && extName==KExtensionLogName);
   373 
   372 
   374 	// and now do some file system operations
   373 	// and now do some file system operations
   375 	r=TheFs.MkDir(dir1);
   374 	r=TheFs.MkDir(dir1);
   376 	test_Value(r, r == KErrNone||r==KErrAlreadyExists);
   375 	test(r==KErrNone||r==KErrAlreadyExists);
   377 	r=file1.Replace(TheFs,file1Name,EFileShareExclusive);
   376 	r=file1.Replace(TheFs,file1Name,EFileShareExclusive);
   378 	test_KErrNone(r);
   377 	test(r==KErrNone);
   379 	r=file1.Write(toWrite);
   378 	r=file1.Write(toWrite);
   380 	test_KErrNone(r);
   379 	test(r==KErrNone);
   381 	r=file1.Read(0,readBuf);
   380 	r=file1.Read(0,readBuf);
   382 	test(readBuf==toWrite);
   381 	test(readBuf==toWrite);
   383 	r=file1.SetSize(0);
   382 	r=file1.SetSize(0);
   384 	test_KErrNone(r);
   383 	test(r==KErrNone);
   385 	file1.Close();
   384 	file1.Close();
   386 	r=TheFs.Delete(file1Name);
   385 	r=TheFs.Delete(file1Name);
   387 	test_KErrNone(r);
   386 	test(r==KErrNone);
   388 	r=TheFs.RmDir(dir1);
   387 	r=TheFs.RmDir(dir1);
   389 	test_KErrNone(r);
   388 	test(r==KErrNone);
   390 
   389 
   391 	test.Printf(_L("RFs::DismountExtension()"));
   390 	test.Printf(_L("RFs::DismountExtension()"));
   392 	// test that can't dismount a primary extension via this method
   391 	// test that can't dismount a primary extension via this method
   393 	r=TheFs.DismountExtension(KExtensionLogName,drive);
   392 	r=TheFs.DismountExtension(KExtensionLogName,drive);
   394 	test_KErrNone(r);
   393 	test(r==KErrNone);
   395 	r=TheFs.ExtensionName(extName,drive,0);
   394 	r=TheFs.ExtensionName(extName,drive,0);
   396 	test_Value(r, r == KErrNone && extName==KExtensionBitName);
   395 	test(r==KErrNone && extName==KExtensionBitName);
   397 	r=TheFs.ExtensionName(extName,drive,1);
   396 	r=TheFs.ExtensionName(extName,drive,1);
   398 	test_Value(r, r == KErrNotFound);
   397 	test(r==KErrNotFound);
   399 	r=TheFs.DismountExtension(KExtensionBitName,drive);
   398 	r=TheFs.DismountExtension(KExtensionBitName,drive);
   400 	test_Value(r, r == KErrAccessDenied);
   399 	test(r==KErrAccessDenied);
   401 	r=TheFs.ExtensionName(extName,drive,0);
   400 	r=TheFs.ExtensionName(extName,drive,0);
   402 	test_Value(r, r == KErrNone && extName==KExtensionBitName);
   401 	test(r==KErrNone && extName==KExtensionBitName);
   403 	r=TheFs.ExtensionName(extName,drive,1);
   402 	r=TheFs.ExtensionName(extName,drive,1);
   404 	test_Value(r, r == KErrNotFound);
   403 	test(r==KErrNotFound);
   405 	
   404 	
   406 	test.Printf(_L("RFs::DismountFileSystem()"));
   405 	test.Printf(_L("RFs::DismountFileSystem()"));
   407 	r=TheFs.MountExtension(KExtensionLogName,drive);
   406 	r=TheFs.MountExtension(KExtensionLogName,drive);
   408 	test_KErrNone(r);
   407 	test(r==KErrNone);
   409 	r=TheFs.ExtensionName(extName,drive,0);
   408 	r=TheFs.ExtensionName(extName,drive,0);
   410 	test_Value(r, r == KErrNone && extName==KExtensionBitName);
   409 	test(r==KErrNone && extName==KExtensionBitName);
   411 	r=TheFs.ExtensionName(extName,drive,1);
   410 	r=TheFs.ExtensionName(extName,drive,1);
   412 	test_Value(r, r == KErrNone && extName==KExtensionLogName);
   411 	test(r==KErrNone && extName==KExtensionLogName);
   413 	// and now dismount
   412 	// and now dismount
   414 	r=TheFs.DismountFileSystem(fsName,drive);
   413 	r=TheFs.DismountFileSystem(fsName,drive);
   415 	test_KErrNone(r);
   414 	test(r==KErrNone);
   416 	r=TheFs.ExtensionName(extName,drive,0);
   415 	r=TheFs.ExtensionName(extName,drive,0);
   417 	test_Value(r, r == KErrNotReady);
   416 	test(r==KErrNotReady);
   418 	r=TheFs.ExtensionName(extName,drive,1);
   417 	r=TheFs.ExtensionName(extName,drive,1);
   419 	test_Value(r, r == KErrNotReady);
   418 	test(r==KErrNotReady);
   420 	// remount the file system
   419 	// remount the file system
   421 	r=TheFs.MountFileSystem(fsName,drive,bDrvSync);
   420 	r=TheFs.MountFileSystem(fsName,drive,bDrvSync);
   422 	test_Value(r, r == KErrNone||r==KErrCorrupt);
   421 	test(r==KErrNone||r==KErrCorrupt);
   423 	r=TheFs.ExtensionName(extName,drive,0);
   422 	r=TheFs.ExtensionName(extName,drive,0);
   424 	test_Value(r, r == KErrNotFound);
   423 	test(r==KErrNotFound);
   425 	r=TheFs.ExtensionName(extName,drive,1);
   424 	r=TheFs.ExtensionName(extName,drive,1);
   426 	test_Value(r, r == KErrNotFound);
   425 	test(r==KErrNotFound);
   427 	Format(drive);
   426 	Format(drive);
   428 
   427 
   429 	test.Next(_L("RFs::RemoveExtension()"));
   428 	test.Next(_L("RFs::RemoveExtension()"));
   430 	r=TheFs.RemoveExtension(KExtensionLogName);
   429 	r=TheFs.RemoveExtension(KExtensionLogName);
   431 	test_KErrNone(r);
   430 	test(r==KErrNone);
   432 	r=TheFs.RemoveExtension(KExtensionEmptyName);
   431 	r=TheFs.RemoveExtension(KExtensionEmptyName);
   433 	test_KErrNone(r);
   432 	test(r==KErrNone);
   434 	r=TheFs.RemoveExtension(KExtensionBitName);
   433 	r=TheFs.RemoveExtension(KExtensionBitName);
   435 	test_KErrNone(r);
   434 	test(r==KErrNone);
   436 	}
   435 	}
   437 
   436 
   438 
   437 
   439 GLDEF_C void CallTestsL()
   438 GLDEF_C void CallTestsL()
   440 //
   439 //
   445     F32_Test_Utils::SetConsole(test.Console()); 
   444     F32_Test_Utils::SetConsole(test.Console()); 
   446 	
   445 	
   447     TInt drive;
   446     TInt drive;
   448 	TInt err=RFs::CharToDrive(gDriveToTest,drive);
   447 	TInt err=RFs::CharToDrive(gDriveToTest,drive);
   449 	test.Start(_L("Starting Test - T_EXT1"));
   448 	test.Start(_L("Starting Test - T_EXT1"));
   450 	test_KErrNone(err);
   449 	test(err==KErrNone);
   451 
   450 
   452 	// Check that the drive supports extensions.
       
   453 	TBool extensionsSupported = EFalse;
       
   454 	TPckg<TBool> dataBuf(extensionsSupported);
       
   455 	err = TheFs.QueryVolumeInfoExt(drive,EFSysExtensionsSupported,dataBuf);
       
   456 	test_KErrNone(err);
       
   457 	if(!extensionsSupported)
       
   458 	    {
       
   459         test.Printf(_L("Drive %C: does not support file sys extensions. Skipping T_EXT1."), gSessionPath[0]);
       
   460         test.End();
       
   461         test.Close();
       
   462         return;
       
   463 	    }
       
   464 	
       
   465     PrintDrvInfo(TheFs, drive);
   451     PrintDrvInfo(TheFs, drive);
   466 
   452 
   467 //Do not run this test on the NAND drive, as
   453 //Do not run this test on the NAND drive, as
   468 //this has the FTL mounted as a primary extension
   454 //this has the FTL mounted as a primary extension
   469 //which causes the test to fail
   455 //which causes the test to fail
   473 #else
   459 #else
   474 	TDriveInfo driveInfo;
   460 	TDriveInfo driveInfo;
   475 	TheFs.Drive(driveInfo,drive);
   461 	TheFs.Drive(driveInfo,drive);
   476 	if (driveInfo.iType == EMediaNANDFlash)
   462 	if (driveInfo.iType == EMediaNANDFlash)
   477 		{
   463 		{
   478 		test.Printf(_L("Skipping T_EXT1 as drive %C: is NAND\n"), gSessionPath[0]);
       
   479 		return;
   464 		return;
   480 		}
   465 		}
   481 #endif
   466 #endif
   482 	TestSecondaryExtensions();
   467 	TestSecondaryExtensions();
   483 
   468