41 |
42 |
42 TUint8* bufPtr=(TUint8*)testBuf.Ptr(); |
43 TUint8* bufPtr=(TUint8*)testBuf.Ptr(); |
43 testBuf.SetLength(testBuf.MaxSize()); |
44 testBuf.SetLength(testBuf.MaxSize()); |
44 Mem::Fill(bufPtr,testBuf.MaxSize(),aCluster); |
45 Mem::Fill(bufPtr,testBuf.MaxSize(),aCluster); |
45 TInt r=aFile.Write(testBuf); |
46 TInt r=aFile.Write(testBuf); |
46 test(r==KErrNone); |
47 test_KErrNone(r); |
47 } |
48 } |
48 |
49 |
49 LOCAL_C void SeekToCluster(RFile& aFile,TInt aCluster) |
50 LOCAL_C void SeekToCluster(RFile& aFile,TInt aCluster) |
50 // |
51 // |
51 // Seek to aCluster and check it is found correctly |
52 // Seek to aCluster and check it is found correctly |
52 // |
53 // |
53 { |
54 { |
54 TBuf8<508> seekBuf(508); |
55 TBuf8<508> seekBuf(508); |
55 TInt r=aFile.Read(aCluster*testBuf.MaxSize(),seekBuf); |
56 TInt r=aFile.Read(aCluster*testBuf.MaxSize(),seekBuf); |
56 test(r==KErrNone); |
57 test_KErrNone(r); |
57 test(seekBuf[0]==(TUint8)aCluster && seekBuf[507]==(TUint8)aCluster); |
58 test(seekBuf[0]==(TUint8)aCluster && seekBuf[507]==(TUint8)aCluster); |
58 } |
59 } |
59 |
60 |
60 LOCAL_C void SeekToCluster(RFile& aFile,TInt aCluster1,TInt aCluster2) |
61 LOCAL_C void SeekToCluster(RFile& aFile,TInt aCluster1,TInt aCluster2) |
61 // |
62 // |
62 // Seek to aCluster and check it is found correctly |
63 // Seek to aCluster and check it is found correctly |
63 // |
64 // |
64 { |
65 { |
65 TBuf8<508> seekBuf(508); |
66 TBuf8<508> seekBuf(508); |
66 TInt r=aFile.Read(aCluster1*testBuf.MaxSize(),seekBuf); |
67 TInt r=aFile.Read(aCluster1*testBuf.MaxSize(),seekBuf); |
67 test(r==KErrNone); |
68 test_KErrNone(r); |
68 test(seekBuf[0]==(TUint8)aCluster1 && seekBuf[507]==(TUint8)aCluster1); |
69 test(seekBuf[0]==(TUint8)aCluster1 && seekBuf[507]==(TUint8)aCluster1); |
69 r=aFile.Read(aCluster2*testBuf.MaxSize(),seekBuf); |
70 r=aFile.Read(aCluster2*testBuf.MaxSize(),seekBuf); |
70 test(r==KErrNone); |
71 test_KErrNone(r); |
71 test(seekBuf[0]==(TUint8)aCluster2 && seekBuf[507]==(TUint8)aCluster2); |
72 test(seekBuf[0]==(TUint8)aCluster2 && seekBuf[507]==(TUint8)aCluster2); |
72 } |
73 } |
73 |
74 |
74 LOCAL_C void ExhaustiveTest(RFile& aFile,TInt aCount1) |
75 LOCAL_C void ExhaustiveTest(RFile& aFile,TInt aCount1) |
75 // |
76 // |
98 |
99 |
99 test.Next(_L("Create interleaved files")); |
100 test.Next(_L("Create interleaved files")); |
100 RFile f1,f2; |
101 RFile f1,f2; |
101 // |
102 // |
102 TInt r=f1.Replace(TheFs,_L("BIGFILE1.TST"),EFileWrite); |
103 TInt r=f1.Replace(TheFs,_L("BIGFILE1.TST"),EFileWrite); |
103 test(r==KErrNone); |
104 test_KErrNone(r); |
104 r=f2.Replace(TheFs,_L("BIGFILE2.TST"),EFileWrite); |
105 r=f2.Replace(TheFs,_L("BIGFILE2.TST"),EFileWrite); |
105 test(r==KErrNone); |
106 test_KErrNone(r); |
106 // |
107 // |
107 TInt maxListLength=4; |
108 TInt maxListLength=4; |
108 TInt i=0,k=0; |
109 TInt i=0,k=0; |
109 TInt countf1=0; |
110 TInt countf1=0; |
110 TInt countf2=0; |
111 TInt countf2=0; |
161 |
162 |
162 test.Next(_L("Regression Protection")); |
163 test.Next(_L("Regression Protection")); |
163 RFile f1,f2; |
164 RFile f1,f2; |
164 // |
165 // |
165 TInt r=f1.Replace(TheFs,_L("BIGFILE1.TST"),EFileWrite); |
166 TInt r=f1.Replace(TheFs,_L("BIGFILE1.TST"),EFileWrite); |
166 test(r==KErrNone); |
167 test_KErrNone(r); |
167 r=f2.Replace(TheFs,_L("BIGFILE2.TST"),EFileWrite); |
168 r=f2.Replace(TheFs,_L("BIGFILE2.TST"),EFileWrite); |
168 test(r==KErrNone); |
169 test_KErrNone(r); |
169 // |
170 // |
170 WriteCluster(f1,0); |
171 WriteCluster(f1,0); |
171 WriteCluster(f1,1); |
172 WriteCluster(f1,1); |
172 WriteCluster(f1,2); |
173 WriteCluster(f1,2); |
173 WriteCluster(f1,3); |
174 WriteCluster(f1,3); |
215 SeekToCluster(f1,cluster2,cluster1); |
216 SeekToCluster(f1,cluster2,cluster1); |
216 } |
217 } |
217 |
218 |
218 test.Next(_L("Increase Size")); |
219 test.Next(_L("Increase Size")); |
219 r=f1.SetSize(1048577); |
220 r=f1.SetSize(1048577); |
220 test(r==KErrNone || r==KErrDiskFull); |
221 test_Value(r, r == KErrNone || r==KErrDiskFull); |
221 if (r==KErrDiskFull) |
222 if (r==KErrDiskFull) |
222 { |
223 { |
223 test.Printf(_L("File too big\n")); |
224 test.Printf(_L("File too big\n")); |
224 f1.Close(); |
225 f1.Close(); |
225 return; |
226 return; |
249 SeekToCluster(f1,cluster2,cluster1); |
250 SeekToCluster(f1,cluster2,cluster1); |
250 } |
251 } |
251 |
252 |
252 test.Next(_L("Reduce file size")); |
253 test.Next(_L("Reduce file size")); |
253 r=f1.SetSize(135000); |
254 r=f1.SetSize(135000); |
254 test(r==KErrNone); |
255 test_KErrNone(r); |
255 |
256 |
256 test.Next(_L("Test data still present")); |
257 test.Next(_L("Test data still present")); |
257 for (j=0;j<200;j++) |
258 for (j=0;j<200;j++) |
258 { |
259 { |
259 TInt cluster1=Math::Rand(TheSeed)%31; |
260 TInt cluster1=Math::Rand(TheSeed)%31; |
282 // |
283 // |
283 : iFile(*aFile), iPos(0) |
284 : iFile(*aFile), iPos(0) |
284 { |
285 { |
285 |
286 |
286 TInt r=iFile.Read(0,iData); |
287 TInt r=iFile.Read(0,iData); |
287 test(r==KErrNone); |
288 test_KErrNone(r); |
288 } |
289 } |
289 |
290 |
290 void TFileReader::Next(TUint8& aVal,TInt& aLength) |
291 void TFileReader::Next(TUint8& aVal,TInt& aLength) |
291 // |
292 // |
292 // Read aLength contiguous bytes with aVal |
293 // Read aLength contiguous bytes with aVal |
424 |
425 |
425 RFile f[KMaxFiles]; |
426 RFile f[KMaxFiles]; |
426 HBufC8* dataBuf=HBufC8::NewL(KMaxBufferLength); |
427 HBufC8* dataBuf=HBufC8::NewL(KMaxBufferLength); |
427 |
428 |
428 TInt r=f[0].Replace(TheFs,_L("TEST1.DAT"),EFileWrite); |
429 TInt r=f[0].Replace(TheFs,_L("TEST1.DAT"),EFileWrite); |
429 test(r==KErrNone); |
430 test_KErrNone(r); |
430 r=f[1].Replace(TheFs,_L("TEST2.DAT"),EFileWrite); |
431 r=f[1].Replace(TheFs,_L("TEST2.DAT"),EFileWrite); |
431 test(r==KErrNone); |
432 test_KErrNone(r); |
432 r=f[2].Replace(TheFs,_L("TEST3.DAT"),EFileWrite); |
433 r=f[2].Replace(TheFs,_L("TEST3.DAT"),EFileWrite); |
433 test(r==KErrNone); |
434 test_KErrNone(r); |
434 r=f[3].Replace(TheFs,_L("TEST4.DAT"),EFileWrite); |
435 r=f[3].Replace(TheFs,_L("TEST4.DAT"),EFileWrite); |
435 test(r==KErrNone); |
436 test_KErrNone(r); |
436 |
437 |
437 TInt size=0; |
438 TInt size=0; |
438 TInt iteration=0; |
439 TInt iteration=0; |
439 |
440 |
440 FOREVER |
441 FOREVER |
455 { |
456 { |
456 TInt fileNum=(order+i)%KMaxFiles; |
457 TInt fileNum=(order+i)%KMaxFiles; |
457 TInt s=len*mult[fileNum]; |
458 TInt s=len*mult[fileNum]; |
458 TInt filePos=pos*mult[fileNum]; |
459 TInt filePos=pos*mult[fileNum]; |
459 r=f[fileNum].Seek(ESeekStart,filePos); |
460 r=f[fileNum].Seek(ESeekStart,filePos); |
460 test(r==KErrNone); |
461 test_KErrNone(r); |
461 |
462 |
462 while(s>0) |
463 while(s>0) |
463 { |
464 { |
464 TInt l=(s>KMaxBufferLength) ? KMaxBufferLength : s; |
465 TInt l=(s>KMaxBufferLength) ? KMaxBufferLength : s; |
465 dataBuf->Des().SetLength(l); |
466 dataBuf->Des().SetLength(l); |
490 test.Printf(_L("\nReduceSize newsize=%d\n"),size); |
491 test.Printf(_L("\nReduceSize newsize=%d\n"),size); |
491 for (TInt i=0;i<KMaxFiles;i++) |
492 for (TInt i=0;i<KMaxFiles;i++) |
492 { |
493 { |
493 TInt fileNum=(order+i)%KMaxFiles; |
494 TInt fileNum=(order+i)%KMaxFiles; |
494 r=f[fileNum].SetSize(size*mult[fileNum]); |
495 r=f[fileNum].SetSize(size*mult[fileNum]); |
495 test(r==KErrNone); |
496 test_KErrNone(r); |
496 } |
497 } |
497 CheckFileContents(&f[0]); |
498 CheckFileContents(&f[0]); |
498 } |
499 } |
499 } |
500 } |
500 End: |
501 End: |