kerneltest/f32test/server/t_rdsect.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Fri, 14 May 2010 17:13:29 +0300
changeset 109 b3a1d9898418
parent 0 a41df078684a
child 257 3e88ff8f41d5
permissions -rw-r--r--
Revision: 201019 Kit: 201019

// Copyright (c) 1998-2009 Nokia Corporation and/or its subsidiary(-ies).
// All rights reserved.
// This component and the accompanying materials are made available
// under the terms of the License "Eclipse Public License v1.0"
// which accompanies this distribution, and is available
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
//
// Initial Contributors:
// Nokia Corporation - initial contribution.
//
// Contributors:
//
// Description:
// f32test\server\t_rdsect.cpp
// 
//

#define __E32TEST_EXTENSION__

#include <f32file.h>
#include <e32test.h>

#include "t_server.h"
#include "t_chlffs.h"

#if defined(__WINS__)
#define WIN32_LEAN_AND_MEAN
#pragma warning (disable:4201) // warning C4201: nonstandard extension used : nameless struct/union
#pragma warning (default:4201) // warning C4201: nonstandard extension used : nameless struct/union
#endif

#if defined(_UNICODE)
#if !defined(UNICODE)
#define UNICODE
#endif
#endif

GLDEF_D RTest test(_L("T_RDSECT"));


TBuf<26> alphaBuffer=_L("ABCDEFGHIJKLMNOPQRSTUVWXYZ");
TBuf<10> numberBuffer=_L("0123456789");
TBuf<14> humptyBuffer=_L("Humpty-Dumpty!");
TPtr8 alphaPtr((TText8*)alphaBuffer.Ptr(),alphaBuffer.Size(),alphaBuffer.Size());
TPtr8 numberPtr((TText8*)numberBuffer.Ptr(),numberBuffer.Size(),numberBuffer.Size());
TPtr8 humptyPtr((TText8*)humptyBuffer.Ptr(),humptyBuffer.Size(),humptyBuffer.Size());


/*

  What this test is for:

  Tests the implementation of RFs::ReadFileSection() which has been designed
  to allow reading from a file regardless of its lock state.  
  Under the EPOC FAT filesystem, the function accesses the raw file data without 
  opening the file using a share mode.  This is obviously a dangerous activity
  should the file be currently open for writing by another user - but the file
  server makes no guarantees as to the data it returns!  The function allows the
  caller to specify the starting position in the file from which to read the data
  and the length of data required.
  
  This test creates a number of files and tests the use of the function when the 
  files are closed and when they are open in a number of access modes.  
  It also tests reading a UID from the files using this new function.

*/

