diff -r 000000000000 -r 96e5fb8b040d kerneltest/f32test/server/t_dctcbdiskadmin.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/kerneltest/f32test/server/t_dctcbdiskadmin.cpp Thu Dec 17 09:24:54 2009 +0200 @@ -0,0 +1,999 @@ +// Copyright (c) 1995-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: +// + +#include +#include +#include +#include +#include +#include +#include +#include "t_server.h" + +GLDEF_D RTest test(_L("t_dctcbdiskadmin")); +GLDEF_D TTime gTimeNow; +LOCAL_D TInt gTheDriveNum; + +const TInt KPathPosition = 2; +_LIT(KExpectedPrivatePath, "\\Private\\00000001\\"); +_LIT(KResourcePath, "?:\\Resource\\"); +_LIT(KSystemPath, "?:\\Sys\\"); +_LIT(KPrivatePath, "?:\\Private\\"); +_LIT(KPrivateFalseID, "?:\\Private\\FFFFFFFF\\"); +_LIT(KDriveName, "Billy"); +_LIT(KVolLable, "Benny"); +_LIT(KFileSys, "systemfile.txt"); +_LIT(KFileSys3, "sysfile.rna"); +_LIT(KFilePri, "privatefile.txt"); +_LIT(KFilePri2, "privatefile.tmp"); +_LIT(KFilePri3, "prifile.rna"); +_LIT(KFileRes, "resourcefile.txt"); +_LIT(KFileRes3, "resfile.rna"); +_LIT(KMkDirSub,"Subdir\\"); +_LIT(KOldFile,"?:\\Anyold.txt"); +_LIT(KWildPath, "Z:\\SYS\\"); +_LIT(KWildFile, "*"); + +TCapability TheCaps; +TBuf<4> driveBuf=_L("?:\\"); +RFormat format; +TInt count; +RRawDisk rawdisk; +RFile file1; +RFile file2; +RDir dir; + +TInt r; +TBuf<40> fsname; +TBuf<40> systestname; +TBuf<40> pritestname; +TBuf<40> restestname; +TBuf<40> theprivatepath; +TBuf<40> pritestfalseidname; +TBuf<40> mkdirname; +TFileName fromTemp; + +TBuf<25> sysfilename; +TBuf<30> realName; +TBuf<40> shortfilename; +TBuf<40> longfilename; + +TRequestStatus aStat1; +TRequestStatus aStat2; +TRequestStatus aStat3; +TRequestStatus aStat4; + +TVolumeInfo aVolInfo; +// TDriveInfo adriveInfo; + +TBuf<40> systestfile; +TBuf<40> pritestfile; +TBuf<40> restestfile; +TBuf<40> systestfile1; +TBuf<40> pritestfile1; +TBuf<40> restestfile1; + +TTime testtime; +TBuf<20> oldName; + +TBuf<25> temp; + +TEntry entry; + + +LOCAL_C void privateFalseIDRFsTest() +// +// +// + { + __UHEAP_MARK; + + //private and wrong UID + pritestfalseidname=KPrivateFalseID; + pritestfalseidname[0]=(TText)('A' + gTheDriveNum); + + mkdirname.Zero(); + mkdirname.Append(pritestfalseidname); + mkdirname.Append(KMkDirSub); + + r=TheFs.MkDirAll(mkdirname); + test(r==KErrPermissionDenied); + + r=TheFs.RmDir(mkdirname); + test(r==KErrPermissionDenied); + + r=TheFs.SetSubst(pritestfalseidname,EDriveO); + test(r==KErrPermissionDenied); + + r=TheFs.RealName(_L("O:\\File.XXX"),realName); + test(r==KErrNone); + + r=TheFs.SetSessionPath(pritestfalseidname); + test(r==KErrPermissionDenied); + + TheFs.NotifyChange(ENotifyAll,aStat2,pritestfalseidname); + test(aStat2==KErrPermissionDenied); + + + pritestfile=KPrivateFalseID; + pritestfile[0]=(TText)('A' + gTheDriveNum); + pritestfile1=pritestfile; + pritestfile.Append(KFilePri2); + pritestfile1.Append(KFilePri3); + + oldName=KOldFile; + oldName[0]=(TText)gDriveToTest; + + r=TheFs.GetShortName(pritestfile, shortfilename); + test(r==KErrPermissionDenied || r==KErrNotSupported); + + r=TheFs.GetLongName(pritestfile1, longfilename); + test(r==KErrPermissionDenied || r==KErrNotSupported); + + r=file1.Create(TheFs,oldName,EFileWrite); + test(r==KErrNone || r==KErrAlreadyExists); + file1.Close(); + + r=TheFs.Replace(oldName,pritestfile); + test(r==KErrPermissionDenied); + + r=TheFs.Rename(pritestfile,pritestfile1); + test(r==KErrPermissionDenied); + + r=TheFs.Entry(pritestfile1,entry); + test(r==KErrPermissionDenied); + + r=TheFs.SetEntry(pritestfile1,testtime,KEntryAttNormal,KEntryAttReadOnly); + test(r==KErrPermissionDenied); + + r=TheFs.Delete(pritestfile1); + test(r==KErrPermissionDenied); + + r=TheFs.Delete(oldName); + test(r==KErrNone); + + __UHEAP_MARKEND; + } +LOCAL_C void systemRFsTest() +// +// RFs test on system Directory +// + { + __UHEAP_MARK; + + systestname=KSystemPath; + systestname[0]=(TText)('A' + gTheDriveNum); + + mkdirname.Zero(); + mkdirname.Append(systestname); + mkdirname.Append(KMkDirSub); + r=TheFs.MkDirAll(mkdirname); + test(r==KErrNone); + + TheFs.RmDir(mkdirname); + test(r==KErrNone); + + r=TheFs.SetSubst(systestname,EDriveO); + test(r==KErrNone); + + r=TheFs.RealName(_L("O:\\File.XXX"),realName); + test(r==KErrPermissionDenied); + + r=TheFs.SetSubst(_L(""),EDriveO); //to unsubst + test(r==KErrNone); + + r=TheFs.SetSessionPath(systestname); + test(r==KErrPermissionDenied); + + TheFs.NotifyChange(ENotifyAll,aStat1,systestname); + test(aStat1==KErrPermissionDenied); + + systestfile=KSystemPath; + systestfile[0]=(TText)('A' + gTheDriveNum); + systestfile1=systestfile; + systestfile.Append(KFileSys); + systestfile1.Append(KFileSys3); + + oldName=KOldFile; + oldName[0]=(TText)gDriveToTest; + + r=TheFs.GetShortName(systestfile, shortfilename); + test(r==KErrPermissionDenied || r==KErrNotSupported); + + r=TheFs.GetLongName(systestfile1, longfilename); + test(r==KErrPermissionDenied || r==KErrNotSupported); + + r=file1.Create(TheFs,oldName,EFileWrite); + test(r==KErrNone || r==KErrAlreadyExists); + file1.Close(); + + r=TheFs.Replace(oldName,systestfile); + test(r==KErrNone); + + r=TheFs.Delete(systestfile1); + test(r==KErrNone || r==KErrNotFound); + + r=TheFs.Rename(systestfile,systestfile1); + test(r==KErrNone); + + r=TheFs.Entry(systestfile1,entry); + test(r==KErrPermissionDenied); + + r=TheFs.SetEntry(systestfile1,testtime,KEntryAttNormal,KEntryAttReadOnly); + test(r==KErrNone); + + r=TheFs.Delete(systestfile1); + test(r==KErrNone); + + __UHEAP_MARKEND; + } + +LOCAL_C void ResourceRFsTest() +// +// +// + { + __UHEAP_MARK; + + restestname=KResourcePath; + restestname[0]=(TText)('A' + gTheDriveNum); + + mkdirname.Zero(); + mkdirname.Append(restestname); + mkdirname.Append(KMkDirSub); + r=TheFs.MkDirAll(mkdirname); + test(r==KErrNone); + + TheFs.RmDir(mkdirname); + test(r==KErrNone); + + r=TheFs.SetSubst(restestname,EDriveO); + test(r==KErrNone); + + r=TheFs.RealName(_L("O:\\File.XXX"),realName); + test(r==KErrNone); + + r=TheFs.SetSubst(_L(""),EDriveO); //to unsubst + test(r==KErrNone); + + r=TheFs.SetSessionPath(restestname); + test(r==KErrNone); + + TheFs.NotifyChange(ENotifyAll,aStat4,restestname); + test(aStat4==KRequestPending); + + restestfile=KResourcePath; + restestfile[0]=(TText)('A' + gTheDriveNum); + restestfile1=restestfile; + restestfile.Append(KFileRes); + restestfile1.Append(KFileRes3); + + oldName=KOldFile; + oldName[0]=(TText)gDriveToTest; + + r=TheFs.GetShortName(restestfile, shortfilename); + test(r==KErrNone || KErrNotFound || r==KErrNotSupported); + + r=TheFs.GetLongName(restestfile1, longfilename); + test(r==KErrNone || KErrNotFound || r==KErrNotSupported); + + r=file1.Create(TheFs,oldName,EFileWrite); + test(r==KErrNone || r==KErrAlreadyExists); + file1.Close(); + + r=TheFs.Replace(oldName,restestfile); + test(r==KErrNone); + + r=TheFs.Delete(restestfile1); + test(r==KErrNone || r==KErrNotFound); + + r=TheFs.Rename(restestfile,restestfile1); + test(r==KErrNone); + + r=TheFs.Entry(restestfile1,entry); + test(r==KErrNone); + + r=TheFs.SetEntry(restestfile1,testtime,KEntryAttNormal,KEntryAttReadOnly); + test(r==KErrNone); + + r=TheFs.Delete(restestfile1); + test(r==KErrNone); + + + __UHEAP_MARKEND; + } + +LOCAL_C void privateRFsTest() +// +// +// + { + __UHEAP_MARK; + + //private + pritestname=KPrivatePath; + pritestname[0]=(TText)('A' + gTheDriveNum); + + mkdirname.Zero(); + mkdirname.Append(pritestname); + mkdirname.Append(KMkDirSub); + + r=TheFs.MkDirAll(mkdirname); + test(r==KErrPermissionDenied); + + r=TheFs.RmDir(mkdirname); + test(r==KErrPermissionDenied); + + r=TheFs.SetSubst(pritestname,EDriveO); + test(r==KErrPermissionDenied); + + r=TheFs.RealName(_L("O:\\File.XXX"),realName); + test(r==KErrNone); + + r=TheFs.SetSessionPath(pritestname); + test(r==KErrPermissionDenied); + + TheFs.NotifyChange(ENotifyAll,aStat2,pritestname); + test(aStat2==KErrPermissionDenied); + + + pritestfile=KPrivatePath; + pritestfile[0]=(TText)('A' + gTheDriveNum); + pritestfile1=pritestfile; + pritestfile.Append(KFilePri2); + pritestfile1.Append(KFilePri3); + + oldName=KOldFile; + oldName[0]=(TText)gDriveToTest; + + r=TheFs.GetShortName(pritestfile, shortfilename); + test(r==KErrPermissionDenied || r==KErrNotSupported); + + r=TheFs.GetLongName(pritestfile1, longfilename); + test(r==KErrPermissionDenied || r==KErrNotSupported); + + r=file1.Create(TheFs,oldName,EFileWrite); + test(r==KErrNone || r==KErrAlreadyExists); + file1.Close(); + + r=TheFs.Replace(oldName,pritestfile); + test(r==KErrPermissionDenied); + + r=TheFs.Rename(pritestfile,pritestfile1); + test(r==KErrPermissionDenied); + + r=TheFs.Entry(pritestfile1,entry); + test(r==KErrPermissionDenied); + + r=TheFs.SetEntry(pritestfile1,testtime,KEntryAttNormal,KEntryAttReadOnly); + test(r==KErrPermissionDenied); + + r=TheFs.Delete(pritestfile1); + test(r==KErrPermissionDenied); + + + __UHEAP_MARKEND; + } + + +LOCAL_C void privateSIDRFstest() + { + __UHEAP_MARK; + + theprivatepath[0]=(TText)gDriveToTest; + test.Printf(_L("the Private Path = %S"),&theprivatepath); + + mkdirname.Zero(); + mkdirname.Append(theprivatepath); + mkdirname.Append(KMkDirSub); + r=TheFs.MkDirAll(mkdirname); + test(r==KErrNone); + + r=TheFs.RmDir(mkdirname); + test(r==KErrNone); + + r=TheFs.SetSubst(theprivatepath,EDriveO); + test(r==KErrNone); + + r=TheFs.RealName(_L("O:\\File.XXX"),realName); + test(r==KErrNone); + + r=TheFs.SetSubst(_L(""),EDriveO); //to unsubst + test(r==KErrNone); + + r=TheFs.SetSessionPath(theprivatepath); + test(r==KErrNone); + + TheFs.NotifyChange(ENotifyAll,aStat3,theprivatepath); + test(aStat3==KRequestPending); + + pritestfile=theprivatepath; + pritestfile[0]=(TText)('A' + gTheDriveNum); + pritestfile1=pritestfile; + pritestfile.Append(KFilePri2); + pritestfile1.Append(KFilePri3); + + oldName=KOldFile; + oldName[0]=(TText)gDriveToTest; + + r=TheFs.GetShortName(pritestfile, shortfilename); + test(r==KErrNone || r==KErrNotFound || r==KErrNotSupported); + + r=TheFs.GetLongName(pritestfile1, longfilename); + test(r==KErrNone || r==KErrNotFound || r==KErrNotSupported); + + r=file1.Create(TheFs,oldName,EFileWrite); + test(r==KErrNone || r==KErrAlreadyExists); + file1.Close(); + + r=TheFs.Replace(oldName,pritestfile); + test(r==KErrNone); + + r=TheFs.Rename(pritestfile,pritestfile1); + test(r==KErrNone || r==KErrAlreadyExists); + + r=TheFs.Entry(pritestfile1,entry); + test(r==KErrNone); + + r=TheFs.SetEntry(pritestfile1,testtime,KEntryAttNormal,KEntryAttReadOnly); + test(r==KErrNone); + + r=TheFs.Delete(pritestfile1); + test(r==KErrNone); + + __UHEAP_MARKEND; + } + + +LOCAL_C void systemRFiletest() +// +//RFile testing with session path set to //system// +// + { + __UHEAP_MARK; + + r=TheFs.SetSessionPath(systestname); + test(r==KErrPermissionDenied); + + r=file1.Temp(TheFs,systestname,fromTemp,EFileWrite); + test(r==KErrNone); + file1.Close(); + + systestfile=KSystemPath; + systestfile[0]=(TText)('A' + gTheDriveNum); + systestfile1=systestfile; + systestfile.Append(KFileSys); + systestfile1.Append(KFileSys3); + + r=file1.Create(TheFs,systestfile,EFileWrite); + test(r==KErrNone); + file1.Close(); + + r=file1.Open(TheFs,systestfile,EFileWrite); + test(r==KErrNone); + file1.Close(); + + r=file1.Open(TheFs,systestfile,EFileRead); + test(r==KErrPermissionDenied); + file1.Close(); + + r=file1.Replace(TheFs,systestfile,EFileWrite); + test(r==KErrNone); + + r=file1.Rename(systestfile1); + test(r==KErrNone); + file1.Close(); + + TFindFile finder(TheFs); + CDir* dir = NULL; + r=finder.FindWildByDir(KWildFile, KWildPath, dir); + if (!(r==KErrPermissionDenied)) + test.Printf(_L("T_DCTCBDISKADMIN: test find wildcards r = %d (expected KErrPermissionDenied)\n"), r); + test(r==KErrPermissionDenied); +// delete dir; + + r=TheFs.Delete(fromTemp); + test(r==KErrNone); + + r=TheFs.Delete(systestfile1); + test(r==KErrNone); + + + __UHEAP_MARKEND; + } + +LOCAL_C void resourceRFiletest() +// +//RFile testing with session path set to //resource// +// + { + __UHEAP_MARK; + + r=TheFs.SetSessionPath(restestname); + test(r==KErrNone); + + r=file1.Temp(TheFs,restestname,fromTemp,EFileWrite); + test(r==KErrNone); + file1.Close(); + + r=file1.Create(TheFs,KFileRes,EFileWrite); + test(r==KErrNone); + file1.Close(); + + r=file1.Open(TheFs,KFileRes,EFileWrite|EFileShareExclusive ); + test(r==KErrNone); + + r=file1.Rename(KFileRes3); + test(r==KErrNone); + file1.Close(); + + r=file1.Open(TheFs,KFileRes3,EFileShareReadersOrWriters|EFileRead); + test(r==KErrNone); + file1.Close(); + + r=file1.Open(TheFs,KFileRes3,EFileShareReadersOrWriters|EFileWrite); + test(r==KErrNone); + file1.Close(); + + r=file1.Open(TheFs,KFileRes3,EFileShareReadersOnly); + test(r==KErrNone); + + r=file1.ChangeMode(EFileShareExclusive); + test(r==KErrNone); + file1.Close(); + + r=file1.Replace(TheFs,KFileRes,EFileWrite); + test(r==KErrNone); + file1.Close(); + + r=TheFs.Delete(KFileRes); + test(r==KErrNone); + + r=TheFs.Delete(KFileRes3); + test(r==KErrNone); + + r=TheFs.Delete(fromTemp); + test(r==KErrNone); + + __UHEAP_MARKEND; + } + + +LOCAL_C void privatefalseIDRFiletest() +// +//RFile testing with session path set to //Private//// +// + { + __UHEAP_MARK; + + r=TheFs.SetSessionPath(pritestfalseidname); + test(r==KErrPermissionDenied); + + // Since can't set the session path to what is required, so use + // an explicit path + pritestfile=pritestfalseidname; + pritestfile[0]=(TText)('A' + gTheDriveNum); + pritestfile.Append(KFilePri); + + r=file1.Temp(TheFs,pritestfalseidname,fromTemp,EFileWrite); + test(r==KErrPermissionDenied); + file1.Close(); + + r=file1.Create(TheFs,pritestfile,EFileWrite); + test(r==KErrPermissionDenied); + file1.Close(); + + r=file1.Open(TheFs,pritestfile,EFileWrite); + test(r==KErrPermissionDenied); + file1.Close(); + + r=file1.Replace(TheFs,pritestfile,EFileWrite); + test(r==KErrPermissionDenied); + + // Can't perform this operation since file1 has not been created +/* r=file1.Rename(KFilePri3); + test(r==KErrPermissionDenied); + file1.Close(); +*/ + __UHEAP_MARKEND; + } + + + +LOCAL_C void privateRFiletest() +// +//RFile testing with session path set to //Private// +// + { + __UHEAP_MARK; + + r=TheFs.SetSessionPath(pritestname); + test(r==KErrPermissionDenied); + + r=file1.Temp(TheFs,pritestname,fromTemp,EFileWrite); + test(r==KErrPermissionDenied); + file1.Close(); + + // Since can't set session path create explicit path + pritestfile=KPrivatePath; + pritestfile[0]=(TText)('A' + gTheDriveNum); + pritestfile.Append(KFilePri); + + r=file1.Create(TheFs,pritestfile,EFileWrite); + test(r==KErrPermissionDenied); + file1.Close(); + + r=file1.Open(TheFs,pritestfile,EFileWrite); + test(r==KErrPermissionDenied); + file1.Close(); + + r=file1.Open(TheFs,pritestfile,EFileRead); + test(r==KErrPermissionDenied); + file1.Close(); + + r=file1.Replace(TheFs,pritestfile,EFileWrite); + test(r==KErrPermissionDenied); + + // Can't rename nor delete since file1 not created +/* + r=file1.Rename(KFilePri3); + test(r==KErrPermissionDenied); + file1.Close(); + + r=TheFs.Delete(fromTemp); + test(r==KErrNone); +*/ + + __UHEAP_MARKEND; + } + + + +LOCAL_C void privateSIDRFiletest() +// +//Rfile Testing with session path set to //Private//UID// +// + { + __UHEAP_MARK; + + r=TheFs.SetSessionToPrivate(gTheDriveNum); + test(r==KErrNone); + + r=file1.Temp(TheFs,theprivatepath,fromTemp,EFileWrite); + test(r==KErrNone); + file1.Close(); + + r=file1.Create(TheFs,KFilePri,EFileWrite); + test(r==KErrNone || r==KErrAlreadyExists); + file1.Close(); + + r=file1.Open(TheFs,KFilePri,EFileWrite); + test(r==KErrNone); + file1.Close(); + + r=file1.Open(TheFs,KFilePri,EFileRead); + test(r==KErrNone); + file1.Close(); + + r=file1.Replace(TheFs,KFilePri,EFileWrite); + test(r==KErrNone); + + r=file1.Rename(KFilePri3); + test(r==KErrNone); + file1.Close(); + + r=TheFs.Delete(KFilePri3); + test(r==KErrNone); + + r=TheFs.Delete(fromTemp); + test(r==KErrNone); + + __UHEAP_MARKEND; + } + +LOCAL_C void RDirtest() +// +// +// + { + __UHEAP_MARK; + + + //system + CDir* dirEntries; + TBuf<30> dirNameBuf(KSystemPath); + dirNameBuf[0]=(TText)gDriveToTest; + r=dir.Open(TheFs,dirNameBuf,KEntryAttNormal); + test(r==KErrPermissionDenied); + dir.Close(); + r=TheFs.GetDir(dirNameBuf,KEntryAttMatchMask,ESortByName,dirEntries); + test(r==KErrPermissionDenied); + dirNameBuf.Zero(); + delete dirEntries; + + //Private + dirNameBuf=KPrivatePath; + dirNameBuf[0]=(TText)gDriveToTest; + r=dir.Open(TheFs,dirNameBuf,KEntryAttNormal); + test(r==KErrPermissionDenied); + dir.Close(); + r=TheFs.GetDir(dirNameBuf,KEntryAttMatchMask,ESortByName,dirEntries); + test(r==KErrPermissionDenied); + dirNameBuf.Zero(); + delete dirEntries; + + //Private//// + dirNameBuf=KPrivateFalseID; + dirNameBuf[0]=(TText)gDriveToTest; + r=dir.Open(TheFs,dirNameBuf,KEntryAttNormal); + test(r==KErrPermissionDenied); + dir.Close(); + r=TheFs.GetDir(dirNameBuf,KEntryAttMatchMask,ESortByName,dirEntries); + test(r==KErrPermissionDenied); + dirNameBuf.Zero(); + delete dirEntries; + + //Private/uid + TheFs.PrivatePath(dirNameBuf); + dirNameBuf.Insert(0,_L("?:")); + dirNameBuf[0]=(TText)gDriveToTest; + r=dir.Open(TheFs,dirNameBuf,KEntryAttNormal); + test(r==KErrNone); + dir.Close(); + r=TheFs.GetDir(dirNameBuf,KEntryAttMatchMask,ESortByName,dirEntries); + test(r==KErrNone); + dirNameBuf.Zero(); + delete dirEntries; + //Resource + + dirNameBuf=KResourcePath; + dirNameBuf[0]=(TText)gDriveToTest; + r=dir.Open(TheFs,dirNameBuf,KEntryAttNormal); + test(r==KErrNone); + r=TheFs.GetDir(dirNameBuf,KEntryAttMatchMask,ESortByName,dirEntries); + test(r==KErrNone); + dir.Close(); + delete dirEntries; + + __UHEAP_MARKEND; + } + + +LOCAL_C void TestTcbDiskAdmin() +// +// Test with tcb capabilities +// + { + __UHEAP_MARK; + + r=TheFs.FileSystemName(fsname,gTheDriveNum); + test(r==KErrNone); + r = DismountFileSystem(TheFs, fsname, gTheDriveNum); + test(r==KErrNone || r==KErrNotFound); +// r=TheFs.RemoveFileSystem(fsname); //can not test due to bug else where fix exists +// test(r==KErrNone); +// r=TheFs.AddFileSystem(fsname); +// test(r==KErrNone); + r = MountFileSystem(TheFs, fsname, gTheDriveNum); + test(r==KErrNone); + r=TheFs.SetDriveName(gTheDriveNum,KDriveName); + test(r==KErrNone); +#ifndef __WINS__ + r=TheFs.SetVolumeLabel(KVolLable, gTheDriveNum); + test(r==KErrNone); +#endif + + systemRFsTest(); + ResourceRFsTest(); + privateRFsTest(); + privateSIDRFstest(); + privateFalseIDRFsTest(); + + systemRFiletest(); + resourceRFiletest(); + privateRFiletest(); + privateSIDRFiletest(); + privatefalseIDRFiletest(); + + //check notifier return values set in rfs testing + User::WaitForRequest(aStat1); + User::WaitForRequest(aStat2); + User::WaitForRequest(aStat3); + User::WaitForRequest(aStat4); + test(aStat1==KErrPermissionDenied); + test(aStat2==KErrPermissionDenied); + test(aStat3==KErrNone); + test(aStat4==KErrNone); + + r=TheFs.SetSessionPath(systestname); + test(r==KErrPermissionDenied); + +//Test RRawDisk class + r=rawdisk.Open(TheFs,gTheDriveNum); + test(r==KErrNone); + rawdisk.Close(); + + RDirtest(); + +#ifdef __WINS__ + if (User::UpperCase(driveBuf[0]) != 'C') +#endif + { + //Test RFormat class + r=format.Open(TheFs,driveBuf,EHighDensity,count); + test(r==KErrNone); + + while(count) + { + TInt r=format.Next(count); + test(r==KErrNone); + } + format.Close(); + } + + driveBuf[0]=(TText)gDriveToTest; + r=TheFs.ScanDrive(driveBuf); + test(r==KErrNone || r==KErrNotSupported); + r=TheFs.CheckDisk(driveBuf); + test(r==KErrNone || r==KErrNotSupported); + + __UHEAP_MARKEND; + } + +LOCAL_C void TestCaps() +// +// test format etc that require certain capabilities +// + { + + __UHEAP_MARK; +#ifndef __REMOVE_PLATSEC_DIAGNOSTIC_STRINGS__ + const char myDiagMsg[] = "Capability Check Failure"; +#endif //!__REMOVE_PLATSEC_DIAGNOSTIC_STRINGS__ + r=RProcess().HasCapability(ECapabilityTCB,ECapabilityDiskAdmin, __PLATSEC_DIAGNOSTIC_STRING(myDiagMsg)); + test(r); + + driveBuf[0]=(TText)gDriveToTest; + r=TheFs.SessionPath(temp); + test(r==KErrNone); + + test.Printf(_L("Session path: %S"),&temp); + + r=TheFs.CreatePrivatePath(gTheDriveNum); + test(r==KErrNone || r== KErrAlreadyExists); + + TBuf<18> tempPri; + r=TheFs.PrivatePath(tempPri); + test(r==KErrNone); + theprivatepath = _L("?:"); + theprivatepath.Append(tempPri); + + TestTcbDiskAdmin(); + + TFileName thesessionpath; + + r=TheFs.SetSessionToPrivate(gTheDriveNum); + test(r==KErrNone); + r=TheFs.SessionPath(thesessionpath); + test(r==KErrNone); + + test(thesessionpath == theprivatepath); + + __UHEAP_MARKEND; + } + +LOCAL_C void CleanupL() +// +// Clean up tests +// + { + test.Next(_L("Delete test directory")); + CFileMan* fMan=CFileMan::NewL(TheFs); + TInt r=fMan->RmDir(gSessionPath); + test(r==KErrNone || r==KErrPathNotFound); + + TBuf<20> delDir; + delDir=KResourcePath; + delDir[0]=(TText)gDriveToTest; + r=fMan->RmDir(delDir); + test(r==KErrNone || r==KErrPathNotFound); + delete fMan; + + delDir=KSystemPath; + delDir[0]=(TText)gDriveToTest; + r=TheFs.RmDir(delDir); + test(r==KErrNone || r==KErrPathNotFound || r==KErrNotFound); + } + +GLDEF_C void CallTestsL(/*TChar aDriveLetter*/) +// +// Do all tests +// + { + if( !PlatSec::IsCapabilityEnforced(ECapabilityTCB) || + !PlatSec::IsCapabilityEnforced(ECapabilityDiskAdmin)) + { + test.Printf(_L("Insufficient capabilities enabled - leaving t_dctcbdiskadmin")); + test.Printf(_L("\n")); // Prevent overwrite by next print + return; + } + + __UHEAP_MARK; + + TurnAllocFailureOff(); + + TheFs.CharToDrive(gDriveToTest,gTheDriveNum); + + TBuf<30> sesspath; + sesspath=_L("?:\\"); + sesspath[0] = (TText)gDriveToTest; + + TInt r= TheFs.SetSessionPath(sesspath); + test(r==KErrNone); + + //cleanup from previous run of this test + RProcess tp; + r=tp.Create(_L("clean_prepdc.exe"),sesspath); + test(r==KErrNone); + { + TRequestStatus ps; + tp.Logon(ps); + tp.Resume(); + tp.Close(); + User::WaitForRequest(ps); + } + + //check double mode ie that Defpath still works + RFs fs1; + RFs fs2; + + r=fs1.Connect(); + test(r==KErrNone); + r=fs1.SessionPath(sesspath); + test(r==KErrNone); + test.Printf(_L("session1 Path=%S"),&sesspath); + + TBuf<30> privatepath; + r=fs1.SetSessionToPrivate(gTheDriveNum); + test(r==KErrNone); + r=fs1.PrivatePath(privatepath); + test(r==KErrNone); + r=privatepath.Compare(KExpectedPrivatePath()); + test(r==0); + r=fs1.SessionPath(sesspath); + test(r==KErrNone); + r=privatepath.Compare(sesspath.Mid(KPathPosition)); + test(r==0); + r=fs1.CreatePrivatePath(gTheDriveNum); + test(r==KErrNone); + fs1.Close(); + + r=fs2.Connect(); + test(r==KErrNone); + r=fs2.SessionPath(sesspath); + test(r==KErrNone); + test.Printf(_L("session2 Path=%S"),&sesspath); + fs2.Close(); + + __UHEAP_MARK; + TestCaps(); + __UHEAP_MARKEND; + + test.Printf(_L("No of files open=%d"), TheFs.ResourceCount()); + + CleanupL(); + __UHEAP_MARKEND; + + }