phoneclientserver/aiwdialdata/tsrc/public/adv/aiwdialtest/src/aiwdialtestcases.cpp
author hgs
Wed, 21 Jul 2010 18:26:52 +0300
changeset 33 8d5d7fcf9b59
permissions -rw-r--r--
201027
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 "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:  Implementation of Caiwdialtest class.
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
// INCLUDE FILES
hgs
parents:
diff changeset
    21
#include <e32math.h>
hgs
parents:
diff changeset
    22
#include <aiwdialdata.h>
hgs
parents:
diff changeset
    23
#include <AiwCommon.h>
hgs
parents:
diff changeset
    24
#include <AiwServiceHandler.h>
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
#include "aiwdialtest.h"
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
// ============================ MEMBER FUNCTIONS ===============================
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    33
// Caiwdialtest::Case
hgs
parents:
diff changeset
    34
// Returns a test case by number.
hgs
parents:
diff changeset
    35
//
hgs
parents:
diff changeset
    36
// This function contains an array of all available test cases 
hgs
parents:
diff changeset
    37
// i.e pair of case name and test function. If case specified by parameter
hgs
parents:
diff changeset
    38
// aCaseNumber is found from array, then that item is returned.
hgs
parents:
diff changeset
    39
// 
hgs
parents:
diff changeset
    40
// The reason for this rather complicated function is to specify all the
hgs
parents:
diff changeset
    41
// test cases only in one place. It is not necessary to understand how
hgs
parents:
diff changeset
    42
// function pointers to class member functions works when adding new test
hgs
parents:
diff changeset
    43
// cases. See function body for instructions how to add new test case.
hgs
parents:
diff changeset
    44
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    45
//
hgs
parents:
diff changeset
    46
const TCaseInfo Caiwdialtest::Case ( 
hgs
parents:
diff changeset
    47
    const TInt aCaseNumber ) const 
hgs
parents:
diff changeset
    48
     {
hgs
parents:
diff changeset
    49
hgs
parents:
diff changeset
    50
    /**
hgs
parents:
diff changeset
    51
    * To add new test cases, implement new test case function and add new 
hgs
parents:
diff changeset
    52
    * line to KCases array specify the name of the case and the function 
hgs
parents:
diff changeset
    53
    * doing the test case
hgs
parents:
diff changeset
    54
    * In practice, do following
hgs
parents:
diff changeset
    55
    * 1) Make copy of existing test case function and change its name
hgs
parents:
diff changeset
    56
    *    and functionality. Note that the function must be added to 
hgs
parents:
diff changeset
    57
    *    aiwdialtest.cpp file and to aiwdialtest.h 
hgs
parents:
diff changeset
    58
    *    header file.
hgs
parents:
diff changeset
    59
    *
hgs
parents:
diff changeset
    60
    * 2) Add entry to following KCases array either by using:
hgs
parents:
diff changeset
    61
    *
hgs
parents:
diff changeset
    62
    * 2.1: FUNCENTRY or ENTRY macro
hgs
parents:
diff changeset
    63
    * ENTRY macro takes two parameters: test case name and test case 
hgs
parents:
diff changeset
    64
    * function name.
hgs
parents:
diff changeset
    65
    *
hgs
parents:
diff changeset
    66
    * FUNCENTRY macro takes only test case function name as a parameter and
hgs
parents:
diff changeset
    67
    * uses that as a test case name and test case function name.
hgs
parents:
diff changeset
    68
    *
hgs
parents:
diff changeset
    69
    * Or
hgs
parents:
diff changeset
    70
    *
hgs
parents:
diff changeset
    71
    * 2.2: OOM_FUNCENTRY or OOM_ENTRY macro. Note that these macros are used
hgs
parents:
diff changeset
    72
    * only with OOM (Out-Of-Memory) testing!
hgs
parents:
diff changeset
    73
    *
hgs
parents:
diff changeset
    74
    * OOM_ENTRY macro takes five parameters: test case name, test case 
hgs
parents:
diff changeset
    75
    * function name, TBool which specifies is method supposed to be run using
hgs
parents:
diff changeset
    76
    * OOM conditions, TInt value for first heap memory allocation failure and 
hgs
parents:
diff changeset
    77
    * TInt value for last heap memory allocation failure.
hgs
parents:
diff changeset
    78
    * 
hgs
parents:
diff changeset
    79
    * OOM_FUNCENTRY macro takes test case function name as a parameter and uses
hgs
parents:
diff changeset
    80
    * that as a test case name, TBool which specifies is method supposed to be
hgs
parents:
diff changeset
    81
    * run using OOM conditions, TInt value for first heap memory allocation 
hgs
parents:
diff changeset
    82
    * failure and TInt value for last heap memory allocation failure. 
hgs
parents:
diff changeset
    83
    */ 
hgs
parents:
diff changeset
    84
hgs
parents:
diff changeset
    85
    static TCaseInfoInternal const KCases[] =
hgs
parents:
diff changeset
    86
        {
hgs
parents:
diff changeset
    87
        // To add new test cases, add new items to this array
hgs
parents:
diff changeset
    88
        
hgs
parents:
diff changeset
    89
        // NOTE: When compiled to GCCE, there must be Classname::
hgs
parents:
diff changeset
    90
        // declaration in front of the method name, e.g. 
hgs
parents:
diff changeset
    91
        // Caiwdialtest::PrintTest. Otherwise the compiler
hgs
parents:
diff changeset
    92
        // gives errors.
hgs
parents:
diff changeset
    93
        
hgs
parents:
diff changeset
    94
        FUNCENTRY( Caiwdialtest::DialTestL ),
hgs
parents:
diff changeset
    95
        // Example how to use OOM functionality
hgs
parents:
diff changeset
    96
        //OOM_ENTRY( "Loop test with OOM", Caiwdialtest::LoopTest, ETrue, 2, 3),
hgs
parents:
diff changeset
    97
        //OOM_FUNCENTRY( Caiwdialtest::PrintTest, ETrue, 1, 3 ),
hgs
parents:
diff changeset
    98
        };
hgs
parents:
diff changeset
    99
hgs
parents:
diff changeset
   100
    // Verify that case number is valid
hgs
parents:
diff changeset
   101
    if( (TUint) aCaseNumber >= sizeof( KCases ) / 
hgs
parents:
diff changeset
   102
                               sizeof( TCaseInfoInternal ) )
hgs
parents:
diff changeset
   103
        {
hgs
parents:
diff changeset
   104
        // Invalid case, construct empty object
hgs
parents:
diff changeset
   105
        TCaseInfo null( (const TText*) L"" );
hgs
parents:
diff changeset
   106
        null.iMethod = NULL;
hgs
parents:
diff changeset
   107
        null.iIsOOMTest = EFalse;
hgs
parents:
diff changeset
   108
        null.iFirstMemoryAllocation = 0;
hgs
parents:
diff changeset
   109
        null.iLastMemoryAllocation = 0;
hgs
parents:
diff changeset
   110
        return null;
hgs
parents:
diff changeset
   111
        } 
hgs
parents:
diff changeset
   112
hgs
parents:
diff changeset
   113
    // Construct TCaseInfo object and return it
hgs
parents:
diff changeset
   114
    TCaseInfo tmp ( KCases[ aCaseNumber ].iCaseName );
hgs
parents:
diff changeset
   115
    tmp.iMethod = KCases[ aCaseNumber ].iMethod;
hgs
parents:
diff changeset
   116
    tmp.iIsOOMTest = KCases[ aCaseNumber ].iIsOOMTest;
hgs
parents:
diff changeset
   117
    tmp.iFirstMemoryAllocation = KCases[ aCaseNumber ].iFirstMemoryAllocation;
hgs
parents:
diff changeset
   118
    tmp.iLastMemoryAllocation = KCases[ aCaseNumber ].iLastMemoryAllocation;
hgs
parents:
diff changeset
   119
    return tmp;
hgs
parents:
diff changeset
   120
hgs
parents:
diff changeset
   121
    }