LOCAL_C void CreateTestFiles()
//
// Create files with uids for testing
//
	{

	test.Next(_L("Create test files"));
	TInt r=TheFs.MkDir(_L("\\F32-TST\\"));
	test_Value(r, r == KErrNone || r==KErrAlreadyExists);

	RFile file;

//	Create \\gSessionPath\\UIDCHK.BLG - with uid no data
	r=file.Replace(TheFs,_L("\\F32-TST\\UIDCHK.BLG"),EFileRead|EFileWrite);
	test_KErrNone(r);
	TUidType uidType(TUid::Uid('U'),TUid::Uid('I'),TUid::Uid('D'));
	TCheckedUid checkedUid(uidType);
	TPtrC8 buf((TUint8*)&checkedUid,sizeof(TCheckedUid));
	r=file.Write(buf);
	test_KErrNone(r);
	file.Close();

//	Create \\gSessionPath\\UIDCHK.MSG - with uid and data
	r=file.Replace(TheFs,_L("\\F32-TST\\UIDCHK.MSG"),EFileRead|EFileWrite);
	test_KErrNone(r);
	TUidType uidType2(TUid::Uid('X'),TUid::Uid('Y'),TUid::Uid('Z'));
	checkedUid.Set(uidType2);
	buf.Set((TUint8*)&checkedUid,sizeof(TCheckedUid));
	r=file.Write(buf);
	test_KErrNone(r);
	r=file.Write(_L8("More file data"));
	test_KErrNone(r);
	file.Close();
	
//	Create \\gSessionPath\\UIDCHK.DAT - uid stored only in the file
	r=file.Replace(TheFs,_L("\\F32-TST\\UIDCHK.DAT"),EFileRead|EFileWrite);
	test_KErrNone(r);
	TUidType uidType3(TUid::Uid('D'),TUid::Uid('A'),TUid::Uid('T'));
	checkedUid.Set(uidType3);
	buf.Set((TUint8*)&checkedUid,sizeof(TCheckedUid));
	r=file.Write(buf);
	test_KErrNone(r);
	r=file.Write(_L8("More file data"));
	test_KErrNone(r);
	file.Close();

//	Make a few random files - these will be deleted before the test begins
//	but are necessary to try to split file ReadFileSection into non-contiguous clusters
	
	r=file.Replace(TheFs,_L("\\F32-TST\\Temp1.txt"),EFileRead|EFileWrite);
	test_KErrNone(r);
	file.SetSize(550);
	file.Close();

	r=file.Replace(TheFs,_L("\\F32-TST\\Temp2.txt"),EFileRead|EFileWrite);
	test_KErrNone(r);
	file.SetSize(256);
	file.Close();

	r=file.Replace(TheFs,_L("\\F32-TST\\Temp3.txt"),EFileRead|EFileWrite);
	test_KErrNone(r);
	file.SetSize(256);
	file.Close();
	
	r=file.Replace(TheFs,_L("\\F32-TST\\Temp4.txt"),EFileRead|EFileWrite);
	test_KErrNone(r);
	file.SetSize(550);
	file.Close();
	
	r=file.Replace(TheFs,_L("\\F32-TST\\Temp5.txt"),EFileRead|EFileWrite);
	test_KErrNone(r);
	file.SetSize(256);
	file.Close();

	r=file.Replace(TheFs,_L("\\F32-TST\\Temp6.txt"),EFileRead|EFileWrite);
	test_KErrNone(r);
	file.SetSize(256);
	file.Close();

	r=file.Replace(TheFs,_L("\\F32-TST\\Temp7.txt"),EFileRead|EFileWrite);
	test_KErrNone(r);
	file.SetSize(256);
	file.Close();

	r=file.Replace(TheFs,_L("\\F32-TST\\Temp8.txt"),EFileRead|EFileWrite);
	test_KErrNone(r);
	file.SetSize(256);
	file.Close();

	r=file.Replace(TheFs,_L("\\F32-TST\\Temp9.txt"),EFileRead|EFileWrite);
	test_KErrNone(r);
	file.SetSize(256);
	file.Close();

	r=file.Replace(TheFs,_L("\\F32-TST\\Temp10.txt"),EFileRead|EFileWrite);
	test_KErrNone(r);
	file.SetSize(256);
	file.Close();

	TheFs.Delete(_L("\\F32-TST\\Temp2.txt"));
	TheFs.Delete(_L("\\F32-TST\\Temp4.txt"));
	TheFs.Delete(_L("\\F32-TST\\Temp6.txt"));
	TheFs.Delete(_L("\\F32-TST\\Temp8.txt"));
	TheFs.Delete(_L("\\F32-TST\\Temp10.txt"));
	
	r=file.Replace(TheFs,_L("\\F32-TST\\ReadFileSection1.txt"),EFileRead|EFileWrite);
	test_KErrNone(r);

//	Write 5000 bytes of nonsense
	
	TInt i=0;
	for ( ; i<100; i++)
		{
		r=file.Write(alphaPtr);
		test_KErrNone(r);
		r=file.Write(numberPtr);
		test_KErrNone(r);
		r=file.Write(humptyPtr);
		test_KErrNone(r);
		}
	
	file.Close();

	TheFs.Delete(_L("\\F32-TST\\Temp1.txt"));
	TheFs.Delete(_L("\\F32-TST\\Temp3.txt"));
	TheFs.Delete(_L("\\F32-TST\\Temp5.txt"));
	TheFs.Delete(_L("\\F32-TST\\Temp7.txt"));
	TheFs.Delete(_L("\\F32-TST\\Temp9.txt"));
	}

#if !defined(_UNICODE)

LOCAL_C void Test1()
//
// Test RFs::ReadFileSection()
//
	{

	test.Next(_L("Use RFs::ReadFileSection() to read from a file"));

//	First, test for non-existant file
	TBuf<256> testDes;
	TInt r=TheFs.ReadFileSection(_L("\\F32-tst\\NonExistantFile.txt"),0,testDes,52);
	test_Value(r, r == KErrNotFound);
	test(testDes.Length()==0);

//	Test with file closed
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),0,testDes,26);
	test_KErrNone(r);
	test(testDes.Length()==26);
	test(testDes==_L("ABCDEFGHIJKLMNOPQRSTUVWXYZ"));
	
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),26,testDes,10);
	test_KErrNone(r);
	test(testDes==_L("0123456789"));
	test(testDes.Length()==10);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),36,testDes,14);
	test_KErrNone(r);
	test(testDes==_L("Humpty-Dumpty!"));
	test(testDes.Length()==14);

//	Test with file open	EFileShareAny|EFileRead
	RFile file;
	r=file.Open(TheFs,_L("\\F32-tst\\ReadFileSection1.txt"),EFileShareAny|EFileRead);
	test_KErrNone(r);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),50,testDes,26);
	test_KErrNone(r);
	test(testDes==_L("ABCDEFGHIJKLMNOPQRSTUVWXYZ"));
	test(testDes.Length()==26);
	
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),76,testDes,10);
	test_KErrNone(r);
	test(testDes==_L("0123456789"));
	test(testDes.Length()==10);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),86,testDes,14);
	test_KErrNone(r);
	test(testDes==_L("Humpty-Dumpty!"));
	test(testDes.Length()==14);
	
	file.Close();

