xml/legacyminidomparser/xmlparser/test/GmxmlTestUtils.h
author hgs
Mon, 13 Sep 2010 13:16:40 +0530
changeset 34 c7e9f1c97567
parent 0 xml/legacyminidomparser/XMLParser/test/GmxmlTestUtils.h@e35f40988205
permissions -rw-r--r--
201037

// 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:
//

#ifndef GMXML_TEST_UTILS_H_
#define GMXML_TEST_UTILS_H_

#include <f32file.h>
#include <e32test.h>
#include <simtsy.h>


//	Constants

//Test Harness Logging

#define KLogsDir				_L("c:\\logs\\")
#define KTestHeader				_L("Test Results")
#define KTestStartingWithDesc	_L("Test %d Starting (%S)")
#define KTestPassed				_L("Test %d OK")
#define KTestFailed				_L("Test %d FAILED (error = %d)")
#define KTestHarnessCompleted	_L("Tests Completed")
#define KTestHarnessFailed		_L("Tests FAILED (error = %d)")
#define KTestCommentPrepend		_L("    ")

#define KTestShowMenu			_L("/manual")


//
//
// CTestTimer
//
//

class CTestTimer : public CTimer
	{
public:
	static CTestTimer* NewL();
	void AfterReq(TTimeIntervalMicroSeconds32 aSec, TRequestStatus& aStatus);
protected:
	CTestTimer();
	void RunL();

private:
	TRequestStatus* iReport;
	};

//
//
// CTestUtils
//
//

class CTestUtils : public CBase
	{
public:
//File Logging

	void TestStart(TInt aTest, const TDesC& aTestDescription);
	void TestFinish(TInt aTest, TInt aError = KErrNone);
	void TestHarnessCompleted();
	void TestHarnessFailed(TInt aError);
	void WriteComment(const TDesC& aComment);


//Test Utils
	
	 virtual void CreateAllTestDirectories();
    
	// File location
	
	
	TInt ResolveLogFile(const TDesC& aFileName, TParse& aParseOut);

	void Printf(TRefByValue<const TDesC> aFmt,...); //prints to RTest and LogFile, depending on iLogToConsole and iLogToFile


	inline RTest& Test() const;

	 TBool RunAuto() const;
	 void SetRunAuto(TBool aRunAuto = ETrue);

public:

protected:
	virtual void ConstructL();
	CTestUtils(RTest& aRTest);
	~CTestUtils();


	virtual void Panic(TInt aPanic) = 0;

	void AppendTestName(TDes &aFileName);
	void AppendVariantName(TDes& aFileName);

	TInt OpenMainLogL();
	void CloseMainLog();
	void WriteToLog(TRefByValue<const TDesC> aFmt,...);



protected:

	RFs						iFs;
	RFile					iFile;
	RTest&					iRTest;
	TBool					iLogToConsole;
	TBool					iLogToFile;

	TBool					iRunAuto;
	HBufC*					iLogBuf;
	HBufC8*					iLogBuf8;

	};

class TTestOverflow : public TDes16Overflow
	{
public:
	TTestOverflow(CTestUtils& aTest)
		: iTest(aTest) {};

	// TDes16Overflow pure virtual
	virtual void Overflow(TDes16& /*aDes*/) {iTest.Printf(_L("ERROR: Printf Overflow\n")); iTest.Test()(EFalse);};

private:
	CTestUtils& iTest;
	};



#include "GmxmlTestUtils.inl"

#endif