locationtriggering/tsrc/lbtengine_test/LbtUnitTestModule/src/LbtUnitTestModule.cpp
author hgs
Mon, 27 Sep 2010 16:57:22 +0530
changeset 50 4c28d569e1fe
permissions -rw-r--r--
201037_001
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
50
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
     1
/*
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). 
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
     3
* All rights reserved.
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
     8
*
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
     9
* Initial Contributors:
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    11
*
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    12
* Contributors:
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    13
* 
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    14
* Description: This file contains testclass implementation.
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    15
*
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    16
*/
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    17
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    18
// INCLUDE FILES
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    19
#include <StifTestInterface.h>
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    20
#include "LbtUnitTestModule.h"
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    21
#include <SettingServerClient.h>
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    22
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    23
// EXTERNAL DATA STRUCTURES
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    24
//extern  ?external_data;
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    25
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    26
// EXTERNAL FUNCTION PROTOTYPES  
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    27
//extern ?external_function( ?arg_type,?arg_type );
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    28
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    29
// CONSTANTS
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    30
//const ?type ?constant_var = ?constant;
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    31
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    32
// MACROS
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    33
//#define ?macro ?macro_def
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    34
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    35
// LOCAL CONSTANTS AND MACROS
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    36
//const ?type ?constant_var = ?constant;
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    37
//#define ?macro_name ?macro_def
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    38
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    39
// MODULE DATA STRUCTURES
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    40
//enum ?declaration
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    41
//typedef ?declaration
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    42
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    43
// LOCAL FUNCTION PROTOTYPES
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    44
//?type ?function_name( ?arg_type, ?arg_type );
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    45
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    46
// FORWARD DECLARATIONS
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    47
//class ?FORWARD_CLASSNAME;
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    48
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    49
// ============================= LOCAL FUNCTIONS ===============================
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    50
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    51
// -----------------------------------------------------------------------------
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    52
// ?function_name ?description.
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    53
// ?description
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    54
// Returns: ?value_1: ?description
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    55
//          ?value_n: ?description_line1
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    56
//                    ?description_line2
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    57
// -----------------------------------------------------------------------------
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    58
//
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    59
/*
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    60
?type ?function_name(
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    61
    ?arg_type arg,  // ?description
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    62
    ?arg_type arg)  // ?description
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    63
    {
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    64
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    65
    ?code  // ?comment
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    66
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    67
    // ?comment
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    68
    ?code
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    69
    }
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    70
*/
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    71
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    72
// ============================ MEMBER FUNCTIONS ===============================
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    73
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    74
// -----------------------------------------------------------------------------
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    75
// CLbtUnitTestModule::CLbtUnitTestModule
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    76
// C++ default constructor can NOT contain any code, that
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    77
// might leave.
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    78
// -----------------------------------------------------------------------------
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    79
//
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    80
CLbtUnitTestModule::CLbtUnitTestModule( 
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    81
    CTestModuleIf& aTestModuleIf ):
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    82
        CScriptBase( aTestModuleIf )
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    83
    {
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    84
    }
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    85
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    86
// -----------------------------------------------------------------------------
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    87
// CLbtUnitTestModule::ConstructL
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    88
// Symbian 2nd phase constructor can leave.
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    89
// -----------------------------------------------------------------------------
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    90
//
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    91
void CLbtUnitTestModule::ConstructL()
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    92
    {
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    93
    //Read logger settings to check whether test case name is to be
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    94
    //appended to log file name.
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    95
    RSettingServer settingServer;
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    96
    TInt ret = settingServer.Connect();
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    97
    if(ret != KErrNone)
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    98
        {
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
    99
        User::Leave(ret);
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   100
        }
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   101
    // Struct to StifLogger settigs.
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   102
    TLoggerSettings loggerSettings; 
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   103
    // Parse StifLogger defaults from STIF initialization file.
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   104
    ret = settingServer.GetLoggerSettings(loggerSettings);
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   105
    if(ret != KErrNone)
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   106
        {
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   107
        User::Leave(ret);
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   108
        } 
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   109
    // Close Setting server session
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   110
    settingServer.Close();
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   111
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   112
    TFileName logFileName;
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   113
    
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   114
    if(loggerSettings.iAddTestCaseTitle)
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   115
        {
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   116
        TName title;
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   117
        TestModuleIf().GetTestCaseTitleL(title);
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   118
        logFileName.Format(KLbtUnitTestModuleLogFileWithTitle, &title);
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   119
        }
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   120
    else
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   121
        {
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   122
        logFileName.Copy(KLbtUnitTestModuleLogFile);
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   123
        }
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   124
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   125
    iLog = CStifLogger::NewL( KLbtUnitTestModuleLogPath, 
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   126
                          logFileName,
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   127
                          CStifLogger::ETxt,
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   128
                          CStifLogger::EFile,
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   129
                          EFalse );
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   130
    
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   131
    iWait = new ( ELeave ) CActiveSchedulerWait;
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   132
    }
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   133
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   134
// -----------------------------------------------------------------------------
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   135
// CLbtUnitTestModule::NewL
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   136
// Two-phased constructor.
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   137
// -----------------------------------------------------------------------------
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   138
//
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   139
CLbtUnitTestModule* CLbtUnitTestModule::NewL( 
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   140
    CTestModuleIf& aTestModuleIf )
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   141
    {
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   142
    CLbtUnitTestModule* self = new (ELeave) CLbtUnitTestModule( aTestModuleIf );
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   143
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   144
    CleanupStack::PushL( self );
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   145
    self->ConstructL();
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   146
    CleanupStack::Pop();
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   147
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   148
    return self;
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   149
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   150
    }
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   151
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   152
// Destructor
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   153
CLbtUnitTestModule::~CLbtUnitTestModule()
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   154
    { 
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   155
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   156
    // Delete resources allocated from test methods
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   157
    Delete();
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   158
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   159
    // Delete logger
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   160
    delete iLog; 
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   161
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   162
    delete iWait;
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   163
    }
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   164
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   165
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   166
// ========================== OTHER EXPORTED FUNCTIONS =========================
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   167
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   168
// -----------------------------------------------------------------------------
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   169
// LibEntryL is a polymorphic Dll entry point.
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   170
// Returns: CScriptBase: New CScriptBase derived object
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   171
// -----------------------------------------------------------------------------
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   172
//
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   173
EXPORT_C CScriptBase* LibEntryL( 
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   174
    CTestModuleIf& aTestModuleIf ) // Backpointer to STIF Test Framework
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   175
    {
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   176
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   177
    return ( CScriptBase* ) CLbtUnitTestModule::NewL( aTestModuleIf );
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   178
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   179
    }
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   180
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   181
4c28d569e1fe 201037_001
hgs
parents:
diff changeset
   182
//  End of File