//	Test with file open	EFileShareExclusive|EFileRead
	r=file.Open(TheFs,_L("\\F32-tst\\ReadFileSection1.txt"),EFileShareExclusive|EFileRead);
	test_KErrNone(r);
	
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),100,testDes,26);
	test_KErrNone(r);
	test(testDes==_L("ABCDEFGHIJKLMNOPQRSTUVWXYZ"));
	test(testDes.Length()==26);
	
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),126,testDes,10);
	test_KErrNone(r);
	test(testDes==_L("0123456789"));
	test(testDes.Length()==10);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),136,testDes,14);
	test_KErrNone(r);
	test(testDes==_L("Humpty-Dumpty!"));
	test(testDes.Length()==14);
	
	file.Close();
	
//	Test with file open	EFileShareExclusive|EFileWrite
	r=file.Open(TheFs,_L("\\F32-tst\\ReadFileSection1.txt"),EFileShareExclusive|EFileWrite);	
	test_KErrNone(r);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),150,testDes,26);
	test_KErrNone(r);
	test(testDes==_L("ABCDEFGHIJKLMNOPQRSTUVWXYZ"));
	test(testDes.Length()==26);
	
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),176,testDes,10);
	test_KErrNone(r);
	test(testDes==_L("0123456789"));
	test(testDes.Length()==10);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),186,testDes,14);
	test_KErrNone(r);
	test(testDes==_L("Humpty-Dumpty!"));
	test(testDes.Length()==14);
	
	file.Close();
	

//	Test with file open	EFileShareReadersOnly|EFileRead
	r=file.Open(TheFs,_L("\\F32-tst\\ReadFileSection1.txt"),EFileShareReadersOnly|EFileRead);
	test_KErrNone(r);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),200,testDes,26);
	test_KErrNone(r);
	test(testDes==_L("ABCDEFGHIJKLMNOPQRSTUVWXYZ"));
	test(testDes.Length()==26);
	
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),226,testDes,10);
	test_KErrNone(r);
	test(testDes==_L("0123456789"));
	test(testDes.Length()==10);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),236,testDes,14);
	test_KErrNone(r);
	test(testDes==_L("Humpty-Dumpty!"));
	test(testDes.Length()==14);
	
	file.Close();

//	Test with several accesses to a file EFileShareAny|EFileWrite
	r=file.Open(TheFs,_L("\\F32-tst\\ReadFileSection1.txt"),EFileShareAny|EFileWrite);
	test_KErrNone(r);

	RFile secondFile;
	r=secondFile.Open(TheFs,_L("\\F32-tst\\ReadFileSection1.txt"),EFileShareAny|EFileWrite);
	test_KErrNone(r);
	
	RFile thirdFile;
	r=thirdFile.Open(TheFs,_L("\\F32-tst\\ReadFileSection1.txt"),EFileShareAny|EFileWrite);
	test_KErrNone(r);
	
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),250,testDes,26);
	test_KErrNone(r);
	test(testDes==_L("ABCDEFGHIJKLMNOPQRSTUVWXYZ"));
	test(testDes.Length()==26);
	
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),276,testDes,10);
	test_KErrNone(r);
	test(testDes==_L("0123456789"));
	test(testDes.Length()==10);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),286,testDes,14);
	test_KErrNone(r);
	test(testDes==_L("Humpty-Dumpty!"));
	test(testDes.Length()==14);
	
//	Test across potential cluster boundaries

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),500,testDes,100);
	test_KErrNone(r);
	test(testDes.Length()==100);
	test(testDes==_L("ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789Humpty-Dumpty!ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789Humpty-Dumpty!"));

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),1000,testDes,100);
	test_KErrNone(r);
	test(testDes.Length()==100);
	test(testDes==_L("ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789Humpty-Dumpty!ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789Humpty-Dumpty!"));

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),1500,testDes,100);
	test_KErrNone(r);
	test(testDes.Length()==100);
	test(testDes==_L("ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789Humpty-Dumpty!ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789Humpty-Dumpty!"));

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),2000,testDes,100);
	test_KErrNone(r);
	test(testDes.Length()==100);
	test(testDes==_L("ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789Humpty-Dumpty!ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789Humpty-Dumpty!"));

	file.Close();
	secondFile.Close();
	thirdFile.Close();
	}


