applayerprotocols/httptransportfw/Test/t_utils/httptestutils.h
changeset 0 b16258d2340f
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/applayerprotocols/httptransportfw/Test/t_utils/httptestutils.h	Tue Feb 02 01:09:52 2010 +0200
@@ -0,0 +1,209 @@
+// Copyright (c) 2000-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:
+//
+
+#if !defined(__HTTPTESTUTILS_H__)
+#define __HTTPTESTUTILS_H__
+
+#include <e32base.h>
+#include <e32test.h>
+#include <f32file.h>
+
+
+#include <http/framework/httplogger.h>
+
+//	Constants
+const TUid KUidWapTestUtils = {0x10005188};
+const TInt KMaxUserEntrySize = 128;
+
+//Test Harness Logging
+
+#define KLogsDir				_L("c:\\logs\\")
+#define KTestHeader				_L("Test Results")
+#define KTestStarting			_L("Test %d Starting")
+#define KTestStartingWithDesc	_L("Test %d Starting (%S)")
+#define KNextTestStepWithDesc	_L("Test %d Step %d (%S)")
+#define KTestPassed				_L("Test %d OK")
+#define KTestFailed				_L("Test %d FAILED (error = %d)")
+#define KTestHarnessCompleted	_L("Tests Completed Ok")
+#define KTestHarnessFailed		_L("Test FAILED (%d failed test(s))")
+#define KTestFailInfo			_L("Test %d : %S failed with Error %d") 
+#define KTestCommentPrepend		_L("\t")
+#define KRTestFailed			_L("RTEST: FAIL : Failed with error %d\n")
+
+//forwd decl
+class CHttpTestBase;
+
+//##ModelId=3C4C4C420207
+class CHTTPTestUtils : public CBase, public TDesOverflow
+//
+//	Test harness providing logging features
+	{
+public:
+	//##ModelId=3C4C4C430136
+	IMPORT_C static CHTTPTestUtils* NewLC(const TDesC& aTitle);
+	//##ModelId=3C4C4C43012C
+	IMPORT_C static CHTTPTestUtils* NewL(const TDesC& aTitle);
+	//##ModelId=3C4C4C430122
+	~CHTTPTestUtils();
+	//##ModelId=3C4C4C430118
+	IMPORT_C void JustStartTestL(const TDesC& aName);
+	//##ModelId=3C4C4C430104
+	IMPORT_C void StartTestL(const TDesC& aName);
+	//##ModelId=3C4C4C4300FA
+	IMPORT_C void JustEndTest();
+	//##ModelId=3C4C4C4300E6
+	IMPORT_C void NextStep(const TDesC& aStepName);
+	//##ModelId=3C4C4C4300DC
+	IMPORT_C void EndTest(TInt aErrorCode);
+	//##ModelId=3C4C4C4300BE
+	IMPORT_C void LogIt(TRefByValue<const TDesC> aFmt, ...);
+	//##ModelId=3C4C4C43008D
+	IMPORT_C void operator()(TInt aResult,TInt aLineNum);
+	//##ModelId=3C4C4C4300B4
+	IMPORT_C void operator()(TInt aResult);
+	//##ModelId=3C4C4C43008C
+	IMPORT_C void PressAnyKey();
+	//##ModelId=3C4C4C43006E
+	IMPORT_C void DumpData(const TDesC8& aData, TBool logIt = EFalse);
+	//##ModelId=3C4C4C430050
+	IMPORT_C void GetAnEntry(const TDesC & ourPrompt, TDes & currentstring);
+	//##ModelId=3C4C4C430032
+	IMPORT_C TInt GetSelection(const TDesC& ourPrompt, const TDesC& validChoices);
+	//##ModelId=3C4C4C43001E
+	IMPORT_C void SetScript(RFile& scriptFile);
+	//##ModelId=3C4C4C43000B
+	inline void DoResourceLeakTest(TBool aValue);
+	//##ModelId=3C4C4C43000A
+	inline RTest& Test();
+
+	//##ModelId=3C4C4C4203DF
+	inline static void DefaultLogFileName(TDes& aFileName);
+
+	//##ModelId=3C4C4C4203DE
+	IMPORT_C static void InitCommsL();
+	//##ModelId=3C4C4C4203D4
+	IMPORT_C static void HoldOpenConnectionL();
+	//##ModelId=3C4C4C4203CB
+	IMPORT_C static void ReleaseConnectionL();
+
+	//##ModelId=3C4C4C4203CA
+	inline TBool IsSilent() const;
+	//##ModelId=3C4C4C4203B6
+	inline void SetSilent(TBool aSilent);
+
+	//##ModelId=3C4C4C42038E
+	IMPORT_C TInt ResolveFile(const TDesC& aComponent, const TDesC& aFileName, TParse& aParseOut);
+	//##ModelId=3C4C4C42037A
+	IMPORT_C HBufC8* ReadFileLC(const TDesC& aFile);
+
+	IMPORT_C void CleanupFailedTestsArray ();
+	IMPORT_C void CreateFailedTestsArrayL ();
+private:	// Methods from TDesOverflow
+
+	IMPORT_C virtual void Overflow(TDes& aDes);
+
+private:
+	//##ModelId=3C4C4C420366
+	CHTTPTestUtils(const TDesC& aTitle);
+	//##ModelId=3C4C4C420352
+	void ConstructL(const TDesC& aTitle);
+	//##ModelId=3C4C4C420348
+	void Panic(TInt aPanic);
+	//##ModelId=3C4C4C42033E
+	void TestHarnessFailed();
+	//##ModelId=3C4C4C420335
+	void TestHarnessComplete();
+	//##ModelId=3C4C4C420334
+	void ResourceLeakTest();
+	//##ModelId=3C4C4C420320
+	inline void WriteComment(const TDesC& aComment);
+	//##ModelId=3C4C4C42030C
+	TInt ReadLineFromScript(TDes& aBuffer);
+
+	//##ModelId=3C4C4C420302
+	void CreateLogFiles(const TDesC& aTestName);
+
+	void Print(const TDesC& aDescriptor);
+
+
+private:
+	//	Helper class to store failed tests
+	class CTestInfo;
+	enum TPanicCode
+		{
+		EBadStartTest,
+		EBadEndTest,
+		EBadCLogPtr
+		};
+private:
+	//##ModelId=3C4C4C4202F8
+	RTest iTest;
+	//##ModelId=3C4C4C4202E6
+	RFs iFs;
+	//##ModelId=3C4C4C4202D0
+	RFile* iScriptFile;
+	__DECLARE_LOG	
+	//##ModelId=3C4C4C4202BE
+	RFileLogger iTestSummaryLogger;
+	//##ModelId=3C4C4C4202B2
+	TInt iTestCount;
+	//##ModelId=3C4C4C42029F
+	CArrayPtrFlat<CTestInfo>* iFailedTests;
+	//##ModelId=3C4C4C42027F
+	TTime iStartTime;
+	//##ModelId=3C4C4C420263
+	TBool iCanStartTest;
+	//##ModelId=3C4C4C420259
+	TInt iStepNumber;
+	//##ModelId=3C4C4C42024F
+	TInt iStartHandleCount;
+	//##ModelId=3C4C4C420243
+	TBool iDoResourceLeakTest;
+	//##ModelId=3C4C4C420239
+	TBool iScriptRunning;
+	//##ModelId=3C4C4C420227
+	TBool iSilent; // if true logs only to file and not to console
+	//##ModelId=3C4C4C42021E
+	CTestInfo* iCurrentTest;
+	};
+
+class CHTTPTestUtils::CTestInfo : public CBase
+//
+//	Holds test number and name
+	{
+public:
+	static CTestInfo* NewLC(const TDesC& aName, TInt aNumber, TInt aErrorCode);
+	static CTestInfo* NewL(const TDesC& aName, TInt aNumber, TInt aErrorCode);
+	~CTestInfo();
+
+	void SetNameL(const TDesC& aName);
+	void SetNumber(TInt aNumber);
+	void SetErrorCode(TInt aErrorCode);
+
+	inline TPtr Name() const;
+	inline TInt Number() const;
+	inline TInt ErrorCode() const;
+private:
+	CTestInfo();
+	void ConstructL(const TDesC& aName, TInt aNumber, TInt aErrorCode);
+private:
+	HBufC* iName;
+	TInt iNumber;
+	TInt iErrorCode;
+	};
+
+#include "httptestutils.inl"
+
+#endif	//	__HTTPTESTUTILS_H__