usbengines/usbotgwatcher/tsrc/UsbOtgWatcherTest/inc/UsbOtgWatcherTest.h
author hgs
Tue, 13 Jul 2010 00:24:10 +0300
changeset 62 eadeea68c837
permissions -rw-r--r--
201027
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
62
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2010 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 "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:
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
#ifndef USBOTGWATCHERTEST_H
hgs
parents:
diff changeset
    20
#define USBOTGWATCHERTEST_H
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
//  INCLUDES
hgs
parents:
diff changeset
    23
#include <StifLogger.h>
hgs
parents:
diff changeset
    24
#include <TestScripterInternal.h>
hgs
parents:
diff changeset
    25
#include <StifTestModule.h>
hgs
parents:
diff changeset
    26
#include <TestclassAssert.h>
hgs
parents:
diff changeset
    27
#include "stifassertmacros.h"
hgs
parents:
diff changeset
    28
//  INCLUDES FOR STUBS
hgs
parents:
diff changeset
    29
#include <stubber.h>
hgs
parents:
diff changeset
    30
#include <apibehavior.h>
hgs
parents:
diff changeset
    31
#include <usbmandll_stub.h>
hgs
parents:
diff changeset
    32
//  INCLUDES FOR TEST
hgs
parents:
diff changeset
    33
#include <usbstates.h>
hgs
parents:
diff changeset
    34
#include <usbuinotif.h>
hgs
parents:
diff changeset
    35
#include "cusbotgwatcher.h"
hgs
parents:
diff changeset
    36
#include "cusbnotifier.h"
hgs
parents:
diff changeset
    37
#include "cusbstatehostainitiate.h"
hgs
parents:
diff changeset
    38
#include "cusbstatehosthandle.h"
hgs
parents:
diff changeset
    39
#include "cusbservicecontrol.h"
hgs
parents:
diff changeset
    40
hgs
parents:
diff changeset
    41
hgs
parents:
diff changeset
    42
// CONSTANTS
hgs
parents:
diff changeset
    43
// Logging path
hgs
parents:
diff changeset
    44
_LIT( KUsbOtgWatcherTestLogPath, "\\logs\\testframework\\UsbOtgWatcherTest\\" );
hgs
parents:
diff changeset
    45
hgs
parents:
diff changeset
    46
// Logging path for ATS - for phone builds comment this line
hgs
parents:
diff changeset
    47
//_LIT( KUsbOtgWatcherTestLogPath, "e:\\testing\\stiflogs\\" ); 
hgs
parents:
diff changeset
    48
hgs
parents:
diff changeset
    49
// Log file
hgs
parents:
diff changeset
    50
_LIT( KUsbOtgWatcherTestLogFile, "UsbOtgWatcherTest.txt" ); 
hgs
parents:
diff changeset
    51
_LIT( KUsbOtgWatcherTestLogFileWithTitle, "UsbOtgWatcherTest_[%S].txt" );
hgs
parents:
diff changeset
    52
hgs
parents:
diff changeset
    53
// MACROS
hgs
parents:
diff changeset
    54
#define TEST_CLASS_VERSION_MAJOR 0
hgs
parents:
diff changeset
    55
#define TEST_CLASS_VERSION_MINOR 0
hgs
parents:
diff changeset
    56
#define TEST_CLASS_VERSION_BUILD 0
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
// Macros used to extract test block parameters
hgs
parents:
diff changeset
    59