LOCAL_C void Test2()
//
// Test RFs::ReadFileSection() on UID reads
//
	{

	
	test.Next(_L("Use RFs::ReadFileSection() to read UIDs from files"));

	TBuf8<sizeof(TCheckedUid)> uidBuf(sizeof(TCheckedUid));
	TPtr uidPtr((TText*)uidBuf.Ptr(),sizeof(TCheckedUid),sizeof(TCheckedUid));
	
	TInt r=TheFs.ReadFileSection(_L("\\F32-TST\\UIDCHK.BLG"),0,uidPtr,sizeof(TCheckedUid));
	test_KErrNone(r);
	TCheckedUid uid(uidBuf);
	TUidType uidType=uid.UidType();
	test(uidType.IsValid());
	
	test(uidType[0]==TUid::Uid('U') && uidType[1]==TUid::Uid('I') && uidType[2]==TUid::Uid('D'));

	r=TheFs.ReadFileSection(_L("\\F32-TST\\UIDCHK.MSG"),0,uidBuf,sizeof(TCheckedUid));
	test_KErrNone(r);
	uid.Set(uidBuf);
	uidType=uid.UidType();
	test(uidType.IsValid());
	test(uidType[0]==TUid::Uid('X') && uidType[1]==TUid::Uid('Y') && uidType[2]==TUid::Uid('Z'));
	
	
	// Test for Null File length
	TBuf8<256> testDesN;
	test.Next(_L("Check for null file name"));
 	r=TheFs.ReadFileSection(_L(""),0,testDesN,26);
 	test_Value(r, r == KErrBadName);
 	
	// Check the lentgh of descriptor.	
 	TInt x = testDesN.Length();
 	test ( x == 0);
 	
 	test.Next(_L("Check for non existing file"));
	r=TheFs.ReadFileSection(_L("sdfsd.dfg"),0,testDesN,26);
 	test.Printf(_L("Return %d"),r);
 	test_Value(r, (r == KErrNotFound) || (r == KErrPathNotFound));
 	
	// Check the lentgh of descriptor.	
 	x = testDesN.Length();
	test ( x == 0);
	
	r=TheFs.ReadFileSection(_L("\\F32-TST\\UIDCHK.DAT"),0,uidBuf,sizeof(TCheckedUid));
	test_KErrNone(r);
	uid.Set(uidBuf);
	uidType=uid.UidType();
	test(uidType.IsValid());
	test(uidType[0]==TUid::Uid('D') && uidType[1]==TUid::Uid('A') && uidType[2]==TUid::Uid('T'));
	

	}

LOCAL_C void Test3()
//
//	Test uid's can be read when the file is open
//
//	EFileShareExclusive,EFileShareReadersOnly,EFileShareAny,
//	EFileStream=0,EFileStreamText=0x100,
//	EFileRead=0,EFileWrite=0x200
//
	{

	test.Next(_L("Test that UIDs can be read from open files"));
	RFile file;
	
//	Test with file open	EFileShareExclusive|EFileRead	
	TInt r=file.Open(TheFs,_L("\\F32-TST\\UIDCHK.DAT"),EFileShareExclusive|EFileRead);
	test_KErrNone(r);

	TBuf8<sizeof(TCheckedUid)> uidBuf;
	
	r=TheFs.ReadFileSection(_L("\\F32-TST\\UIDCHK.DAT"),0,uidBuf,sizeof(TCheckedUid));
	test_KErrNone(r);
	
	TCheckedUid uid(uidBuf);
	TUidType uidType=uid.UidType();
	test(uidType.IsValid());
	test(uidType[0]==TUid::Uid('D') && uidType[1]==TUid::Uid('A') && uidType[2]==TUid::Uid('T'));

	file.Close();

//	Test with file open	EFileShareExclusive|EFileWrite	
	r=file.Open(TheFs,_L("\\F32-TST\\UIDCHK.DAT"),EFileShareExclusive|EFileWrite);
	test_KErrNone(r);

	r=TheFs.ReadFileSection(_L("\\F32-TST\\UIDCHK.DAT"),0,uidBuf,sizeof(TCheckedUid));
	test_KErrNone(r);
	uid.Set(uidBuf);
	uidType=uid.UidType();
	test(uidType.IsValid());
	test(uidType[0]==TUid::Uid('D') && uidType[1]==TUid::Uid('A') && uidType[2]==TUid::Uid('T'));

	file.Close();

//	Test with file open	EFileShareReadersOnly|EFileRead		
	r=file.Open(TheFs,_L("\\F32-TST\\UIDCHK.DAT"),EFileShareReadersOnly|EFileRead);
	test_KErrNone(r);
	
	r=TheFs.ReadFileSection(_L("\\F32-TST\\UIDCHK.DAT"),0,uidBuf,sizeof(TCheckedUid));
	test_KErrNone(r);
	uid.Set(uidBuf);
	uidType=uid.UidType();
	test(uidType.IsValid());
	test(uidType[0]==TUid::Uid('D') && uidType[1]==TUid::Uid('A') && uidType[2]==TUid::Uid('T'));
	
	file.Close();


//	Test with file open	EFileShareAny|EFileRead		
	r=file.Open(TheFs,_L("\\F32-TST\\UIDCHK.DAT"),EFileShareAny|EFileRead);
	test_KErrNone(r);
	
	r=TheFs.ReadFileSection(_L("\\F32-TST\\UIDCHK.DAT"),0,uidBuf,sizeof(TCheckedUid));
	test_KErrNone(r);
	uid.Set(uidBuf);
	uidType=uid.UidType();
	test(uidType.IsValid());
	test(uidType[0]==TUid::Uid('D') && uidType[1]==TUid::Uid('A') && uidType[2]==TUid::Uid('T'));
	
	file.Close();

//	Test with several accesses to file open	EFileShareAny|EFileWrite			
	r=file.Open(TheFs,_L("\\F32-TST\\UIDCHK.DAT"),EFileShareAny|EFileWrite);
	test_KErrNone(r);
	
	RFile secondFile;
	r=secondFile.Open(TheFs,_L("\\F32-TST\\UIDCHK.DAT"),EFileShareAny|EFileWrite);
	test_KErrNone(r);
	
	RFile thirdFile;
	r=thirdFile.Open(TheFs,_L("\\F32-TST\\UIDCHK.DAT"),EFileShareAny|EFileRead);
	test_KErrNone(r);
	
	r=TheFs.ReadFileSection(_L("\\F32-TST\\UIDCHK.DAT"),0,uidBuf,sizeof(TCheckedUid));
	test_KErrNone(r);
	uid.Set(uidBuf);
	uidType=uid.UidType();
	test(uidType.IsValid());
	test(uidType[0]==TUid::Uid('D') && uidType[1]==TUid::Uid('A') && uidType[2]==TUid::Uid('T'));
	
	file.Close();
	secondFile.Close();
	thirdFile.Close();

	}


