appfw/uiftestfw/inc/appfwk_test_AppUi.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Mon, 21 Jun 2010 15:51:07 +0300
branchRCL_3
changeset 47 312d2b433792
parent 13 096dad6e50a9
permissions -rw-r--r--
Revision: 201023 Kit: 2010125

// Copyright (c) 2005-2010 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:
//

/**
 @file
 @test
 @internalComponent - Internal Symbian test code 
*/


#ifndef __APPFWK_TEST_APPUI_H__
#define __APPFWK_TEST_APPUI_H__

#include <e32std.h>
#include <e32base.h>
#include <coeaui.h>
#include <eikappui.h>

#include <test/testexecutestepbase.h>

#include <test/appfwk_tmsteststep.h>

// user panic descriptors
_LIT(KPanicNullPointer,"Null pointer");

//user panic errors
const TInt KNullPointer = 1;


/********************************************************************/
/*																	*/
/*																	*/
/*		MAutoTestApp												*/
/*																	*/
/*																	*/
/********************************************************************/

class MAutoTestApp
	{
public:
	virtual void RunTestStepL(TInt aNextStep)=0; // this function needs to be implemented by the derived class of either CTestCoeAppUi or CTestAppUi
	};


/********************************************************************/
/*																	*/
/*																	*/
/*		CAutoTestManager											*/
/*																	*/
/*																	*/
/********************************************************************/

/**
  The test code manager, provides functions to set active object  with lowest priority for running test in auto mode.
*/
class CAutoTestManager : public CActive
	{
public:
	enum TTestResult
		{
		EPass,
		EFailed,
		EUnknown,
		};
public:
	IMPORT_C ~CAutoTestManager();
	IMPORT_C static CAutoTestManager* NewL(MAutoTestApp* aAutoTestApp);
	IMPORT_C void StartAutoTest(); //init active object and set it active
	IMPORT_C void FinishAllTestCases(TTestResult aTestResult);	//every test program should call this function in order to 
						 										//stop the consequence of test steps by 
																//closing active sheduler
	IMPORT_C void SetTestCaseNumber(TInt aNumber);
	inline TTestResult	GetTestResult() const;
private: 
	IMPORT_C CAutoTestManager(MAutoTestApp* aAutoTestApp);
	void RunL();
	void DoCancel();
private:
	MAutoTestApp* iAutoTestApp;
	TInt iNumStep;
	TTestResult	iResult;
	};

inline CAutoTestManager::TTestResult	CAutoTestManager::GetTestResult() const
	{
	return iResult;
	}


/********************************************************************/
/*																	*/
/*																	*/
/*		CTestCoeAppUi												*/
/*																	*/
/*																	*/
/********************************************************************/

/**
  The abstract class is base for test programs, incapsulates the CAutoTestManager member.
  The class doesn't handles work with resources.

  It is supposed that a derived class in its ConstructL(); function first of all has to calls the ConstructL() function of the parent class.
*/

class CTestCoeAppUi : public CCoeAppUi, public MAutoTestApp
	{
public:
	IMPORT_C CTestCoeAppUi(CTmsTestStep* aStep);
	IMPORT_C ~CTestCoeAppUi();
	IMPORT_C void ConstructL(); // should be called from ConstructL of the child class
	CTestExecuteLogger&	Logger() {return iStep->Logger();}
	inline void testBooleanTrue(TBool aCondition, const TText8* aFile, TInt aLine) 
		{
		iStep -> testBooleanTrue(aCondition, aFile, aLine);
		}

	// provide access to TMS methods
	inline void SetTestStepID(const TDesC& aStepName)
		{
		iStep->SetTestStepID( aStepName );
		}
	inline void RecordTestResultL()
		{
		iStep->RecordTestResultL();
		}
	inline void MultipleResultsForSameID( TBool aShowMultipleResults )
		{
		iStep->MultipleResultsForSameID( aShowMultipleResults );
		}
	inline void CloseTMSGraphicsStep()
		{
		iStep->CloseTMSGraphicsStep();
		}
	void testBooleanTrueL(TBool aCondition, const TText8* aFile, TInt aLine);
	void testBooleanTrueWithErrorCode(TBool aCondition, TInt aErrorCode, const TText8* aFile, TInt aLine );
	void testBooleanTrueWithErrorCodeL(TBool aCondition, TInt aErrorCode, const TText8* aFile, TInt aLine );
	void TestCheckPointCompareL(TInt aVal, TInt aExpectedVal, const TDesC& aText, const TText8* aFile, TInt aLine);

protected:
	inline CAutoTestManager& AutoTestManager() const;
	
	CTmsTestStep*		iStep;

private:
	CAutoTestManager* iAutoTestManager;
	};

CAutoTestManager& CTestCoeAppUi::AutoTestManager() const
	{
	return *iAutoTestManager;
	}


class CEikButtonGroupContainer;
class CEikMenuBar;

/********************************************************************/
/*																	*/
/*																	*/
/*		CTestAppUi													*/
/*																	*/
/*																	*/
/********************************************************************/

/**
  The abstract class is base for test programs, incapsulates the CAutoTestManager member.
  The class handles work with resources.

  It is supposed that a derived class in its ConstructL(); function first of all has to calls the ConstructL() function of the parent class.
*/
class CTestAppUi : public CEikAppUi, public MAutoTestApp
	{
public:
	IMPORT_C CTestAppUi(CTmsTestStep*	aStep, const TDesC& aRes, TInt aResourceHotKeysId = 0, TInt aResourceMenuBarId = 0, TInt aResourceToolBarId = 0);
	IMPORT_C ~CTestAppUi();
	IMPORT_C void ConstructL(); // should be called from ConstructL of the child class
	CTestExecuteLogger&	Logger() {return iStep->Logger();}
	inline void testBooleanTrue(TBool aCondition, const TText8* aFile, TInt aLine) 
		{
		iStep -> testBooleanTrue(aCondition, aFile, aLine, ETrue);
		}

	// provide access to TMS methods
	inline void SetTestStepID(const TDesC& aStepName)
		{
		iStep->SetTestStepID( aStepName );
		}
	inline void RecordTestResultL()
		{
		iStep->RecordTestResultL();
		}
	inline void MultipleResultsForSameID( TBool aShowMultipleResults )
		{
		iStep->MultipleResultsForSameID( aShowMultipleResults );
		}
	inline void CloseTMSGraphicsStep()
		{
		iStep->CloseTMSGraphicsStep();
		}

protected:
	inline CAutoTestManager& AutoTestManager() const;
	IMPORT_C void ReduceRect(TRect& aRect) const;	//reduce client rectangle if toolbar or/and menu exist hide menu from screen
	IMPORT_C void ProcessCommandL(TInt aCommand);

private:
	CAutoTestManager* iAutoTestManager;

	TInt iResourceFileFlag;
	CEikButtonGroupContainer *iToolBar;
	CEikMenuBar	*iMenuBar;
	
	TInt iResourceHotKeysId;
	TInt iResourceMenuBarId;
	TInt iResourceToolBarId;
	TFileName iRes;

protected:
	CTmsTestStep *iStep;
	};

CAutoTestManager& CTestAppUi::AutoTestManager() const
	{
	return *iAutoTestManager;
	}

//to prevent from alloc memory error in the User::__DbgMarkEnd 
//we need to call this function if we are using  CCoeEnv and memory heap macros
IMPORT_C void PreallocateHALBuffer();

//to prevent test fail due to panic dialog on screen 
//we need to call this function if we the test we are running is sensitive to dialogs being on screen.
IMPORT_C void CloseAllPanicWindowsL();

#endif	// __APPFWK_TEST_APPUI_H__