classicui_pub/queries_api/tsrc/src/testsdkqueries.cpp
branchRCL_3
changeset 20 d48ab3b357f1
parent 0 2f259fa3e83a
equal deleted inserted replaced
19:aecbbf00d063 20:d48ab3b357f1
       
     1 /*
       
     2 * Copyright (c) 2002 - 2007 Nokia Corporation and/or its subsidiary(-ies).
       
     3 * All rights reserved.
       
     4 * This component and the accompanying materials are made available
       
     5 * under the terms of "Eclipse Public License v1.0"
       
     6 * which accompanies this distribution, and is available
       
     7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
       
     8 *
       
     9 * Initial Contributors:
       
    10 * Nokia Corporation - initial contribution.
       
    11 *
       
    12 * Contributors:
       
    13 *
       
    14 * Description:  Test queries_api
       
    15 *
       
    16 */
       
    17 
       
    18 
       
    19 
       
    20 // INCLUDE FILES
       
    21 #include <stiftestinterface.h>
       
    22 #include <settingserverclient.h>
       
    23 #include <screensaverinternalpskeys.h>
       
    24 #include <e32property.h>
       
    25 
       
    26 #include "testsdkqueries.h"
       
    27 #include "testsdkqueriesview.h"
       
    28 #include "testsdkqueriescontainer.h"
       
    29 
       
    30 // CONSTANTS
       
    31 _LIT( KModuleName, "testsdkqueries.dll" );
       
    32 
       
    33 // ============================ MEMBER FUNCTIONS ===============================
       
    34 
       
    35 // -----------------------------------------------------------------------------
       
    36 // Ctestsdkqueries::Ctestsdkqueries
       
    37 // C++ default constructor can NOT contain any code, that
       
    38 // might leave.
       
    39 // -----------------------------------------------------------------------------
       
    40 //
       
    41 CTestSDKQueries::CTestSDKQueries( CTestModuleIf& aTestModuleIf ):
       
    42     CScriptBase( aTestModuleIf )
       
    43     {
       
    44     }
       
    45 
       
    46 // -----------------------------------------------------------------------------
       
    47 // Ctestsdkqueries::ConstructL
       
    48 // Symbian 2nd phase constructor can leave.
       
    49 // -----------------------------------------------------------------------------
       
    50 //
       
    51 void CTestSDKQueries::ConstructL()
       
    52     {
       
    53     
       
    54     iView = CTestSDKQueriesView::NewL();
       
    55     iContainer = CTestSDKQueriesContainer::NewL( iView->ClientRect(), iContainer );
       
    56     
       
    57     
       
    58     //Read logger settings to check whether test case name is to be
       
    59     //appended to log file name.
       
    60     RSettingServer settingServer;
       
    61     CleanupClosePushL( settingServer );
       
    62     TInt ret = settingServer.Connect();
       
    63     if ( ret != KErrNone )
       
    64         {
       
    65         User::Leave(ret);
       
    66         }
       
    67     // Struct to StifLogger settigs.
       
    68     TLoggerSettings loggerSettings; 
       
    69     // Parse StifLogger defaults from STIF initialization file.
       
    70     ret = settingServer.GetLoggerSettings( loggerSettings );
       
    71     if ( ret != KErrNone )
       
    72         {
       
    73         User::Leave( ret );
       
    74         } 
       
    75     // Close Setting server session
       
    76     settingServer.Close();
       
    77     CleanupStack::PopAndDestroy( &settingServer );
       
    78 
       
    79     TFileName logFileName;
       
    80     
       
    81     if ( loggerSettings.iAddTestCaseTitle )
       
    82         {
       
    83         TName title;
       
    84         TestModuleIf().GetTestCaseTitleL( title );
       
    85         logFileName.Format( KtestsdkqueriesLogFileWithTitle, &title );
       
    86         }
       
    87     else
       
    88         {
       
    89         logFileName.Copy( KtestsdkqueriesLogFile );
       
    90         }
       
    91 
       
    92     iLog = CStifLogger::NewL( KtestsdkqueriesLogPath, 
       
    93                           logFileName,
       
    94                           CStifLogger::ETxt,
       
    95                           CStifLogger::EFile,
       
    96                           EFalse );
       
    97     
       
    98     iOffset = CCoeEnv::Static()->AddResourceFileL(_L("C:\\resource\\testsdkqueries.rsc"));
       
    99     
       
   100     SendTestClassVersion();
       
   101     
       
   102     TurnOffScreenSaver();
       
   103     }
       
   104 
       
   105 // -----------------------------------------------------------------------------
       
   106 // Ctestsdkqueries::NewL
       
   107 // Two-phased constructor.
       
   108 // -----------------------------------------------------------------------------
       
   109 //
       
   110 CTestSDKQueries* CTestSDKQueries::NewL( CTestModuleIf& aTestModuleIf )
       
   111     {
       
   112     CTestSDKQueries* self = new( ELeave ) CTestSDKQueries( aTestModuleIf );
       
   113 
       
   114     CleanupStack::PushL( self );
       
   115     self->ConstructL();
       
   116     CleanupStack::Pop( self );
       
   117 
       
   118     return self;
       
   119 
       
   120     }
       
   121 
       
   122 // Destructor
       
   123 CTestSDKQueries::~CTestSDKQueries()
       
   124     { 
       
   125 
       
   126     // Delete resources allocated from test methods
       
   127     Delete();
       
   128 
       
   129     // Delete logger
       
   130     delete iLog; 
       
   131 
       
   132     CCoeEnv::Static()->DeleteResourceFile( iOffset );
       
   133 
       
   134     RestoreScreenSaver();
       
   135     }
       
   136 
       
   137 //-----------------------------------------------------------------------------
       
   138 // Ctestsdkqueries::SendTestClassVersion
       
   139 // Method used to send version of test class
       
   140 //-----------------------------------------------------------------------------
       
   141 //
       
   142 void CTestSDKQueries::SendTestClassVersion()
       
   143     {
       
   144     TVersion moduleVersion;
       
   145     moduleVersion.iMajor = TEST_CLASS_VERSION_MAJOR;
       
   146     moduleVersion.iMinor = TEST_CLASS_VERSION_MINOR;
       
   147     moduleVersion.iBuild = TEST_CLASS_VERSION_BUILD;
       
   148 
       
   149     TFileName moduleName;
       
   150     moduleName = KModuleName;
       
   151 
       
   152     TBool newVersionOfMethod = ETrue;
       
   153     TestModuleIf().SendTestModuleVersion( moduleVersion, moduleName, 
       
   154         newVersionOfMethod );
       
   155     }
       
   156 
       
   157 // ========================== OTHER EXPORTED FUNCTIONS =========================
       
   158 
       
   159 // -----------------------------------------------------------------------------
       
   160 // LibEntryL is a polymorphic Dll entry point.
       
   161 // Returns: CScriptBase: New CScriptBase derived object
       
   162 // -----------------------------------------------------------------------------
       
   163 //
       
   164 EXPORT_C CScriptBase* LibEntryL( 
       
   165     CTestModuleIf& aTestModuleIf ) // Backpointer to STIF Test Framework
       
   166     {
       
   167     return ( CScriptBase* ) CTestSDKQueries::NewL( aTestModuleIf );
       
   168     }
       
   169 
       
   170 // -----------------------------------------------------------------------------
       
   171 // Turn off ScreenSaver
       
   172 // -----------------------------------------------------------------------------
       
   173 //
       
   174 void CTestSDKQueries::TurnOffScreenSaver()
       
   175     {
       
   176     TInt err1 = RProperty::Get( KPSUidScreenSaver, KScreenSaverAllowScreenSaver, 
       
   177         iOldScreenSaverProperty );
       
   178     TInt err2 = RProperty::Set( KPSUidScreenSaver, KScreenSaverAllowScreenSaver, 
       
   179         KScreenSaverAllowScreenSaver );    
       
   180     RDebug::Printf( "screensaver property=%d err1=%d err2=%d\n", 
       
   181         iOldScreenSaverProperty, err1, err2 );
       
   182     }
       
   183 
       
   184 // -----------------------------------------------------------------------------
       
   185 // Restore ScreenSaver
       
   186 // -----------------------------------------------------------------------------
       
   187 //
       
   188 void CTestSDKQueries::RestoreScreenSaver()
       
   189     {
       
   190     RProperty::Set( KPSUidScreenSaver, KScreenSaverAllowScreenSaver, 
       
   191         iOldScreenSaverProperty );
       
   192     User::ResetInactivityTime();
       
   193     }
       
   194 
       
   195 
       
   196 //  End of File
       
   197 
       
   198 
       
   199