LOCAL_C void TestErrors()
//
//	Test errors and boundary conditions
//
	{

	test.Next(_L("Test Error handling"));

//	Test that specifying a zero length section returns a zero length descriptor
	TBuf<30> testDes;
	TInt r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),25,testDes,0);
	test_KErrNone(r);
	test(testDes.Length()==0);
	
//	Test that specifying a negative starting position causes a panic
//	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),-1,testDes,10);
//	This will panic: See RFs::ReadFileSection() code - relevant lines are
//	__ASSERT_ALWAYS(aPos>=0,Panic(EPosNegative));
	
//	Test that specifying a section of greater length than the descriptor to
//	hold the data will cause a panic
//	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),0,testDes,45);
//	This will panic: See RFs::ReadFileSection() code - relevant lines are	
//	__ASSERT_ALWAYS(aDes.MaxLength()>=aLength,Panic(EBadLength));

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),2000,testDes,-20);
	test_Value(r, r == KErrArgument);

//	Test that specifying a position and length which extends beyond the end of
//	the	file returns a zero length descriptor and KErrNone

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),4993,testDes,20);
	test_KErrNone(r);	
	test(testDes.Length()==7);
	test(testDes==_L("Dumpty!"));

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),4999,testDes,1);
	test_KErrNone(r);	
	test(testDes.Length()==1);
	test(testDes==_L("!"));

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),5000,testDes,1);
	test_KErrNone(r);	
	test(testDes.Length()==0);
	
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),5550,testDes,20);
	test_KErrNone(r);	
	test(testDes.Length()==0);

//	Test reading the whole file	
	HBufC* hDes=HBufC::New(5002);
	if (!hDes)
		User::Leave(KErrNoMemory);
	TPtr pDes=hDes->Des();

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),0,pDes,5000);
	test_KErrNone(r);	
	test(pDes.Length()==5000);
	
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),0,pDes,5000);
	test_KErrNone(r);	
	test(pDes.Length()==5000);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),0,pDes,5002);
	test_KErrNone(r);	
	test(pDes.Length()==5000);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),2000,pDes,3000);
	test_KErrNone(r);	
	test(pDes.Length()==3000);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),2000,pDes,4002);
	test_KErrNone(r);	
	test(pDes.Length()==3000);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),5000,pDes,5002);
	test_KErrNone(r);	
	test(pDes.Length()==0);
	
	delete hDes;
	}

#else


//	BEGINNING OF UNICODE TESTS

