author | Gareth Stockwell <gareth.stockwell@accenture.com> |
Fri, 22 Oct 2010 11:38:29 +0100 | |
branch | bug235_bringup_0 |
changeset 206 | c170e304623f |
parent 0 | 5d03bc08d59c |
permissions | -rw-r--r-- |
// Copyright (c) 2008-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: // @file // // #include <e32std.h> #include <e32math.h> #include <w32std.h> #include <w32debug.h> #include <e32base.h> #include "teflogextensions.h" #include "globalsettings.h" #include "CWsGceCscBase.h" #include <bitdraw.h> #include <bitdrawinterfaceid.h> #include <imageconversion.h> #include <test/tefunit.h> CWsGceCscBase::CWsGceCscBase(): iDoTearDown(EFalse), iUtility(this, NULL) { } CWsGceCscBase::~CWsGceCscBase() { if (iDoTearDown) TearDownFromDeleteL(); //This mechanism is not entirely clean to use. } void CWsGceCscBase::SetupL() { iDoTearDown=ETrue; iRed.SetInternal(0xFFFF0000); iGreen.SetInternal(0xFF00FF00); iBlue.SetInternal(0xFF0000FF); iCyan.SetInternal(0xFF00FFFF); iMagenta.SetInternal(0xFFFF00FF); iYellow.SetInternal(0xFFFFFF00); iWhite.SetInternal(0xFFFFFFFF); ASSERT_EQUALS_X(iSession.Connect(), KErrNone); {//Stolen from TAuto CloseAllPanicWindows() TInt idFocus = iSession.GetFocusWindowGroup(); TWsEvent event; event.SetType(EEventKey); //EEventKeyDown TKeyEvent *keyEvent = event.Key(); keyEvent->iCode = EKeyEscape; keyEvent->iScanCode = EStdKeyEscape; keyEvent->iModifiers = 0; TInt theLimit = 50; while(idFocus != NULL && (theLimit-- > 0)) { iSession.SendEventToAllWindowGroups(event); TInt idNewFocus = iSession.GetFocusWindowGroup(); if (idNewFocus!=idFocus) { INFO_PRINTF1(_L("A window was closed [probably a panic box from the previous test].")); } idFocus=idNewFocus; } } TInt err = KErrNone; TRAP(err, iScreenDevice = new (ELeave) CWsScreenDevice(iSession)); PRINT_ON_ERROR2_L(err, _L("Failed to create screen device: %d"), err); ASSERT_EQUALS_X(iScreenDevice->Construct(TGlobalSettings::Instance().iScreen), KErrNone); iDisplayMode = iScreenDevice->DisplayMode(); // Get default display mode TRAP(err, iGc = new (ELeave) CWindowGc(iScreenDevice)); PRINT_ON_ERROR2_L(err, _L("Failed to create graphics context: %d"), err); ASSERT_EQUALS_X(iGc->Construct(), KErrNone); iGroup = RWindowGroup(iSession); ASSERT_EQUALS_X(iGroup.Construct(++iWindowHandle,iScreenDevice), KErrNone); iSession.Flush(); RWindow testTrans(iSession); ASSERT_EQUALS_X(testTrans.Construct(iGroup, ++iWindowHandle), KErrNone); iTransparencyEnabled=(testTrans.SetTransparencyFactor(iWhite)==KErrNone); testTrans.Close(); //clean-up if previous test abended if (PostTestCleanupInstance().iSharedUtility) { //Temp removed - may be causing ONB fails! // if (PostTestCleanupInstance().iSharedUtility->DestroyAll()) // { // INFO_PRINTF1(_L("Destroyed some surfaces from previous test.")); // // } } if (!PostTestCleanupInstance().iCleanedUpOnExit) PostTestCleanupInstance().iCleanedUpOnExit=EFalse; if (!GCEIsSupported()) { INFO_PRINTF1(_L("Some Setup skipped: GCE support is not loaded")); return; } TRAPD(err_FailedToCreateSurfaceUtility, iUtility = CSurfaceUtility::NewL( PostTestCleanupInstance().iSharedUtility)); ASSERT_EQUALS(err_FailedToCreateSurfaceUtility,KErrNone); } void CWsGceCscBase::TearDownL() { iDoTearDown=EFalse; delete iGc; delete iScreenDevice; iGroup.Close(); iSession.Flush(); iSession.Close(); delete iUtility(); PostTestCleanupInstance().iCleanedUpOnExit=ETrue; Pause(1000); } void CWsGceCscBase::TearDownFromDeleteL() { CWsGceCscBase::TearDownL(); } void CWsGceCscBase::Pause(TInt aMilliseconds) { User::After(TTimeIntervalMicroSeconds32(aMilliseconds * 1000)); } /** Test using an indipendent method that GCE version of WServ is running * This method can only be called after the testcase is started * * @return true if WServ version is GCE technology, false if legacy technology **/ TBool CWsGceCscBase::GCEIsSupported() const { CFbsDrawDevice* screenDevice=NULL; TDisplayMode displayMode=iScreenDevice->DisplayMode(); TRAPD(err, screenDevice = CFbsDrawDevice::NewScreenDeviceL(TGlobalSettings::Instance().iScreen, displayMode)); TBool rv=EFalse; if(err == KErrNone) { TAny* p=NULL; rv=(screenDevice->GetInterface(KSurfaceInterfaceID, p)==KErrNone); delete screenDevice; } return rv; } /** Test using an indipendent method that GCE version of WServ is running * This method can be called at any time, even by external code, but creates temporary window session objects * * @return true if WServ version is GCE technology, false if legacy technology **/ TBool CWsGceCscBase::GCEIsSupportedStatic() { CFbsDrawDevice* screenDevice=NULL; RWsSession session; if (session.Connect()!=KErrNone) { return EFalse; } CWsScreenDevice screen(session); if (screen.Construct(TGlobalSettings::Instance().iScreen)!=KErrNone) { return EFalse; } TDisplayMode displayMode=screen.DisplayMode(); TRAPD(err, screenDevice = CFbsDrawDevice::NewScreenDeviceL(TGlobalSettings::Instance().iScreen, displayMode)); TBool rv=EFalse; if(err == KErrNone) { TAny* p=NULL; rv=(screenDevice->GetInterface(KSurfaceInterfaceID, p)==KErrNone); delete screenDevice; } return rv; } //Allocating an instance of surface utility here means all test code instances will share the same instance of the utility class. // Owns the singleton CWsGceCscBase::TPostTestCleanup& CWsGceCscBase::PostTestCleanupInstance() { static class RPostTestCleanup:public TPostTestCleanup { public: RPostTestCleanup() { iSharedUtility=NULL; iCleanedUpOnExit=ETrue; } ~RPostTestCleanup() { // I want to cleanly release the surface utility, but at this point the threads have already been pulled down! // if (iSharedUtility) // delete iSharedUtility; iSharedUtility=NULL; //avoid phoenix behaviour } } staticInstance; return staticInstance; } // This handles any non-member uses of the extended ASSERT_XXX macros extern void TefUnitFailLeaveL(); /** * side-effect: log the state info just before I leave! * Note that this only logs intentional assertion failures. * Fails due to panics or throws won't log this info. **/ void CWsGceCscBase::TefUnitFailLeaveL() { for (TInt line=0;line<KMaxInfoLines;line++) if (iTestInfo[line].Length()) Logger().LogExtra((TText8*)"Test state at fail - line",line, ESevrAll, iTestInfo[line]); TGlobalSettings::Instance().Report(Logger()); User::Leave(KErrTEFUnitFail); } TInt CWsGceCscBase::DebugInfo(TWsDebugInfoFunc aFunction, TInt aParam, TDes8& aHostBuffer, const void*&aReturnedObject, TInt aObjectSize)const { TInt reqSize=iSession.DebugInfo(aFunction,aHostBuffer,aParam); aReturnedObject=NULL; if (reqSize<0) { if ((reqSize%aObjectSize)!=0) { return KErrCorrupt; } else { return reqSize; } } if (reqSize>aHostBuffer.MaxLength()) { return reqSize/aObjectSize; } if (reqSize==0) { reqSize=aHostBuffer.MaxLength(); } if ((reqSize%aObjectSize)!=0) { return KErrCorrupt; } aReturnedObject=(const void*)aHostBuffer.Ptr(); reqSize/=aObjectSize; return reqSize; } void CWsGceCscBase::SetCompositionMode(RWindow& aWindow, TDisplayMode aMode) { iDisplayMode = (TDisplayMode)aWindow.SetRequiredDisplayMode(aMode); aWindow.Invalidate(); aWindow.BeginRedraw(); aWindow.EndRedraw(); } TBool CWsGceCscBase::Compare(CFbsBitmap& aBitmap1, CFbsBitmap& aBitmap2) { if ((aBitmap1.SizeInPixels() == aBitmap2.SizeInPixels()) && (aBitmap1.DisplayMode() == aBitmap2.DisplayMode())) { TSize size = aBitmap1.SizeInPixels(); TInt width = size.iWidth; TInt height = size.iHeight; TRgb color1, color2; for (TInt i = 0; i < width; i++) { for (TInt j = 0; j < height; j++) { aBitmap1.GetPixel(color1, TPoint(i, j)); aBitmap2.GetPixel(color2, TPoint(i, j)); if (color1 != color2) { return EFalse; } } } return ETrue; } return EFalse; } void CWsGceCscBase::ConstructOpaqueWindowL(RWindow& aWindow, const TRgb& aColor, TInt aPos, const TPoint &aPoint, const TSize &aSize) { ASSERT_EQUALS_X(aWindow.Construct(iGroup, ++iWindowHandle), KErrNone); aWindow.SetRequiredDisplayMode(iDisplayMode); aWindow.SetExtent(aPoint, aSize); aWindow.SetBackgroundColor(aColor); aWindow.SetOrdinalPosition(aPos); aWindow.Activate(); aWindow.BeginRedraw(); iGc->Activate(aWindow); iGc->Deactivate(); aWindow.EndRedraw(); } void CWsGceCscBase::ConstructOpaqueWindowLC(RWindow& aWindow, const TRgb& aColor, TInt aPos, const TPoint &aPoint, const TSize &aSize) { ASSERT_EQUALS_X(aWindow.Construct(iGroup, ++iWindowHandle), KErrNone); CleanupClosePushL(aWindow); aWindow.SetRequiredDisplayMode(iDisplayMode); aWindow.SetExtent(aPoint, aSize); aWindow.SetBackgroundColor(aColor); aWindow.SetOrdinalPosition(aPos); aWindow.SetVisible(ETrue); aWindow.Activate(); aWindow.BeginRedraw(); iGc->Activate(aWindow); iGc->Clear(); iGc->Deactivate(); aWindow.EndRedraw(); } void CWsGceCscBase::SetBackgroundColorWindow(RWindow& aWindow, const TRgb& aColor) { aWindow.Invalidate(); aWindow.SetBackgroundColor(aColor); aWindow.BeginRedraw(); iGc->Activate(aWindow); iGc->Deactivate(); aWindow.EndRedraw(); } void CWsGceCscBase::ConstructOpaqueSurfacedWindowLC(RWindow& aWindow, const TRgb& aColor, TInt aPos, const TPoint &aPoint, const TSize &aSize, TSurfaceId& aSurfaceID) { ASSERT_EQUALS_X(aWindow.Construct(iGroup, ++iWindowHandle), KErrNone); CleanupClosePushL(aWindow); aWindow.SetRequiredDisplayMode(iDisplayMode); aWindow.SetExtent(aPoint, aSize); aWindow.SetBackgroundColor(aColor); aWindow.SetOrdinalPosition(aPos); ASSERT_EQUALS_X(aWindow.SetBackgroundSurface(aSurfaceID), KErrNone); aWindow.Activate(); aWindow.BeginRedraw(); iGc->Activate(aWindow); iGc->Deactivate(); aWindow.EndRedraw(); } void CWsGceCscBase::ConstructOpaqueSurfacedWindowL(RWindow& aWindow, const TRgb& aColor, TInt aPos, const TPoint& aPoint, const TSize& aSize, const TSurfaceId& aSurfaceID) { ASSERT_EQUALS_X(aWindow.Construct(iGroup, ++iWindowHandle), KErrNone); aWindow.SetRequiredDisplayMode(iDisplayMode); aWindow.SetExtent(aPoint, aSize); aWindow.SetBackgroundColor(aColor); aWindow.SetOrdinalPosition(aPos); ASSERT_EQUALS_X(aWindow.SetBackgroundSurface(aSurfaceID), KErrNone); aWindow.Activate(); aWindow.BeginRedraw(); iGc->Activate(aWindow); iGc->Deactivate(); aWindow.EndRedraw(); }