lowlevellibsandfws/apputils/tsrc/t_fileutils.cpp
changeset 0 e4d67989cc36
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/lowlevellibsandfws/apputils/tsrc/t_fileutils.cpp	Tue Feb 02 02:01:42 2010 +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);
+	}