LOCAL_C void TestUnicode()
//
// Test RFs::ReadFileSection()
//
	{
	test.Next(_L("Use RFs::ReadFileSection() to read from a file"));

	//	First, test for non-existant file
	TBuf8<256> testDes;
	TInt r=TheFs.ReadFileSection(_L("\\F32-tst\\NonExistantFile.txt"),0,testDes,52);
	test_Value(r, r == KErrNotFound);
	test(testDes.Length()==0);
	
	//	Test with file closed
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),0,testDes,52);
	test_KErrNone(r);
	test(testDes.Length()==52);
	test(testDes==alphaPtr);
	
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),52,testDes,20);
	test_KErrNone(r);
	test(testDes==numberPtr);
	test(testDes.Length()==20);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),72,testDes,28);
	test_KErrNone(r);
	test(testDes==humptyPtr);
	test(testDes.Length()==28);
	
    //  Test for Null File length
	TBuf8<256> testDesN;
	test.Next(_L("Check for null file name"));
 	r=TheFs.ReadFileSection(_L(""),0,testDesN,26);
 	test_Value(r, r == KErrBadName);
 	
	//  Check the lentgh of descriptor.	
 	TInt x = testDesN.Length();
 	test ( x == 0);
 	
 	test.Next(_L("Check for non existing file"));
	r=TheFs.ReadFileSection(_L("sdfsd.dfg"),0,testDesN,26);
 	test.Printf(_L("Return %d"),r);
 	test_Value(r, (r == KErrNotFound) || (r == KErrPathNotFound));
 	
	//  Check the lentgh of descriptor.	
 	x = testDesN.Length();
	test ( x == 0);

    //  Test for Empty directory  
    r=TheFs.ReadFileSection(_L("\\F32-tst\\"),0,testDesN,52);
    test_Value(r, r == KErrBadName);
    test(testDesN.Length()==0);

    //  Test for File with wildcard name 
    r=TheFs.ReadFileSection(_L("\\F32-tst\\*.txt"),0,testDesN,52);
    test_Value(r, r == KErrBadName);
    test(testDesN.Length()==0);

    //  Test for Folder with wildcard name 
    r=TheFs.ReadFileSection(_L("\\F32-tst*\\ReadFileSection1.txt"),0,testDesN,52);
    test_Value(r, r == KErrBadName);
    test(testDesN.Length()==0);
      
    //  Test for Root directory
    r=TheFs.ReadFileSection(_L("\\"),0,testDesN,52);
    test_Value(r, r == KErrBadName);
    test(testDesN.Length()==0);

    //  Test for no file being specified.
    r=TheFs.ReadFileSection(_L(""),0,testDesN,26);
    test_Value(r, r == KErrBadName);
    test(testDesN.Length()==0); 


    // Test with file open	EFileShareAny|EFileRead
	RFile file;
	r=file.Open(TheFs,_L("\\F32-tst\\ReadFileSection1.txt"),EFileShareAny|EFileRead);
	test_KErrNone(r);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),100,testDes,52);
	test_KErrNone(r);
	test(testDes==alphaPtr);
	test(testDes.Length()==52);
	
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),152,testDes,20);
	test_KErrNone(r);
	test(testDes==numberPtr);
	test(testDes.Length()==20);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),172,testDes,28);
	test_KErrNone(r);
	test(testDes==humptyPtr);
	test(testDes.Length()==28);
	
	file.Close();

//	Test with file open	EFileShareExclusive|EFileRead
	r=file.Open(TheFs,_L("\\F32-tst\\ReadFileSection1.txt"),EFileShareExclusive|EFileRead);
	test_KErrNone(r);
	
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),200,testDes,52);
	test_KErrNone(r);
	test(testDes==alphaPtr);
	test(testDes.Length()==52);
	
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),252,testDes,20);
	test_KErrNone(r);
	test(testDes==numberPtr);
	test(testDes.Length()==20);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),272,testDes,28);
	test_KErrNone(r);
	test(testDes==humptyPtr);
	test(testDes.Length()==28);
	
	file.Close();
	
//	Test with file open	EFileShareExclusive|EFileWrite
	r=file.Open(TheFs,_L("\\F32-tst\\ReadFileSection1.txt"),EFileShareExclusive|EFileWrite);	
	test_KErrNone(r);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),300,testDes,52);
	test_KErrNone(r);
	test(testDes==alphaPtr);
	test(testDes.Length()==52);
	
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),352,testDes,20);
	test_KErrNone(r);
	test(testDes==numberPtr);
	test(testDes.Length()==20);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),372,testDes,28);
	test_KErrNone(r);
	test(testDes==humptyPtr);
	test(testDes.Length()==28);
	
	file.Close();
	

//	Test with file open	EFileShareReadersOnly|EFileRead
	r=file.Open(TheFs,_L("\\F32-tst\\ReadFileSection1.txt"),EFileShareReadersOnly|EFileRead);
	test_KErrNone(r);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),400,testDes,52);
	test_KErrNone(r);
	test(testDes==alphaPtr);
	test(testDes.Length()==52);
	
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),452,testDes,20);
	test_KErrNone(r);
	test(testDes==numberPtr);
	test(testDes.Length()==20);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),472,testDes,28);
	test_KErrNone(r);
	test(testDes==humptyPtr);
	test(testDes.Length()==28);
	
	file.Close();

