kerneltest/f32test/server/t_ftrace.cpp
changeset 9 96e5fb8b040d
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/kerneltest/f32test/server/t_ftrace.cpp	Thu Dec 17 09:24:54 2009 +0200
@@ -0,0 +1,423 @@
+// Copyright (c) 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_ftrace.cpp
+// 
+//
+
+#include <f32file.h>
+#include <f32tracedef.h>
+#include <e32test.h>
+#include "t_server.h"
+
+#include "../../../kernel/eka/include/d32btrace.h"
+#include "../../../kernel/eka/include/e32btrace.h"
+#include <utraceefsrv.h>
+
+RTest test(_L("T_FTRACE"));
+
+RBTrace Trace;
+
+void SetBTraceFilter(const TUint32* aNew,TUint32* aOld)
+	{
+	TUint category = 0;
+	do
+		{
+		TUint32 newBits = *aNew++;
+		TUint32 oldBits = 0;
+		do
+			{
+			oldBits >>= 1;
+			if(Trace.SetFilter(category,newBits&1))
+				oldBits |= 0x80000000u;
+			newBits >>= 1;
+			++category;
+			}
+		while(category&31);
+		if(aOld)
+			*aOld++ = oldBits;
+		}
+	while(category<256);
+	}
+
+
+
+//---------------------------------------------------------------------------------------------------------------------
+//! @SYMTestCaseID				KBASE-T_FTRACE-0001
+//! @SYMTestCaseDesc			Test File Server Tracing of RFile::Replace()
+//! @SYMTestType				UT
+//! @SYMPREQ					PREQ1617
+//! @SYMTestPriority			Medium
+//! @SYMTestActions				
+//! 	1.	Call RFile::Replace() to create a file
+//! 	2.	Get trace data from BTrace and verify that the expected trace data is present
+//! 
+//! @SYMTestExpectedResults
+//! 	1.	Trace data payload should be as expected, i.e. it should contain the file name, mode etc.
+//---------------------------------------------------------------------------------------------------------------------
+void TestRFileReplace()
+	{
+	test.Start(_L("Test trace output from creating a file"));
+	RFile file;
+	TFileName testFileName = _L("File.txt");
+
+	TheFs.Delete(testFileName);
+
+	Trace.Empty();
+
+	TInt r = file.Replace(TheFs,testFileName,EFileStreamText);
+	test(r==KErrNone);
+
+
+	TBool funcInFound = EFalse;
+	TBool funcOutFound = EFalse;
+
+	TBuf8<1024> buf;
+	for(;;)
+		{
+		TUint8* record;
+		TInt dataSize = Trace.GetData(record);
+		if(!dataSize)
+			break;
+		TUint8* end = record+dataSize;
+
+		while(record<end)
+			{
+			TUint size = record[BTrace::ESizeIndex];
+			TUint flags = record[BTrace::EFlagsIndex];
+			TUint category = record[BTrace::ECategoryIndex];
+			TUint subCategory = record[BTrace::ESubCategoryIndex];
+			TUint8* data = record+4;
+			size -= 4;
+
+			buf.Zero();
+			if(flags&(BTrace::EHeader2Present))
+				{
+				data += 4;
+				size -= 4;
+				}
+
+			if((flags&(BTrace::ETimestampPresent|BTrace::ETimestamp2Present))==(BTrace::ETimestampPresent|BTrace::ETimestamp2Present))
+				{
+				buf.AppendFormat(_L8("time:%08x:%08x "),((TUint32*)data)[1],*(TUint32*)data);
+				data += 8;
+				size -= 8;
+				}
+			else if(flags&(BTrace::ETimestampPresent|BTrace::ETimestamp2Present))
+				{
+				buf.AppendFormat(_L8("time:%08x "),*(TUint32*)data);
+				data += 4;
+				size -= 4;
+				}
+
+			if(flags&(BTrace::EContextIdPresent))
+				{
+				buf.AppendFormat(_L8("context:%08x "),*(TUint32*)data);
+				data += 4;
+				size -= 4;
+				}
+			else
+				{
+				buf.AppendFormat(_L8("                 "));
+				}
+
+			if(flags&(BTrace::EPcPresent))
+				{
+				buf.AppendFormat(_L8("pc:%08x "),*(TUint32*)data);
+				data += 4;
+				size -= 4;
+				}
+
+			if(flags&(BTrace::EExtraPresent))
+				{
+				data += 4;
+				size -= 4;
+				}
+
+			TUint32 data0 = (size>0) ? *(TUint32*)(data) : 0;
+			TUint32 data1 = (size>4) ? *(TUint32*)(data+4) : 0;
+			TPtrC8 des(0,0);
+			if(size>=8)
+				des.Set(data+8,size-8);
+
+			buf.AppendFormat(_L8("size:%d flags:%02x cat:%d,%d data: "),size,flags,category,subCategory);
+			for(TUint i=0; i<size; i+=4)
+				buf.AppendFormat(_L8("%08x "),*(TUint32*)(data+i));
+			buf.Append('\r');
+			buf.Append('\n');
+			test(buf.MaxLength() >= (buf.Length()*2));
+			RDebug::RawPrint(buf.Expand());
+
+
+			if (category == UTF::EBorder && subCategory == 0 && data0 == EF32TraceUidEfsrv)
+				{
+				if (data1 == UTraceModuleEfsrv::EFileReplace)
+					{
+					TInt sessionHandle = (size>8) ? *(TUint32*)(data+8) : 0;
+					TUint32 fileMode = (size>12) ? *(TUint32*)(data+12) : 0;
+					TInt fileNameLen = (size>16) ? *(TUint32*)(data+16) : 0;
+					fileNameLen/= 2;	// convert to unicode length
+					TText16* fileName = (TText16*) ((size>20) ? (data+20) : NULL);
+
+					test(sessionHandle == TheFs.Handle());
+					test(fileMode == EFileStreamText);
+					test(fileNameLen == testFileName.Length());
+					TPtrC16 fileNamePtr (fileName, fileNameLen);
+					test(fileName != NULL);
+					test(testFileName.Compare(fileNamePtr) == 0);
+					funcInFound = ETrue;
+					}
+				else if (data1 == UTraceModuleEfsrv::EFileReplaceReturn)
+					{
+					TInt retCode = (size>8) ? *(TUint32*)(data+8) : 0;
+					TInt subsessionHandle = (size>12) ? *(TUint32*)(data+12) : 0;
+
+					test(retCode == KErrNone);
+					test(subsessionHandle == file.SubSessionHandle());
+					funcOutFound = ETrue;
+					}
+				}
+
+			record = BTrace::NextRecord(record);
+			}
+		Trace.DataUsed();
+		}
+
+	file.Close();
+	TheFs.Delete(testFileName);
+
+	test (funcInFound);
+	test (funcOutFound);
+	}
+
+//---------------------------------------------------------------------------------------------------------------------
+//! @SYMTestCaseID				KBASE-T_FTRACE-0002
+//! @SYMTestCaseDesc			Test File Server Tracing of RFs::Rename()
+//! @SYMTestType				UT
+//! @SYMPREQ					PREQ1617
+//! @SYMTestPriority			Medium
+//! @SYMTestActions				
+//! 	1.	Call RFile::Replace() to create a file
+//! 	2.	Close the file
+//! 	3.	Call RFs::Rename to rename the file
+//! 	4.	Get trace data from BTrace and verify that the expected trace data is present
+//! 
+//! @SYMTestExpectedResults
+//! 	1.	Trace data payload should be as expected, i.e. it should contain both file names, etc.
+//---------------------------------------------------------------------------------------------------------------------
+void TestRFsRename()
+	{
+	test.Start(_L("Test trace output from renaming a file"));
+	RFile file;
+	TFileName testFileName1 = _L("File1.txt");
+	TFileName testFileName2 = _L("File2.txt");
+
+	TheFs.Delete(testFileName1);
+	TheFs.Delete(testFileName2);
+
+	TInt r = file.Replace(TheFs,testFileName1,EFileStreamText);
+	test(r==KErrNone || KErrAlreadyExists);
+	file.Close();
+
+	Trace.Empty();
+
+	r = TheFs.Rename(testFileName1, testFileName2);
+	test(r==KErrNone);
+
+
+	TBool funcInFound = EFalse;
+	TBool funcOutFound = EFalse;
+
+	TBuf8<1024> buf;
+	for(;;)
+		{
+		TUint8* record;
+		TInt dataSize = Trace.GetData(record);
+		if(!dataSize)
+			break;
+		TUint8* end = record+dataSize;
+
+		while(record<end)
+			{
+			TUint size = record[BTrace::ESizeIndex];
+			TUint flags = record[BTrace::EFlagsIndex];
+			TUint category = record[BTrace::ECategoryIndex];
+			TUint subCategory = record[BTrace::ESubCategoryIndex];
+			TUint8* data = record+4;
+			size -= 4;
+
+			buf.Zero();
+			if(flags&(BTrace::EHeader2Present))
+				{
+				data += 4;
+				size -= 4;
+				}
+
+			if((flags&(BTrace::ETimestampPresent|BTrace::ETimestamp2Present))==(BTrace::ETimestampPresent|BTrace::ETimestamp2Present))
+				{
+				buf.AppendFormat(_L8("time:%08x:%08x "),((TUint32*)data)[1],*(TUint32*)data);
+				data += 8;
+				size -= 8;
+				}
+			else if(flags&(BTrace::ETimestampPresent|BTrace::ETimestamp2Present))
+				{
+				buf.AppendFormat(_L8("time:%08x "),*(TUint32*)data);
+				data += 4;
+				size -= 4;
+				}
+
+			if(flags&(BTrace::EContextIdPresent))
+				{
+				buf.AppendFormat(_L8("context:%08x "),*(TUint32*)data);
+				data += 4;
+				size -= 4;
+				}
+			else
+				{
+				buf.AppendFormat(_L8("                 "));
+				}
+
+			if(flags&(BTrace::EPcPresent))
+				{
+				buf.AppendFormat(_L8("pc:%08x "),*(TUint32*)data);
+				data += 4;
+				size -= 4;
+				}
+
+			if(flags&(BTrace::EExtraPresent))
+				{
+				data += 4;
+				size -= 4;
+				}
+
+			TUint32 data0 = (size>0) ? *(TUint32*)(data) : 0;
+			TUint32 data1 = (size>4) ? *(TUint32*)(data+4) : 0;
+			TPtrC8 des(0,0);
+			if(size>=8)
+				des.Set(data+8,size-8);
+
+			buf.AppendFormat(_L8("size:%d flags:%02x cat:%d,%d data: "),size,flags,category,subCategory);
+			for(TUint i=0; i<size; i+=4)
+				buf.AppendFormat(_L8("%08x "),*(TUint32*)(data+i));
+			buf.Append('\r');
+			buf.Append('\n');
+			test(buf.MaxLength() >= (buf.Length()*2));
+			RDebug::RawPrint(buf.Expand());
+
+
+			if (category == UTF::EBorder && subCategory == 0 && data0 == EF32TraceUidEfsrv)
+				{
+				TUint8* recData = data+8;
+				if (data1 == UTraceModuleEfsrv::EFsRename)
+					{
+					TInt sessionHandle = *(TUint32*) recData; recData+= 4;
+
+					TInt fileNameLen1 = *(TUint32*) recData; recData+= 4;
+					TText16* fileName1 = (TText16*) recData; recData+= ((fileNameLen1 +4) & ~3);
+
+					TInt fileNameLen2 = *(TUint32*) recData; recData+= 4;
+					TText16* fileName2 = (TText16*) recData; recData+= fileNameLen2;
+
+					fileNameLen1/= 2;	// convert to unicode length
+					fileNameLen2/= 2;	// convert to unicode length
+
+
+					test(sessionHandle == TheFs.Handle());
+					
+					test(fileNameLen1 == testFileName1.Length());
+					TPtrC16 fileNamePtr1 (fileName1, fileNameLen1);
+					test(fileName1 != NULL);
+					test(testFileName1.Compare(fileNamePtr1) == 0);
+
+					test(fileNameLen2 == testFileName2.Length());
+					TPtrC16 fileNamePtr2 (fileName2, fileNameLen2);
+					test(fileName2 != NULL);
+					test(testFileName2.Compare(fileNamePtr2) == 0);
+
+					funcInFound = ETrue;
+					}
+				else if (data1 == UTraceModuleEfsrv::EFsRenameReturn)
+					{
+					TInt retCode = (size>8) ? *(TUint32*)(data+8) : 0;
+
+					test(retCode == KErrNone);
+
+					funcOutFound = ETrue;
+					}
+				}
+
+			record = BTrace::NextRecord(record);
+			}
+		Trace.DataUsed();
+		}
+
+
+	test (funcInFound);
+	test (funcOutFound);
+
+	TheFs.Delete(testFileName1);
+	TheFs.Delete(testFileName2);
+	}
+
+void CallTestsL()
+	{
+
+// By default, file server trace-points are only compiled in in debug mode
+#if defined(_DEBUG)
+	test.Title();
+	TInt r;
+
+	test.Start(_L("Open LDD"));
+	r = Trace.Open();
+	test(r == KErrNone);
+
+
+	TUint32 OldTraceFilter[8] = {0};
+
+	TUint savedMode = Trace.Mode();
+	SetBTraceFilter(OldTraceFilter,OldTraceFilter);
+
+	Trace.ResizeBuffer(0x100000);
+	Trace.Empty();
+
+	Trace.SetMode(RBTrace::EEnable | RBTrace::EFreeRunning);
+
+	TBool b;
+//	b = Trace.SetFilter(BTrace::EThreadIdentification, ETrue);
+//	test(b >= 0);
+	b = Trace.SetFilter(UTF::EPanic, ETrue);
+	test(b >= 0);
+	b = Trace.SetFilter(UTF::EError, ETrue);
+	test(b >= 0);
+	b = Trace.SetFilter(UTF::EBorder, ETrue);
+	test(b >= 0);
+
+	b = Trace.SetFilter2(EF32TraceUidEfsrv, ETrue);
+	test(b >= 0);
+
+	TestRFileReplace();
+	TestRFsRename();
+
+	// restore trace settings...
+	Trace.SetMode(0);
+	SetBTraceFilter(OldTraceFilter,OldTraceFilter);
+	Trace.SetMode(savedMode);
+
+
+	test.Next(_L("Close LDD"));
+	Trace.Close();
+
+	test.End();
+#endif
+	}
+