diff -r e5af45d51884 -r 31fccae4f8a7 uiaccelerator_plat/alf_extension_api/tsrc/src/testalfext.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/uiaccelerator_plat/alf_extension_api/tsrc/src/testalfext.cpp Wed Sep 01 12:16:53 2010 +0100 @@ -0,0 +1,198 @@ +/* +* Copyright (c) 2002 - 2007 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: functions implement of testalfext +* +*/ + + + +// INCLUDE FILES +#include +#include +#include +#include +#include +#include +#include "testalfext.h" + +// CONSTANTS +_LIT( KModuleName, "testalfext.dll" ); +const TInt KHuiCtrlGroupId = 1; +// ============================ MEMBER FUNCTIONS =============================== + +// ----------------------------------------------------------------------------- +// CTestAlfExt::CTestAlfExt +// C++ default constructor can NOT contain any code, that +// might leave. +// ----------------------------------------------------------------------------- +// +CTestAlfExt::CTestAlfExt( CTestModuleIf& aTestModuleIf ): + CScriptBase( aTestModuleIf ) + { + } + +// ----------------------------------------------------------------------------- +// CTestAlfExt::~CTestAlfExt +// Destructor. +// ----------------------------------------------------------------------------- +// +CTestAlfExt::~CTestAlfExt() + { + // Delete logger + delete iLog; + delete iInterface; + delete iHuiEnv; + + } + +// ----------------------------------------------------------------------------- +// CTestAlfExt::ConstructL +// Symbian 2nd phase constructor can leave. +// ----------------------------------------------------------------------------- +// +void CTestAlfExt::ConstructL() + { + //Read logger settings to check whether test case name is to be + //appended to log file name. + RSettingServer settingServer; + CleanupClosePushL( settingServer ); + TInt ret = settingServer.Connect(); + if ( ret != KErrNone ) + { + User::Leave(ret); + } + // Struct to StifLogger settigs. + TLoggerSettings loggerSettings; + // Parse StifLogger defaults from STIF initialization file. + ret = settingServer.GetLoggerSettings( loggerSettings ); + if ( ret != KErrNone ) + { + User::Leave( ret ); + } + // Close Setting server session + settingServer.Close(); + CleanupStack::PopAndDestroy( &settingServer ); + + TFileName logFileName; + + if ( loggerSettings.iAddTestCaseTitle ) + { + TName title; + TestModuleIf().GetTestCaseTitleL( title ); + logFileName.Format( KtestalfextLogFileWithTitle, &title ); + } + else + { + logFileName.Copy( KtestalfextLogFile ); + } + + iLog = CStifLogger::NewL( KtestalfextLogPath, + logFileName, + CStifLogger::ETxt, + CStifLogger::EFile, + EFalse ); + + iInterface = new ( ELeave ) + CTestAlfInterfacePorvider; + + iHuiEnv = CHuiEnv::NewL( EHuiRendererBitgdi ); + iHuiControlGroup = &( iHuiEnv->NewControlGroupL( KHuiCtrlGroupId ) ); + //Construct the iHuiControl + iHuiControl = new( ELeave ) CHuiControl( *iHuiEnv ); + iHuiControl->ConstructL(); + iHuiControlGroup->AppendL( iHuiControl ); + iHuiVisual = CHuiVisual::AddNewL( *iHuiControl); + + SendTestClassVersion(); + + TurnOffScreenSaver(); + } + +// ----------------------------------------------------------------------------- +// CTestAlfExt::NewL +// Two-phased constructor. +// ----------------------------------------------------------------------------- +// +CTestAlfExt* CTestAlfExt::NewL( CTestModuleIf& aTestModuleIf ) + { + CTestAlfExt* self = new( ELeave ) CTestAlfExt( aTestModuleIf ); + + CleanupStack::PushL( self ); + self->ConstructL(); + CleanupStack::Pop( self ); + + return self; + + } + +//----------------------------------------------------------------------------- +// CTestAlfExt::SendTestClassVersion +// Method used to send version of test class +//----------------------------------------------------------------------------- +// +void CTestAlfExt::SendTestClassVersion() + { + TVersion moduleVersion; + moduleVersion.iMajor = TEST_CLASS_VERSION_MAJOR; + moduleVersion.iMinor = TEST_CLASS_VERSION_MINOR; + moduleVersion.iBuild = TEST_CLASS_VERSION_BUILD; + + TFileName moduleName; + moduleName = KModuleName; + + TBool newVersionOfMethod = ETrue; + TestModuleIf().SendTestModuleVersion( moduleVersion, moduleName, + newVersionOfMethod ); + } + +// ========================== OTHER EXPORTED FUNCTIONS ========================= + +// ----------------------------------------------------------------------------- +// LibEntryL is a polymorphic Dll entry point. +// Returns: CScriptBase: New CScriptBase derived object +// ----------------------------------------------------------------------------- +// +EXPORT_C CScriptBase* LibEntryL( + CTestModuleIf& aTestModuleIf ) // Backpointer to STIF Test Framework + { + return ( CScriptBase* ) CTestAlfExt::NewL( aTestModuleIf ); + } + +// ----------------------------------------------------------------------------- +// Turn off ScreenSaver +// ----------------------------------------------------------------------------- +// +void CTestAlfExt::TurnOffScreenSaver() + { + TInt err1 = RProperty::Get( KPSUidScreenSaver, KScreenSaverAllowScreenSaver, + iOldScreenSaverProperty ); + TInt err2 = RProperty::Set( KPSUidScreenSaver, KScreenSaverAllowScreenSaver, + KScreenSaverAllowScreenSaver ); + RDebug::Printf( "screensaver property=%d err1=%d err2=%d\n", + iOldScreenSaverProperty, err1, err2 ); + } + +// ----------------------------------------------------------------------------- +// Restore ScreenSaver +// ----------------------------------------------------------------------------- +// +void CTestAlfExt::RestoreScreenSaver() + { + RProperty::Set( KPSUidScreenSaver, KScreenSaverAllowScreenSaver, + iOldScreenSaverProperty ); + User::ResetInactivityTime(); + } + + +// End of File