//	Test with several accesses to a file EFileShareAny|EFileWrite
	r=file.Open(TheFs,_L("\\F32-tst\\ReadFileSection1.txt"),EFileShareAny|EFileWrite);
	test_KErrNone(r);

	RFile secondFile;
	r=secondFile.Open(TheFs,_L("\\F32-tst\\ReadFileSection1.txt"),EFileShareAny|EFileWrite);
	test_KErrNone(r);
	
	RFile thirdFile;
	r=thirdFile.Open(TheFs,_L("\\F32-tst\\ReadFileSection1.txt"),EFileShareAny|EFileWrite);
	test_KErrNone(r);
	
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),500,testDes,52);
	test_KErrNone(r);

#if defined(__WINS__)
#if defined(_DEBUG)
	test(testDes==alphaPtr);
	test(testDes.Length()==52);
#endif
#else
	test(testDes==alphaPtr);
	test(testDes.Length()==52);
#endif
	
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),552,testDes,20);
	test_KErrNone(r);
	test(testDes==numberPtr);
	test(testDes.Length()==20);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),572,testDes,28);
	test_KErrNone(r);
	test(testDes==humptyPtr);
	test(testDes.Length()==28);
	
//	Test across potential cluster boundaries

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),1000,testDes,200);
	test_KErrNone(r);
	test(testDes.Length()==200);
	TBuf8<200> amalgam;
	TInt i=0;
	for (; i<2; i++)
		{
		amalgam.Append(alphaPtr);
		amalgam.Append(numberPtr);
		amalgam.Append(humptyPtr);
		}

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),1000,testDes,200);
	test_KErrNone(r);
	test(testDes.Length()==200);
	test(testDes==amalgam);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),3000,testDes,200);
	test_KErrNone(r);
	test(testDes.Length()==200);
	test(testDes==amalgam);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),4000,testDes,200);
	test_KErrNone(r);
	test(testDes.Length()==200);
	test(testDes==amalgam);

	file.Close();
	secondFile.Close();
	thirdFile.Close();

//	Test errors and boundary conditions
	test.Next(_L("Test Error handling"));

//	Test that specifying a zero length section returns a zero length descriptor
	TBuf8<30> testDes2;
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),50,testDes2,0);
	test_KErrNone(r);
	test(testDes2.Length()==0);
	
//	Test that specifying a negative starting position causes a panic
//	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),-1,testDes2,10);
//	This will panic: See RFs::ReadFileSection() code - relevant lines are
//	__ASSERT_ALWAYS(aPos>=0,Panic(EPosNegative));
	
//	Test that specifying a section of greater length than the descriptor to
//	hold the data will cause a panic
//	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),0,testDes2,45);
//	This will panic: See RFs::ReadFileSection() code - relevant lines are	
//	__ASSERT_ALWAYS(aDes.MaxLength()>=aLength,Panic(EBadLength));


	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),2000,testDes2,-20);
	test_Value(r, r == KErrArgument);

//	Test that specifying a position and length which extends beyond the end of
//	the	file returns a zero length descriptor and KErrNone

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),9993,testDes2,30);
	test_KErrNone(r);	
	test(testDes2.Length()==7);
	test(testDes2==humptyPtr.Right(7));

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),9999,testDes2,1);
	test_KErrNone(r);	
	test(testDes2.Length()==1);
	test(testDes2==humptyPtr.Right(1));

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),10000,testDes2,1);
	test_KErrNone(r);	
	test(testDes2.Length()==0);
	
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),10550,testDes2,20);
	test_KErrNone(r);	
	test(testDes2.Length()==0);

//	Test reading the whole file	
	HBufC8* hDes=HBufC8::New(10002);
	if (!hDes)
		User::Leave(KErrNoMemory);
	TPtr8 pDes=hDes->Des();

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),0,pDes,10000);
	test_KErrNone(r);	
	test(pDes.Length()==10000);
	
	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),0,pDes,10000);
	test_KErrNone(r);	
	test(pDes.Length()==10000);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),0,pDes,10002);
	test_KErrNone(r);	
	test(pDes.Length()==10000);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),4000,pDes,6000);
	test_KErrNone(r);	
	test(pDes.Length()==6000);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),4000,pDes,8002);
	test_KErrNone(r);	
	test(pDes.Length()==6000);

	r=TheFs.ReadFileSection(_L("\\F32-tst\\ReadFileSection1.txt"),10000,pDes,10002);
	test_KErrNone(r);	
	test(pDes.Length()==0);
	
	delete hDes;
	}
	
#endif