#define TESTENTRY( A, B )\
hgs
parents:
diff changeset
    60
    if ( !iTestBlockParams.iTestBlockName.Compare( TPtrC( ( TText* ) L ##A ) ) )\
hgs
parents:
diff changeset
    61
        { iTestBlockFunction = &B; iTestBlockFound = ETrue; }\
hgs
parents:
diff changeset
    62
    if ( !iTestBlockParams.iTestBlockName.Compare( TPtrC( ( TText* ) L ##A ) ) )
hgs
parents:
diff changeset
    63
hgs
parents:
diff changeset
    64
#define TESTPARAM( A, B )\
hgs
parents:
diff changeset
    65
    GetTestBlockParamL( ( TGetTestBlockParamOperation ) A, ( TTestBlockParamName ) B );
hgs
parents:
diff changeset
    66
hgs
parents:
diff changeset
    67
// FUNCTION PROTOTYPES
hgs
parents:
diff changeset
    68
hgs
parents:
diff changeset
    69
// FORWARD DECLARATIONS
hgs
parents:
diff changeset
    70
class CUsbOtgWatcher;
hgs
parents:
diff changeset
    71
class RUsb;
hgs
parents:
diff changeset
    72
hgs
parents:
diff changeset
    73
// DATA TYPES
hgs
parents:
diff changeset
    74
hgs
parents:
diff changeset
    75
// Enum type used to determine test block execution result
hgs
parents:
diff changeset
    76
enum TUsbOtgWatcherTestResult
hgs
parents:
diff changeset
    77
    {
hgs
parents:
diff changeset
    78
    ETestCasePassed,
hgs
parents:
diff changeset
    79
    ETestCaseFailed
hgs
parents:
diff changeset
    80
    };
hgs
parents:
diff changeset
    81
hgs
parents:
diff changeset
    82
// Enum type indicating test block parameter which should be used to store
hgs
parents:
diff changeset
    83
// data extracted from test script
hgs
parents:
diff changeset
    84
enum TTestBlockParamName
hgs
parents:
diff changeset
    85
    {
hgs
parents:
diff changeset
    86
    eTestOption1,
hgs
parents:
diff changeset
    87
    eTestOption2,
hgs
parents:
diff changeset
    88
    eTestOption3,    
hgs
parents:
diff changeset
    89
    eTestIntOption1,
hgs
parents:
diff changeset
    90
    eTestIntOption2,
hgs
parents:
diff changeset
    91
    eTestIntOption3,   
hgs
parents:
diff changeset
    92
    eTestCharOption1,
hgs
parents:
diff changeset
    93
    eTestCharOption2,
hgs
parents:
diff changeset
    94
    eTestCharOption3
hgs
parents:
diff changeset
    95
    };
hgs
parents:
diff changeset
    96
hgs
parents:
diff changeset
    97
// Enum type used to indicate which get parameter function should be used
hgs
parents:
diff changeset
    98
enum TGetTestBlockParamOperation
hgs
parents:
diff changeset
    99
    {
hgs
parents:
diff changeset
   100
    eGetString,
hgs
parents:
diff changeset
   101
    eGetInt,
hgs
parents:
diff changeset
   102
    eGetChar
hgs
parents:
diff changeset
   103
    };
hgs
parents:
diff changeset
   104
hgs
parents:
diff changeset
   105
// CLASS DECLARATION
hgs
parents:
diff changeset
   106
/**
hgs
parents:
diff changeset
   107
*  TUsbOtgWatcherTestBlockParams test class for storing test block parameters.
hgs
parents:
diff changeset
   108
*/
hgs
parents:
diff changeset
   109
NONSHARABLE_CLASS( TUsbOtgWatcherTestBlockParams )
hgs
parents:
diff changeset
   110
    {
hgs
parents:
diff changeset
   111
    public:
hgs
parents:
diff changeset
   112
        TPtrC iTestBlockName;
hgs
parents:
diff changeset
   113
        
hgs
parents:
diff changeset
   114
        TPtrC iTestOption1;
hgs
parents:
diff changeset
   115
        TPtrC iTestOption2;
hgs
parents:
diff changeset
   116
        TPtrC iTestOption3;
hgs
parents:
diff changeset
   117
        
hgs
parents:
diff changeset
   118
        TInt iTestIntOption1;
hgs
parents:
diff changeset
   119
        TInt iTestIntOption2;
hgs
parents:
diff changeset
   120
        TInt iTestIntOption3;
hgs
parents:
diff changeset
   121
        
hgs
parents:
diff changeset
   122
        TChar iTestCharOption1;
hgs
parents:
diff changeset
   123
        TChar iTestCharOption2;
hgs
parents:
diff changeset
   124
        TChar iTestCharOption3;
hgs
parents:
diff changeset
   125
    };
hgs
parents:
diff changeset
   126
hgs
parents:
diff changeset
   127
/**
hgs
parents:
diff changeset
   128
*  CUsbOtgWatcherTest test class for STIF Test Framework TestScripter.
hgs
parents:
diff changeset
   129
*/
hgs
parents:
diff changeset
   130
NONSHARABLE_CLASS( CtUsbOtgWatcher ) : public CScriptBase
hgs
parents:
diff changeset
   131
    {
hgs
parents:
diff changeset
   132
    public:  // Constructors and destructor
hgs
parents:
diff changeset
   133
hgs
parents:
diff changeset
   134
        /**
hgs
parents:
diff changeset
   135
        * Two-phased constructor.
hgs
parents:
diff changeset
   136
        */
hgs
parents:
diff changeset
   137
        static CtUsbOtgWatcher* NewL( CTestModuleIf& aTestModuleIf );
hgs
parents:
diff changeset
   138
hgs
parents:
diff changeset
   139
        /**
hgs
parents:
diff changeset
   140
        * Destructor.
hgs
parents:
diff changeset
   141
        */
hgs
parents:
diff changeset
   142
        virtual ~CtUsbOtgWatcher();
hgs
parents:
diff changeset
   143
hgs
parents:
diff changeset
   144
    public: // New functions
hgs
parents:
diff changeset
   145
    public: // Functions from base classes
hgs
parents:
diff changeset
   146
hgs
parents:
diff changeset
   147
        /**
hgs
parents:
diff changeset
   148
        * From CScriptBase Runs a script line.
hgs
parents:
diff changeset
   149
        * @since ?Series60_version
hgs
parents:
diff changeset
   150
        * @param aItem Script line containing method name and parameters
hgs
parents:
diff changeset
   151
        * @return Symbian OS error code
hgs
parents:
diff changeset
   152
        */
hgs
parents:
diff changeset
   153
        virtual TInt RunMethodL( CStifItemParser& aItem );
hgs
parents:
diff changeset
   154
hgs
parents:
diff changeset
   155
    protected:  // New functions
hgs
parents:
diff changeset
   156
    protected:  // Functions from base classes
hgs
parents:
diff changeset
   157
    private:
hgs
parents:
diff changeset
   158
hgs
parents:
diff changeset
   159
        /**
hgs
parents:
diff changeset
   160
        * C++ default constructor.
hgs
parents:
diff changeset
   161
        */
hgs
parents:
diff changeset
   162
        CtUsbOtgWatcher( CTestModuleIf& aTestModuleIf );
hgs
parents:
diff changeset
   163
hgs
parents:
diff changeset
   164
        /**
hgs
parents:
diff changeset
   165
        * By default Symbian 2nd phase constructor is private.
hgs
parents:
diff changeset
   166
        */
hgs
parents:
diff changeset
   167
        void ConstructL();
hgs
parents:
diff changeset
   168
hgs
parents:
diff changeset
   169
        /**
hgs
parents:
diff changeset
   170
        * Frees all resources allocated from test methods.
hgs
parents:
diff changeset
   171
        * @since ?Series60_version
hgs
parents:
diff changeset
   172
        */
hgs
parents:
diff changeset
   173
        void TestDelete();
hgs
parents:
diff changeset
   174
        
hgs
parents:
diff changeset
   175
        /**
hgs
parents:
diff changeset
   176
        * Constructs all test resources for test methods.
hgs
parents:
diff changeset
   177
        */
hgs
parents:
diff changeset
   178
        void TestConstructL();
hgs
parents:
diff changeset
   179
        
hgs
parents:
diff changeset
   180
        /**
hgs
parents:
diff changeset
   181
        * Extracts test block parameters from script file
hgs
parents:
diff changeset
   182
        */
hgs
parents:
diff changeset
   183
        void TestBlocksInfoL();
hgs
parents:
diff changeset
   184
        
hgs
parents:
diff changeset
   185
        /**
hgs
parents:
diff changeset
   186
        * Executes test block
hgs
parents:
diff changeset
   187
        */
hgs
parents:
diff changeset
   188
        TInt ExecuteTestBlock( CStifItemParser& aItem );
hgs
parents:
diff changeset
   189
        
hgs
parents:
diff changeset
   190
        /**
hgs
parents:
diff changeset
   191
        * Executes proper get parameter function indicated by its arguments
hgs
parents:
diff changeset
   192
        */
hgs
parents:
diff changeset
   193
        void GetTestBlockParamL( TGetTestBlockParamOperation aOperation,
hgs
parents:
diff changeset
   194
                                TTestBlockParamName aParamName );
hgs
parents:
diff changeset
   195
        
hgs
parents:
diff changeset
   196
        /**
hgs
parents:
diff changeset
   197
         * Method used to log version of test class
hgs
parents:
diff changeset
   198
         */
hgs
parents:
diff changeset
   199
        void SendTestClassVersion();
hgs
parents:
diff changeset
   200
hgs
parents:
diff changeset
   201
        // ADD NEW METHOD DEC HERE
hgs
parents:
diff changeset
   202
        // [TestMethods] - Do not remove 
hgs
parents:
diff changeset
   203
        void ExampleTestL( TUsbOtgWatcherTestBlockParams& aParams, 
hgs
parents:
diff changeset
   204
                            TUsbOtgWatcherTestResult& aTestResult );
hgs
parents:
diff changeset
   205
        
hgs
parents:
diff changeset
   206
        void SetupTearDownL( TUsbOtgWatcherTestBlockParams& aParams,
hgs
parents:
diff changeset
   207
                            TUsbOtgWatcherTestResult& aTestResult );
hgs
parents:
diff changeset
   208
        
hgs
parents:
diff changeset
   209
        void PinOnTest_SuccessL( TUsbOtgWatcherTestBlockParams& aParams,
hgs
parents:
diff changeset
   210
                            TUsbOtgWatcherTestResult& aTestResult );
hgs
parents:
diff changeset
   211
        
hgs
parents:
diff changeset
   212
        void PinOffTest_SuccessL( TUsbOtgWatcherTestBlockParams& aParams,
hgs
parents:
diff changeset
   213
                            TUsbOtgWatcherTestResult& aTestResult );
hgs
parents:
diff changeset
   214
        
hgs
parents:
diff changeset
   215
        void PinOnTest_EmptyCableL( TUsbOtgWatcherTestBlockParams& aParams,
hgs
parents:
diff changeset
   216
                            TUsbOtgWatcherTestResult& aTestResult );
hgs
parents:
diff changeset
   217
        
hgs
parents:
diff changeset
   218
        void PinOnTest_TryStartErrorL( TUsbOtgWatcherTestBlockParams& aParams,
hgs
parents:
diff changeset
   219
                            TUsbOtgWatcherTestResult& aTestResult );
hgs
parents:
diff changeset
   220
        
hgs
parents:
diff changeset
   221
        void PinOnTest_BusRequestErrorL( TUsbOtgWatcherTestBlockParams& aParams,
hgs
parents:
diff changeset
   222
                            TUsbOtgWatcherTestResult& aTestResult );
hgs
parents:
diff changeset
   223
        
hgs
parents:
diff changeset
   224
        void DeviceAttached_BadHubPostionL( TUsbOtgWatcherTestBlockParams& aParams,
hgs
parents:
diff changeset
   225
                            TUsbOtgWatcherTestResult& aTestResult );
hgs
parents:
diff changeset
   226
        
hgs
parents:
diff changeset
   227
        void DeviceAttached_TooMuchRequiredL( TUsbOtgWatcherTestBlockParams& aParams,
hgs
parents:
diff changeset
   228
                            TUsbOtgWatcherTestResult& aTestResult );
hgs
parents:
diff changeset
   229
        
hgs
parents:
diff changeset
   230
        void DeviceAttached_SupportedDeviceL( TUsbOtgWatcherTestBlockParams& aParams,
hgs
parents:
diff changeset
   231
                            TUsbOtgWatcherTestResult& aTestResult );
hgs
parents:
diff changeset
   232
        
hgs
parents:
diff changeset
   233
        void DeviceDetached_SupportedDeviceL( TUsbOtgWatcherTestBlockParams& aParams,
hgs
parents:
diff changeset
   234
                            TUsbOtgWatcherTestResult& aTestResult );
hgs
parents:
diff changeset
   235
   
hgs
parents:
diff changeset
   236
        void IndicatorNotifier_IndicatorActivateL( TUsbOtgWatcherTestBlockParams& aParams,
hgs
parents:
diff changeset
   237
                            TUsbOtgWatcherTestResult& aTestResult );
hgs
parents:
diff changeset
   238
        
hgs
parents:
diff changeset
   239
        //others method
hgs
parents:
diff changeset
   240
        void SetupL();
hgs
parents:
diff changeset
   241
        void TearDown();
hgs
parents:
diff changeset
   242
        
hgs
parents:
diff changeset
   243
    public:     // Data
hgs
parents:
diff changeset
   244
    protected:  // Data
hgs
parents:
diff changeset
   245
    private:    // Data
hgs
parents:
diff changeset
   246
        
hgs
parents:
diff changeset
   247
        // Member object used to store test block parameters
hgs
parents:
diff changeset
   248
        TUsbOtgWatcherTestBlockParams iTestBlockParams;
hgs
parents:
diff changeset
   249
        TTestResult iResult;
hgs
parents:
diff changeset
   250
        
hgs
parents:
diff changeset
   251
        // Used to indicate if test block with specified parameters exist
hgs
parents:
diff changeset
   252
        TBool iTestBlockFound;
hgs
parents:
diff changeset
   253
        
hgs
parents:
diff changeset
   254
        // Function pointer used to call proper test block methods
hgs
parents:
diff changeset
   255
        void ( CtUsbOtgWatcher::*iTestBlockFunction )
hgs
parents:
diff changeset
   256
            ( TUsbOtgWatcherTestBlockParams&, TUsbOtgWatcherTestResult& );
hgs
parents:
diff changeset
   257
        
hgs
parents:
diff changeset
   258
        // Not own
hgs
parents:
diff changeset
   259
        CStifItemParser* iItem;
hgs
parents:
diff changeset
   260
        CStubber * iStubber;
hgs
parents:
diff changeset
   261
        RUsb* iUsbMan;
hgs
parents:
diff changeset
   262
        CUsbOtgWatcher* iWatcher;
hgs
parents:
diff changeset
   263
hgs
parents:
diff changeset
   264
        // Reserved pointer for future extension
hgs
parents:
diff changeset
   265
        //TAny* iReserved;
hgs
parents:
diff changeset
   266
hgs
parents:
diff changeset
   267
        // ADD NEW DATA DEC HERE
hgs
parents:
diff changeset
   268
hgs
parents:
diff changeset
   269
        
hgs
parents:
diff changeset
   270
    public:     // Friend classes
hgs
parents:
diff changeset
   271
    protected:  // Friend classes
hgs
parents:
diff changeset
   272
    private:    // Friend classes
hgs
parents:
diff changeset
   273
        
hgs
parents:
diff changeset
   274
    };
hgs
parents:
diff changeset
   275
#endif      // USBOTGWATCHERTEST_H
hgs
parents:
diff changeset
   276
hgs
parents:
diff changeset
   277
// End of File