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