LOCAL_C void TestZ()
//
// Test Rom filesystem
//
	{
	test.Next(_L("Use RFs::ReadFileSection() to read from a file on the ROM"));
#if defined (__WINS__)
//	Requires a copy of t_rdsect.txt in z directory (\EPOC32\RELEASE\WINS\BUILD\Z\TEST)
//	Initially, test with file closed
	TBuf8<256> testDes;
	TBuf8<27> temp1;
	TInt r=TheFs.ReadFileSection(_L("Z:\\test\\t_rdsect.txt"),0,temp1,26);
	test_KErrNone(r);
	test(temp1.Length()==26);
	test(temp1==_L8("ABCDEFGHIJKLMNOPQRSTUVWXYZ"));
	
	TBuf8<11> temp2;
	r=TheFs.ReadFileSection(_L("Z:\\test\\t_rdsect.txt"),26,temp2,10);
	test_KErrNone(r);
	test(temp2==_L8("0123456789"));
	test(temp2.Length()==10);

	r=TheFs.ReadFileSection(_L("Z:\\test\\t_rdsect.txt"),36,testDes,14);
	test_KErrNone(r);
	test(testDes==_L8("Humpty-Dumpty!"));
	test(testDes.Length()==14);

//	Test with file open	EFileShareAny|EFileRead
	RFile file;
	r=file.Open(TheFs,_L("Z:\\test\\t_rdsect.txt"),EFileShareAny|EFileRead);
	test_KErrNone(r);
	
	r=TheFs.ReadFileSection(_L("Z:\\test\\t_rdsect.txt"),50,testDes,26);
	test_KErrNone(r);
	test(testDes==_L8("ABCDEFGHIJKLMNOPQRSTUVWXYZ"));
	test(testDes.Length()==26);
	
	r=TheFs.ReadFileSection(_L("Z:\\test\\t_rdsect.txt"),76,testDes,10);
	test_KErrNone(r);
	test(testDes==_L8("0123456789"));
	test(testDes.Length()==10);

	r=TheFs.ReadFileSection(_L("Z:\\test\\t_rdsect.txt"),86,testDes,14);
	test_KErrNone(r);
	test(testDes==_L8("Humpty-Dumpty!"));
	test(testDes.Length()==14);
	
	file.Close();
#else
//	Test for MARM builds - oby file puts file in ROM (z:\test\)
//	The file is the ASCII version

	test.Next(_L("read small descriptor\n"));	
	TBuf8<256> testDes;
	TBuf8<27> temp1;
	TInt r=TheFs.ReadFileSection(_L("Z:\\test\\T_RDSECT.txt"),0,temp1,26);
	test_KErrNone(r);
	test(temp1.Length()==26);	
	test(temp1==_L8("ABCDEFGHIJKLMNOPQRSTUVWXYZ"));
	
	TBuf8<11> temp2;
	r=TheFs.ReadFileSection(_L("Z:\\test\\T_RDSECT.txt"),26,temp2,10);
	test_KErrNone(r);
	test(temp2.Length()==10);
#if !defined (UNICODE)
	test(testDes==_L8("0123456789"));
#endif
	r=TheFs.ReadFileSection(_L("Z:\\test\\T_RDSECT.txt"),36,testDes,14);
	test_KErrNone(r);
	test(testDes.Length()==14);
#if !defined (UNICODE)	
	test(testDes==_L8("Humpty-Dumpty!"));
#endif
	r=TheFs.ReadFileSection(_L("Z:\\test\\T_RDSECT.txt"),50,testDes,26);
	test_KErrNone(r);
	test(testDes.Length()==26);
#if !defined (UNICODE)	
	test(testDes==_L8("ABCDEFGHIJKLMNOPQRSTUVWXYZ"));
#endif
	r=TheFs.ReadFileSection(_L("Z:\\test\\T_RDSECT.txt"),76,testDes,10);
	test_KErrNone(r);
	test(testDes.Length()==10);
#if !defined (UNICODE)	
	test(testDes==_L8("0123456789"));
#endif
	r=TheFs.ReadFileSection(_L("Z:\\test\\T_RDSECT.txt"),86,testDes,14);
	test_KErrNone(r);
	test(testDes.Length()==14);
#if !defined (UNICODE)	
	test(testDes==_L8("Humpty-Dumpty!"));
#endif
#endif
	}

LOCAL_C void DoTestsL()
//
// Do all tests
//
	{
	CreateTestFiles();
#if !defined (_UNICODE)
	Test1();
	Test2();
	Test3();
	TestErrors();
#else
	TestUnicode();
#endif
	TestZ();
	}

GLDEF_C void CallTestsL(void)
//
// Test formatting
//
    {

	test.Title();
	test.Start(_L("Testing filesystem on default drive"));

	TChar driveLetter;
	if (IsSessionDriveLFFS(TheFs,driveLetter))
		{
		test.Printf(_L("CallTestsL: Skipped: test does not run on LFFS.\n"));
		return;
		}	

	DoTestsL();
	CheckDisk();

	test.End();
	test.Close();
	return;
    }