diff -r 000000000000 -r bde4ae8d615e os/ossrv/lowlevellibsandfws/apputils/tsrc/t_fileutils.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/os/ossrv/lowlevellibsandfws/apputils/tsrc/t_fileutils.cpp Fri Jun 15 03:10:57 2012 +0200 @@ -0,0 +1,149 @@ +// Copyright (c) 2004-2009 Nokia Corporation and/or its subsidiary(-ies). +// All rights reserved. +// This component and the accompanying materials are made available +// under the terms of "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: +// Tests EikFileUtils::SortByTable() function. +// +// + +#include <e32test.h> +#include <f32file.h> +#include <bautils.h> + +LOCAL_D RTest test(_L("t_fileutils.exe")); + +const TInt KSortTableUid1=0x3f631; +const TInt KSortTableUid2=0x276a9; + +/** +@SYMTestCaseID SYSLIB-BAFL-CT-0486 +@SYMTestCaseDesc Tests for the sorting of files containing an array of UIDs. +@SYMTestPriority High +@SYMTestActions Tests BaflUtils::SortByTable() function. +@SYMTestExpectedResults Tests must not fail +@SYMREQ REQ0000 +*/ +void TestSortByTableL() + { + CDir* theFileList; + TInt theAttribs=KEntryAttMatchMask|KEntryAttAllowUid; + TFileName theCurrentPath = _L("Z:\\system\\documents\\baflsortbytabletest\\"); + + RFs fileSession; + User::LeaveIfError(fileSession.Connect()); + CleanupClosePushL(fileSession); + + TInt ret=fileSession.GetDir(theCurrentPath,theAttribs,ESortByName,theFileList); + test(ret==KErrNone); + CleanupStack::PushL(theFileList); + + CBaflFileSortTable*theTable = new (ELeave) CBaflFileSortTable(); + CleanupStack::PushL(theTable); + + TInt insertErr; + + TRAP(insertErr,theTable->InsertL(0,TUid::Uid(KSortTableUid1))); + test(insertErr==KErrNone); + + TRAP(insertErr,theTable->InsertL(1,TUid::Uid(KSortTableUid2))); + test(insertErr==KErrNone); + + test.Printf(_L("\nGet the names of the files sorted by alphabetical order\n")); + for(TInt theIndex1 = 0; theIndex1 < theFileList->Count(); theIndex1++) + { + TEntry theEntry = (*theFileList)[theIndex1]; + TUid theUid1 = theEntry[2]; + test.Printf(_L("The %d file in list %S, Uid = 0x%x\n"), theIndex1 + 1, &theEntry.iName, theUid1.iUid); + switch(theIndex1) + { + case 0: + test(theEntry.iName == _L("addcert.rsc")); + break; + case 1: + test(theEntry.iName == _L("help.rsc")); + break; + case 2: + test(theEntry.iName == _L("msgeditor.rsc")); + break; + case 3: + test(theEntry.iName == _L("smlprogress.rsc")); + break; + default: + break; + } + } + + TInt sortErr = BaflUtils::SortByTable(*theFileList, theTable); + test(sortErr==KErrNone); + + test.Printf(_L("\nGet the names of the files sorted by the Uid's table\n")); + for(TInt theIndex = 0; theIndex < theFileList->Count(); theIndex++) + { + TEntry theEntry = (*theFileList)[theIndex]; + TUid theUid1 = theEntry[2]; + + test.Printf(_L("The %d file in list %S, Uid = 0x%x\n"), theIndex + 1, &theEntry.iName, theUid1.iUid); + switch(theIndex) + { + case 0: + test(theEntry.iName == _L("msgeditor.rsc")); + break; + case 1: + test(theEntry.iName == _L("help.rsc")); + break; + case 2: + test(theEntry.iName == _L("addcert.rsc")); + break; + case 3: + test(theEntry.iName == _L("smlprogress.rsc")); + break; + default: + break; + } + } + CleanupStack::PopAndDestroy(3, &fileSession); + } + + +void DoTestsL() + { + __UHEAP_MARK; + + TRAPD(testsortErr,TestSortByTableL()); + test(testsortErr==KErrNone); + + __UHEAP_MARKEND; + } + + +GLDEF_C TInt E32Main() + { + __UHEAP_MARK; + + test.Title(); + test.Start(_L(" @SYMTestCaseID:SYSLIB-BAFL-CT-0486 SORT BY TABLE TEST ")); + + // get clean-up stack + CTrapCleanup* cleanup = CTrapCleanup::New(); + + test (cleanup!=0); + + TRAPD(err,DoTestsL()); + test(err==KErrNone); + + delete cleanup; + test.End(); + test.Close(); + + __UHEAP_MARKEND; + return(KErrNone); + }