--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/windowing/windowserver/tauto/openwfc/AUTO.H Tue Feb 02 01:47:50 2010 +0200
@@ -0,0 +1,669 @@
+// Copyright (c) 1995-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:
+// Header for window server auto test code
+//
+//
+
+
+#ifndef __AUTO_H__
+#define __AUTO_H__
+
+#include <e32std.h>
+#include <e32math.h>
+#include "../../SERVER/w32cmd.h"
+#include <w32std.h>
+#include "../tlib/testbase.h"
+#include <wsautotest.mbg>
+#include "TGraphicsHarness.h"
+#include "../../SERVER/openwfc/panics.h"
+
+#define DISABLE_FAIL_DIALOG
+
+#define TEST_BITMAP_NAME _L("Z:\\WSTEST\\WSAUTOTEST.MBM")
+
+#define SCREEN_MODE_TESTING
+
+#define LOG_MESSAGE(p) LogMessage(((TText8*)__FILE__), __LINE__,(p))
+#define LOG_MESSAGE2(p1,p2) LogMessage(((TText8*)__FILE__), __LINE__,(p1),(p2))
+#define LOG_MESSAGE3(p1,p2,p3) LogMessage(((TText8*)__FILE__), __LINE__,(p1),(p2),(p3))
+#define LOG_MESSAGE4(p1,p2,p3,p4) LogMessage(((TText8*)__FILE__), __LINE__,(p1),(p2),(p3),(p4))
+#define LOG_MESSAGE5(p1,p2,p3,p4,p5) LogMessage(((TText8*)__FILE__), __LINE__,(p1),(p2),(p3),(p4),(p5))
+#define LOG_MESSAGE6(p1,p2,p3,p4,p5,p6) LogMessage(((TText8*)__FILE__), __LINE__,(p1),(p2),(p3),(p4),(p5),(p6))
+#define LOG_MESSAGE7(p1,p2,p3,p4,p5,p6,p7) LogMessage(((TText8*)__FILE__), __LINE__,(p1),(p2),(p3),(p4),(p5),(p6),(p7))
+
+// MB 23\11\04 The heap size was only 4k which was causing DSA step 7 to fail on HW.
+// Increased heap size to 8k
+// 23/02/2009 Again failing with no memory due to COLOR16MAP used.
+// Increased heap size to 16k
+LOCAL_D const TUint KOtherProcHeapSize=0x4000;
+LOCAL_D const TInt KAutoTestPriority=-20;
+
+TBool DoCheckRect(CTBaseWin *aWin1,CTBaseWin *aWin2,const TRect &aRect);
+TBool DoCheckRect(CTBaseWin *aWin1,CTBaseWin *aWin2,const TRect &aRect, TUint aFlags);
+TBool DoCheckRectRWin(RWindowBase &aWin1,RWindowBase &aWin2,const TRect &aRect);
+TBool DoCheckRectRWin(RWindowBase &aWin1,RWindowBase &aWin2,const TRect &aRect, TUint aFlags);
+TBool DoCheckRect(CTBaseWin *aWin1,CTBaseWin *aWin2);
+TBool DoCheckRect(TPoint aPos1,TPoint aPos2,TSize aSize);
+
+_LIT(KWSERV,"WSERV");
+_LIT(KW32,"W32");
+_LIT(KPlatsecBegin,"*PlatSec* ERROR - BEGIN NEGATIVE PLATSEC TESTING");
+_LIT(KPlatsecEnd,"*PlatSec* ERROR - END NEGATIVE PLATSEC TESTING");
+_LIT(KTestFontTypefaceName,"DejaVu Sans Condensed");
+
+class TestClient;
+class CMinWin;
+class CTWsGraphicsBase;
+
+enum TestState
+ {
+ EInvalid,
+ ENext,
+ EWait,
+ EFinished
+ };
+
+enum TAutoPanics
+ {
+ EAutoPanicTestFailed,
+ EAutoPanicPanicFailed,
+ EAutoPanicTestRectsIndex,
+ EAutoPanicTestRectsSection,
+ EAutoPanicUnexpectedLeave,
+ EAutoPanicTestBrushesIndex,
+ EAutoPanicWindowType,
+ EAutoPanicTooManyDownKeys,
+ EAutoPanicInvalidEvent,
+ EAutoFadeWindow,
+ EAutoPanicWrongTest,
+ EAutoPanicAnimError,
+ ETManPanicPcFailed, //Panic use in a test copied from TMan
+ EAutoPanicTestError, //Test returned bad return type
+ EAutoPanicDirect, //Direct Screen Access logic state error
+ EAutoPanicScanCapital, //Scan codes must not be lower case letters
+ EAutoPanicRedrawStoring, //Inconsistent Redraw Storing Behaviour
+ EAutoPanicRecalledCreateTestBaseL, //Called CreateTestBaseL twice
+ EAutoPanicHeartBeatCursorRect, //Invalid size of rectangle in ChangeTransAndCheckHeartBeat
+ EAutoPanicGroupWinHasChild, //Main test group window has child at start of test
+ EAutoPanicPanicSetTrans, //Error setting transparency during panic tests
+ EAutoPanicNoDigitiser, //Pointer event when the configuration has no digitiser
+ };
+
+enum TPanicExitReasons
+ {
+ EWsExitReasonBad,
+ EWsExitReasonFinished,
+ };
+
+enum TAutoLeaves
+ {
+ ETestPassed=0,
+ ETestFailed=1,
+ };
+
+typedef TInt (*TPanicFunction)(TInt aInt, TAny *aPtr);
+
+struct SPanicParams
+ {
+ TInt num;
+ TPanicFunction func;
+ TAny *ptr;
+ };
+
+class LogWindow : public CTWin
+ {
+ enum
+ {
+ EDummyValue=-9999
+ };
+public:
+ LogWindow();
+ void ConstructL(CTWinBase& aParent);
+ void Draw();
+ void DrawSubTitle();
+ void DrawMessage();
+ void LogTest(const TDesC &aTitle,TInt aNum);
+ const TDesC& LogSubTest(const TDesC &aTitle,TInt aNum);
+ const TDesC& LogMessage(TBool aLog,const TDesC& aText,TInt aNum=EDummyValue);
+private:
+ TBuf<0x40> iTestTitle;
+ TBuf<0x40> iSubTitle;
+ TBuf<0x40> iMessage;
+ TInt iTitleHeight;
+ };
+
+class CTestBase;
+
+/**
+This class is a window that is used to fake a border around the TestWindow defined below.
+It simply draws an opaque black window on top of which the TestWindow will be drawn giving the illusion
+there is a border.
+
+@see TestWindow
+@internalComponent
+@released
+*/
+class CBorderWindow : public CTWin
+ {
+public:
+ CBorderWindow();
+ void ConstructL(CTWinBase& aParent);
+ void Draw();
+ };
+
+class TestWindow : public CTWin
+ {
+public:
+ TestWindow();
+ ~TestWindow();
+ void Draw();
+ void SetUpL(TPoint aPos, TSize aSize, CTWinBase* aParent, CWindowGc& aGc);
+ void ClearWin();
+ void SetBorderExt(TPoint aPos, TSize aSize);
+ CBorderWindow* GetBorderWin();
+private:
+ CBorderWindow* iBorderWin;
+ };
+
+/**
+This class used to run each individual test before the migration to TEF.
+Now it doesn't do much and should probably be refactored.
+
+@internalComponent
+@released
+*/
+class CTestDriver : public CBase
+ {
+public:
+ /** Factory function that returns a class derived from CTestDriver */
+ static CTestDriver* CreateL(TInt aScreenNumber);
+ virtual ~CTestDriver();
+
+protected:
+ CTestDriver(TInt aScreenNumber);
+
+public:
+ virtual void DoDisplayDialog(TDesC& timeBuf,TDesC& testReport) = 0;
+
+ void TestComplete2();
+ void DestroyTest();
+
+ inline TInt ScreenNumber() {return iScreenNumber;}
+ inline TInt NumberOfScreens() {return iNumberOfScreens;}
+
+public:
+ CTestBase *iTest;
+ TInt iSubTestNum;
+ static TInt iTestNum;
+protected:
+ TTime iStartTime;
+ TInt iScreenNumber;
+ TInt iTestSize;
+ TInt iNumberOfScreens;
+ };
+
+/** Variant of CTestDriver used when the tests are run on the primary screen.
+
+@internalComponent
+@released
+*/
+class CTestDriverPrimary: public CTestDriver
+ {
+public:
+ CTestDriverPrimary(TInt aScreenNumber);
+ void DoDisplayDialog(TDesC& timeBuf,TDesC& testReport);
+ };
+
+/** Variant of CTestDriver used when the tests are run on a secondary screen.
+
+@internalComponent
+@released
+*/
+class CTestDriverSecondary : public CTestDriver
+ {
+public:
+ CTestDriverSecondary(TInt aScreenNumber);
+ void DoDisplayDialog(TDesC& timeBuf,TDesC& testReport);
+ };
+
+/** List of rectangles use by TGDI.CPP and TRECTLIST.CPP.
+
+Since only 2 tests make use of this shouldn't it be moved outside of the framework?
+
+@internalComponent
+@released
+*/
+class TTestRects
+ {
+private:
+ enum TRectListLimits
+ {
+ EMaxRectFromList=64,
+ EMaxRectZeroSize=73,
+ EMaxRectWide=83,
+ EMaxRectHigh=93
+ };
+
+public:
+ void Construct(const RWindow &aWindow);
+ TInt Count1() const;
+ TInt Count2() const;
+ TInt Count3() const;
+ TRect operator[](TInt aIndex);
+ static void ResetSeed();
+private:
+ TInt Rnd(TInt aSize);
+ TInt RndMax(TInt aSize);
+ TInt RectCoord(TInt aSection,TInt aSize);
+ void RectCoordPair(TInt &aTl, TInt &aBr, TInt aSection, TInt aSize);
+
+private:
+ TSize iSize;
+ static TRect iList[64];
+ static TInt64 iSeed;
+ };
+
+/**
+@internalComponent
+@released
+*/
+class CBitmap : public CBase
+ {
+public:
+ static CBitmap* NewLC(const TSize& aSizeInPixels,TDisplayMode aDispMode);
+ static CBitmap* NewL(const TSize& aSizeInPixels,TDisplayMode aDispMode);
+ static CBitmap* NewL(TInt aHandle);
+ static CBitmap* NewL(TDesC& aFileName);
+ ~CBitmap();
+ inline CFbsBitmap& Bitmap() const {return *iBitmap;}
+ inline CFbsBitmapDevice& Device() const {return *iDevice;}
+ inline CFbsBitGc& Gc() const {return *iGc;}
+private:
+ static CBitmap* NewLC(TInt aHandle,const TSize& aSizeInPixels,TDisplayMode aDispMode);
+ void ConstructL(TInt aHandle,const TSize& aSizeInPixels,TDisplayMode aDispMode);
+private:
+ CFbsBitmap* iBitmap;
+ CFbsBitmapDevice* iDevice;
+ CFbsBitGc* iGc;
+ };
+
+/*TPartialRedrawType*/
+enum TPartialRedrawType
+ {
+ //redraw store type is not yet determined.
+ EPartialRedraw_Unknown,
+ //redraw store is discarded on invalidation and begin-redraw on a smaller rect.
+ EPartialRedraw_None,
+ // redraw store is preserved on invalidation and begin-redraw on a smaller rect.
+ EPartialRedraw_PreserveStoredCmds,
+ // redraw store is appended with partial redraw commands, and old redraw store is suitably modified.
+ EPartialRedraw_FullRedrawSupport
+ };
+
+class CTestBase : public CBase
+ {
+public:
+ enum TPriorites
+ {
+ EAutoTestPriority=KAutoTestPriority
+ };
+ enum TTestLevel
+ {
+ ELevelQuick, // Quick check on main cases for each function
+ ELevelNormal, // Suitable test level for internal release
+ ELevelRelease, // Thorough test suitable for official releases
+ ELevelMega, // Really OTT, takes forever to run, leave it going over the weekend sort of tests
+ };
+public:
+ CTestBase(const TDesC &aTitle,CTWsGraphicsBase* aTestBase);
+ ~CTestBase();
+ void StartTestL(TInt aNum, CTestDriver* aDriver, TTestLevel aLevel);
+ void LogSubTest(const TDesC &aTitle);
+ void LogMessage(TInt aValue);
+ void LogSubState(TInt aSubState);
+ TInt LaunchPanicThread(RThread &aThread, SPanicParams *aPtr);
+ TInt TestPanicL(SPanicParams *aPtr, TInt aExitReason, const TDesC &aCategory, TBool* aTestFinished=NULL);
+ TInt TestPanicL(TPanicFunction aFunction, TInt aExitReason, TInt aInt, TAny *aPtr, const TDesC &aCategory, TBool* aTestFinished=NULL);
+ TInt TestWsPanicL(TPanicFunction aFunction, TClientPanic aExitReason, TInt aInt, TAny *aPtr=NULL, TBool* aTestFinished=NULL);
+ TInt TestW32PanicL(TPanicFunction aFunction, TW32Panic aExitReason, TInt aInt, TAny *aPtr, TBool* aTestFinished=NULL);
+ TInt TestWservPanicL(TPanicFunction aFunction, TWservPanic aExitReason, TInt aInt, TAny *aPtr);
+ void TriggerFail();
+ static void DrawTestBackground(TBool aInvertColours, const TSize &aSize, TInt aGrays=16);
+ inline CTestDriver* Driver();
+ void SimulatePointer(TRawEvent::TType aType, TInt aX, TInt aY);
+ TBool ConfigurationSupportsPointerEventTesting() const;
+ void SimulateEvent(TRawEvent::TType aType);
+ void LogColors(const CBitmapDevice& aDevice,TPoint aBasePoint, TPoint aStartPoint, TPoint aEndPoint);
+ void LogColors4(const CBitmapDevice& aDevice,TPoint aStartPoint,TInt aLen);
+ inline TInt ScreenNumber() {return iScreenNumber;}
+ TPartialRedrawType RedrawStoreTypeL();
+ TBool IsFullRomL();
+ void SimulateKeyDownUpWithModifiers(TInt aScanCode,TUint aModifiers);
+ void SimulatePointerDownUp(TInt aX, TInt aY);
+ void SimulateKeyDownUp(TInt aScanCode);
+ void SimulateKey(TRawEvent::TType aType, TInt aScanCode);
+ void DelayIfFullRomL();
+ void SetUpMember(TSpriteMember &aMember);
+ void AbortL();
+ void LogLeave(TInt aErr);
+ void CloseAllPanicWindows();
+ const TSize& StdTestWindowSize();
+ TInt MaxGrays() const;
+ TInt MaxColors() const;
+ TInt SaveScreen(const TDesC& aFileName);
+ TInt SaveScreen(const TDesC& aFileName,const TSize& aScreenSize,TDisplayMode aColorDepth);
+protected:
+ void UpdateTestResults(TInt aNoOfTest, TInt aNoOfTestPass);
+ void SaveScreenL(const TDesC& aFileName,const TSize& aScreenSize,TDisplayMode aColorDepth);
+public:
+ static TInt iNumberTestsPass;
+ static TInt iNumberTests;
+ TInt iState;
+ TInt iScreenNumber;
+ static TInt iScreenNo;
+ TTestRects iTestRects;
+ static TRect iNormalPointerCursorArea;
+ TBuf<0x40> iSubTitle;
+ TTestLevel iTestLevel;
+ static TInt iNumberOfGrpWndsOnPrimaryScreenWithZeroPriority; // Will be used in TGWHANDLE test.
+protected:
+ CTestDriver* iDriver;
+private:
+ TBuf<0x40> iTitle;
+ CTWsGraphicsBase* iTestBase;
+ /**
+ Several tests use 3 windows : one is a log window, one is a reference window
+ and one is the actual output of the test. All these windows have the same width which is roughly
+ 1/3 of the screen. They also have the same height which is roughly equal to the screen height.
+ */
+ TSize iStdTestWindowSize;
+ CMinWin* iMinWin;
+ TInt iTestNum;
+ TBool iFail; // Used to trigger failures to test test code.
+ TInt iThreadNumber;
+ /**
+ The type of redraw store in use. Static members so that RedrawStoreTypeL computes
+ this value only once and then returns the cached result as this remains the same for
+ the entire test run.
+ */
+ static TPartialRedrawType iRedrawType;
+ /** The number of greys available in the richest grey mode. */
+ static TInt iMaxGrays;
+ /** The number of colours available in the richest supported colour mode. */
+ static TInt iMaxColors;
+ };
+
+class CTWsGraphicsBase : public CTGraphicsBase
+ {
+public:
+ CTWsGraphicsBase(CTestStep* aStep);
+ ~CTWsGraphicsBase();
+ void CreateTestBaseL(CTTMSGraphicsStep* aTmsStep);
+ inline CTestBase *TestBase() const {return(iTest);};
+ void TestComplete();
+ void LogMessage(const TText8* aFile,TInt aLine,TRefByValue<const TDesC> aFmt,...);
+ TInt GetScreenFromIni() const;
+protected:
+ void CheckRect(TPoint aPos1,TPoint aPos2,TSize aSize, const TDesC *aErrorMsg=NULL);
+ void CheckRect(TPoint aPos1,TPoint aPos2,TSize aSize, const TDesC &aErrorMsg);
+ void CheckRectNoMatch(TPoint aPos1,TPoint aPos2,TSize aSize, const TDesC *aErrorMsg=NULL);
+ void CheckRectNoMatch(TPoint aPos1,TPoint aPos2,TSize aSize, const TDesC &aErrorMsg);
+ void CheckRect(CTBaseWin *aWin1,CTBaseWin *aWin2, const TDesC *aErrorMsg=NULL);
+ void CheckRect(CTBaseWin *aWin1,CTBaseWin *aWin2, const TDesC &aErrorMsg);
+ void CheckRectNoMatch(CTBaseWin *aWin1,CTBaseWin *aWin2, const TDesC *aErrorMsg=NULL);
+ void CheckRectNoMatch(CTBaseWin *aWin1,CTBaseWin *aWin2, const TDesC &aErrorMsg);
+ TBool CheckRect(CTBaseWin *aWin1,CTBaseWin *aWin2,const TRect &aRect, const TDesC *aErrorMsg=NULL);
+ TBool CheckRect(CTBaseWin *aWin1,CTBaseWin *aWin2,const TRect &aRect, const TDesC &aErrorMsg);
+ void CheckRectNoMatch(CTBaseWin *aWin1,CTBaseWin *aWin2,const TRect &aRect, const TDesC *aErrorMsg=NULL);
+ void CheckRectNoMatch(CTBaseWin *aWin1,CTBaseWin *aWin2,const TRect &aRect, const TDesC &aErrorMsg);
+ TBool CompareWindows(const TDesC *aErrorMsg=NULL);
+ TBool CompareWindows(const TDesC &aErrorMsg);
+ void CompareWindows(const TRect &aRect, const TDesC *aErrorMsg=NULL);
+ void CompareWindows(const TRect &aRect, const TDesC &aErrorMsg);
+ void CompareWindowsSoftFailWinscw(const TText8* aFile, TInt aLine);
+ const TSize& StdTestWindowSize();
+ TInt MaxGrays() const;
+ TInt MaxColors() const;
+private:
+ TBool CheckRetValue(TBool aPass,const TDesC* aErrorMsg,const TDesC& aErrorFunction);
+protected:
+ CTestBase* iTest;
+ CTTMSGraphicsStep* iTmsStep;
+ };
+
+class TestWindowGroup : public CTWindowGroup
+ {
+public:
+ TestWindowGroup(CTClient *aClient);
+ void BecomeOwning();
+ void KeyL(const TKeyEvent &aKey,const TTime &aTime);
+ void KeyDownL(const TKeyEvent &aKey,const TTime &aTime);
+ void KeyUpL(const TKeyEvent &aKey,const TTime &aTime);
+ };
+
+class TestClient : public CTClient
+ {
+public:
+ TestClient();
+ ~TestClient();
+ void ConstructL(); // virtual from CTClient
+ void KeyL(const TKeyEvent &aKey,const TTime &aTime);
+ void Shutdown();
+ inline CTestDriver* Driver();
+ TBool WaitForEvent();
+ TBool IsEventWaiting();
+ void LogAvailableScreenModeL();
+ void TestWsSetBufferSizeL();
+ void TestWsSetMaxBufferSizeL();
+ inline LogWindow& StdLogWindow() {return *iStdLogWindow;}
+ void SetTestClientScreenMode(TInt aMode);
+ void UpdateTestClientScreenMode();
+public:
+ RArray<TInt> iScreenModes;
+
+private:
+ /**
+ Several tests use 3 windows : one is a log window, one is a reference window
+ and one is the actual output of the test. This member is the log window.
+ */
+ LogWindow* iStdLogWindow;
+ CTestDriver* iDriver;
+ };
+
+class TThreadStartUp
+ {
+public:
+ TThreadStartUp() :iInitFunction(0), iParam(0) {}
+ TThreadStartUp(TThreadFunction aInitFunction,TAny* aParam) :iInitFunction(aInitFunction), iParam(aParam) {}
+public:
+ TThreadFunction iInitFunction; //The call to this fn will prepare a cleanup stack, but this function should not leave.
+ TAny* iParam;
+ };
+
+#if defined(__WINS__)
+ const TOwnerType KOwnerType=EOwnerThread;
+#else
+ const TOwnerType KOwnerType=EOwnerProcess;
+#endif
+
+typedef TBuf<32> TBufArg;
+
+class CProcess : public CBase
+ {
+public:
+ enum
+ {
+ eProcessPriortyTest,
+ eProcessKeyTest,
+ eProcessDirectTest,
+ eProcessMultiDisplayTest,
+ eNumProcessCalls //Must be last one
+ };
+ struct TInitialFunction
+ {
+ inline TInitialFunction(const TDesC& aParam,TThreadFunction aFunction) :iParam(aParam), iFunction(aFunction) {}
+ TBuf<16> iParam;
+ TThreadFunction iFunction;
+ };
+public:
+ static TInt Start(const TWinCommand& aParam);
+ static CProcess* NewL(TInt aFunctionNo,TInt aScreenNumber=KDefaultScreen);
+ static CProcess* NewTL(TInt aFunctionNo,TInt aScreenNumber=KDefaultScreen,TRequestStatus* aClientRequestStatus = NULL);
+ static CProcess* NewThreadL(const TDesC& aName,TThreadFunction aFunction,TThreadStartUp* aPtr
+ ,TRequestStatus* aStatus);
+ static CProcess* NewThreadL(const TDesC& aName,TThreadStartUp* aPtr);
+ static CProcess* NewThreadRendezvousL(const TDesC& aName,TThreadFunction aFunction,TThreadStartUp* aPtr,TRequestStatus* aLogonStatus,TRequestStatus& aRendezvousStatus);
+ static CProcess* NewThreadRendezvousL(const TDesC& aName,TThreadStartUp* aPtr,TRequestStatus& aRendezvousStatus);
+
+ static CProcess* NewSimpleThreadL(const TDesC& aName,TThreadStartUp* aPtr,TRequestStatus* aStatus=NULL);
+ void ConstructL(TInt aFunctionNo,TInt aScreenNumber=KDefaultScreen);
+ void ConstructTL(TInt aFunctionNo,TInt aScreenNumber=KDefaultScreen,TRequestStatus* aStatus=NULL);
+ void ConstructL(const TDesC& aName,TThreadFunction aFunction,TThreadStartUp* aPtr,TRequestStatus* aStatus);
+ void ConstructRendezvousL(const TDesC& aName,TThreadFunction aFunction,TThreadStartUp* aPtr,TRequestStatus* aLogonStatus,TRequestStatus& aRendezvousStatus);
+
+ ~CProcess();
+ void Logon(TRequestStatus& aStatus) const;
+ void Terminate(TInt aReason);
+ TBool StillAlive();
+ void LeaveIfDied();
+ static TBool ProcessDied(TInt aScreenNo=KDefaultScreen);
+private:
+ enum
+ {
+ eOtherCreated=0x0001,
+ eThreadCreated=0x0002,
+ };
+private:
+ static TInt ThreadInit(TAny *aPtr);
+ static void InitialiseL(TThreadStartUp* aPtr);
+ static TInt SimpleThreadInit(TAny *aPtr);
+ void Close();
+ static void GetProcArg(const TWinCommand& aParam,TBufArg& aProcArg);
+ static void GetScreenArg(const TWinCommand& aParam, TInt& aScreenArg);
+
+private:
+ TUint iCreated;
+ RProcess iOther;
+ RThread iThread;
+ static TInitialFunction iFunctions[eNumProcessCalls];
+ };
+
+GLREF_D TestWindow* BaseWin;
+GLREF_D TestWindow* TestWin;
+GLREF_D TestClient* TheClient;
+GLREF_D CWindowGc* TheGc;
+
+GLREF_C void AutoPanic(TInt aPanic);
+GLREF_C void CleanUpWindow(TAny *aWindow);
+GLREF_C void PushWindowL(RWindowTreeNode *aWindow);
+GLREF_C TBool OpacityAndAlphaSupportedL();
+GLREF_C TInt TransparencySupportedL();
+GLREF_C TInt CheckScalingSupportedOrNot();
+GLREF_C TBool CheckNonZeroOriginsSupportedOrNot();
+GLREF_C TPoint PhysicalToLogical(TPoint aPhysicalPtMinusOrigin,TSize aScale);
+GLREF_C TPtrC DisplayModeAsString(TDisplayMode aMode);
+GLREF_C TBool LossyCheckBlankBitmap(const CFbsBitmap& aBitmap, const TRect aArea, const TRgb aCheckColor, TBool aLossyCompare=ETrue);
+GLREF_C TBool LossyCompareBitmap(const CFbsBitmap& aBitmap1, const CFbsBitmap& aBitmap2, const TRect aCompareRect, TBool aLossyCompare=ETrue);
+GLDEF_C TBool LossyCompareBitmapRecord(CFbsBitmap& aBitmap1, CFbsBitmap& aBitmap2, const TRect aCompareRect, TBool aLossyCompare, TInt& aPixelsDifferent, CTestExecuteLogger& aLogger);
+GLREF_C TBool LossyCheckBlankWindow(const CWsScreenDevice& aScreen, CFbsBitmap& aBitmap, const TRect aArea, const TRgb aCheckColor);
+GLREF_C TBool LossyCompareWindow(const CWsScreenDevice& aScreen, CFbsBitmap& aBitmap1, CFbsBitmap& aBitmap2, const TRect aCompareRect);
+
+#define LogText(S) {_LIT(String__LINE__,S); Logger.Log(String__LINE__);}
+#define LogFormat(S) {Logger.Log(S);}
+
+inline CTestDriver* CTestBase::Driver()
+ {
+ return iDriver;
+ }
+
+class CTransWindow : public CBlankWindow
+ {
+public:
+ static CTransWindow* NewL(RPointerArray<CTransWindow>& aWindows,TRgb aColor,TRect aPos);
+ static CTransWindow* NewL(CTWinBase* aParent,TRgb aColor,TRect aPos,TDisplayMode* aDisplayMode);
+ static CTransWindow* NewL(CTWinBase* aParent,TRgb aColor,TDisplayMode* aDisplayMode);
+ void ToggleVisibility();
+ static void SetOrdinal(RPointerArray<CTransWindow>& aWindows,TInt aOldPos,TInt aNewPos);
+ inline TRgb Color() {return iCol;}
+ inline TBool IsVisible() {return iVisible;}
+ void SetShadowDisabled(TBool aState);
+ inline TBool IsShadowing() {return iShadowing;}
+ inline TBool ShadowHeight() {return iShadowHight;}
+ inline void SetPosOffset(TPoint aOffset) {iPosOffset=aOffset;}
+ virtual void Draw();
+ void SetDrawOpaque(TBool aDrawOpaque) { iDrawOpaque = aDrawOpaque; }
+ TBool DrawOpaque() const { return iDrawOpaque; }
+ //Virtual functions from CTWinBase overridden in CTBaseWin
+ void AdjustShadow(TInt aAdjust);
+ TPoint Position() const;
+ inline TInt TransparentError() {return iError;}
+private:
+ CTransWindow(TRgb aColor) :CBlankWindow(aColor), iVisible(ETrue) {}
+ //Virtual function from CTBaseWin
+ void InitWin();
+private:
+ TBool iVisible;
+ TBool iShadowing;
+ TBool iDrawOpaque;
+ TInt iShadowHight;
+ TPoint iPosOffset;
+ TInt iError;
+ };
+
+class CMinWin : public CBase
+ {
+public:
+ CMinWin(TInt aScreenNo);
+ ~CMinWin();
+ void ConstructL();
+ void Draw(const TRect& aRect);
+private:
+ RWsSession iWs;
+ RWindow iWin;
+ RWindowGroup iGroup;
+ CWsScreenDevice* iScr;
+ TInt iScreenNo;
+ TRect iRect;
+ CWindowGc* iGc;
+ };
+
+class CTimeOut : public CTimer
+ {
+public:
+ inline CTimeOut(): CTimer((EPriorityLow+EPriorityIdle)/2) {}
+ void ConstructL();
+ void Start(TTimeIntervalMicroSeconds32 aInterval,TCallBack aCallBack);
+ //Pure virtual from CActive
+ void RunL();
+private:
+ TCallBack iCallBack;
+ };
+
+#define COMPARE_WINDOWS_SOFTFAIL_WINSCW CompareWindowsSoftFailWinscw((TText8*)__FILE__, __LINE__)
+
+#define __WS_CONSTRUCT_STEP__(a) \
+ CT##a##Step::CT##a##Step() \
+ { \
+ SetTestStepName(KT##a##Step); \
+ SetLogHeapInfo(ETrue); \
+ } \
+ \
+CTGraphicsBase* CT##a##Step::CreateTestL() \
+ { \
+ CTWsGraphicsBase* test=new (ELeave) CT##a (this); \
+ test->CreateTestBaseL(this);\
+ return test;\
+ }
+
+#endif