hgs
parents:
diff changeset
   122
hgs
parents:
diff changeset
   123
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   124
//  Test dialing a call.
hgs
parents:
diff changeset
   125
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   126
//
hgs
parents:
diff changeset
   127
TInt Caiwdialtest::DialTestL( TTestResult& /*aResult*/ ) 
hgs
parents:
diff changeset
   128
    {
hgs
parents:
diff changeset
   129
    CAiwDialData* dialData = CAiwDialData::NewLC();
hgs
parents:
diff changeset
   130
    dialData->SetPhoneNumberL( *iPhoneNumber );
hgs
parents:
diff changeset
   131
    
hgs
parents:
diff changeset
   132
    CAiwGenericParamList* list = CAiwGenericParamList::NewLC();
hgs
parents:
diff changeset
   133
    dialData->FillInParamListL( *list );
hgs
parents:
diff changeset
   134
    
hgs
parents:
diff changeset
   135
    CActiveScheduler* scheduler = new( ELeave )CActiveScheduler();
hgs
parents:
diff changeset
   136
    CleanupStack::PushL( scheduler );
hgs
parents:
diff changeset
   137
    CActiveScheduler::Install( scheduler );
hgs
parents:
diff changeset
   138
   
hgs
parents:
diff changeset
   139
    
hgs
parents:
diff changeset
   140
    RCriteriaArray criterias;
hgs
parents:
diff changeset
   141
    _LIT8( KContentType, "*" );
hgs
parents:
diff changeset
   142
    CAiwCriteriaItem* criteria = CAiwCriteriaItem::NewLC( KAiwCmdCall, KAiwCmdCall, KContentType );
hgs
parents:
diff changeset
   143
    TUid uid;
hgs
parents:
diff changeset
   144
	uid.iUid = KAiwClassBase;
hgs
parents:
diff changeset
   145
	criteria->SetServiceClass( uid );
hgs
parents:
diff changeset
   146
    criterias.AppendL( criteria );
hgs
parents:
diff changeset
   147
    CleanupClose<RCriteriaArray>::PushL( criterias );
hgs
parents:
diff changeset
   148
    
hgs
parents:
diff changeset
   149
    CAiwServiceHandler* service = CAiwServiceHandler::NewLC();
hgs
parents:
diff changeset
   150
    service->AttachL( criterias );
hgs
parents:
diff changeset
   151
    service->ExecuteServiceCmdL( KAiwCmdCall, *list, service->OutParamListL() );
hgs
parents:
diff changeset
   152
    
hgs
parents:
diff changeset
   153
    CleanupStack::PopAndDestroy( 6, dialData );
hgs
parents:
diff changeset
   154
    return KErrNone;
hgs
parents:
diff changeset
   155
    }
hgs
parents:
diff changeset
   156
hgs
parents:
diff changeset
   157
//  End of File