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); |
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 // |