devmngt_plat/services_db_api/tsrc/ServicesDbApiTest/inc/ServicesDbApiTest.h
author Pat Downey <patd@symbian.org>
Wed, 01 Sep 2010 12:33:30 +0100
branchRCL_3
changeset 35 5f281e37a2f5
parent 0 254040eb3b7d
permissions -rw-r--r--
Revert incorrect RCL_3 drop: Revision: 201029 Kit: 201035

/*
* Copyright (c) 2002 - 2007 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of "Eclipse Public License v1.0""
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description:  Implementation of class CServicesDbApiTest
*
*/



#ifndef SERVICESDBAPITEST_H
#define SERVICESDBAPITEST_H

//  INCLUDES
#include <StifLogger.h>
#include <TestScripterInternal.h>
#include <StifTestModule.h>
#include <TestclassAssert.h>
#include <services_db.h>
#include <ConeResLoader.h>
#include <data_caging_path_literals.hrh>
#include <StringLoader.h>
#include <barsread.h>
#include <eikenv.h>



// MACROS
#define TEST_CLASS_VERSION_MAJOR 0
#define TEST_CLASS_VERSION_MINOR 0
#define TEST_CLASS_VERSION_BUILD 0

// Logging path
_LIT( KServicesDbApiTestLogPath, "\\logs\\testframework\\ServicesDbApiTest\\" ); 
// Log file
_LIT( KServicesDbApiTestLogFile, "ServicesDbApiTest.txt" ); 
_LIT( KServicesDbApiTestLogFileWithTitle, "ServicesDbApiTest_[%S].txt" );

_LIT(KEmptyString,"");

// FORWARD DECLARATIONS
class CServicesDbApiTest;


//Constants
const TInt KNoOfServices = 3; // This is the number of services listed in resource file. 
const TInt KFirstOption = 0;
const TInt KSecondOption = 1;
const TInt KFirstServiceIndex = 0;
const TInt KSecondServiceIndex = 1;
const TInt KThirdServiceIndex=2;
const TInt KFirstServiceUid =   257;
const TInt KSecondServiceUid = 258;
const TInt KThirdServiceUid  =  259;
const TInt KBufSize = 128;

// CLASS DECLARATION

/**
*  CServicesDbApiTest test class for STIF Test Framework TestScripter.
*  This class is written to test Services DB API. 
*
*  @lib ServicesDbApiTest.lib
*  @since ?Series60_version
*/
NONSHARABLE_CLASS(CServicesDbApiTest) : public CScriptBase
    {
    public:  // Constructors and destructor

        /**
        * Two-phased constructor.
        */
        static CServicesDbApiTest* NewL( CTestModuleIf& aTestModuleIf );

        /**
        * Destructor.
        */
        virtual ~CServicesDbApiTest();

 
    public: // Functions from base classes

        /**
        * From CScriptBase Runs a script line.
        * @since ?Series60_version
        * @param aItem Script line containing method name and parameters
        * @return Symbian OS error code
        */
        virtual TInt RunMethodL( CStifItemParser& aItem );


    private:

        /**
        * C++ default constructor.
        */
        CServicesDbApiTest( CTestModuleIf& aTestModuleIf );

        /**
        * By default Symbian 2nd phase constructor is private.
        */
        void ConstructL();

        /**
        * Frees all resources allocated from test methods.
        * @since ?Series60_version
        */
        void Delete();

        /**
        * Test methods are listed below. 
        */
        
        /**
         * Method used to log version of test class
         */
        void SendTestClassVersion();

        //[TestMethods]
        
        /**
        * Creates CServicesDB object
        * @since ?Series60_version
        * @param aOption Option to create CServicesDB object using NewL or NewLC
        * @return Symbian OS error code.
        */
        TInt CreateSeviceDBL(TInt aOption);  
        
        /**
        * In this method NewLC is called.
        * @since ?Series60_version
        * @param aResReader Resource reader to get information from Resource file
        * @return Symbian OS error code.
        */
        void CallNewlcL(  TResourceReader aResReader );
        
        /**
        * This method is used to test CServicesDB::NewL
        * @since ?Series60_version
        * @param No parameters required
        * @return Symbian OS error code.
        */
        TInt InitializeSeviceDB( );
        
        /**
        * This method is used to test CServicesDB::NewLC
        * @since ?Series60_version
        * @param No parameters required
        * @return Symbian OS error code.
        */
        TInt InitializeonStackSeviceDB( );
        
        /**
        * This method is used to test CServicesDB::Count
        * @since ?Series60_version
        * @param No parameters required
        * @return Symbian OS error code.
        */
        TInt CountSeviceDB();
        
        /**
        * This method is used to test CServicesDB::ServiceUidL
        * @since ?Series60_version
        * @param aItem Script line containing parameters.
        * @return Symbian OS error code.
        */
        TInt ServiceUidLSeviceDB( CStifItemParser& aItem );
        
        /**
        * This method is used to test CServicesDB::ServiceStringLC
        * with Index as parameter.
        * @since ?Series60_version
        * @param aItem Script line containing parameters.
        * @return Symbian OS error code.
        */
        TInt ServiceStringLCSeviceDB( CStifItemParser& aItem );
        
        /**
        * This method is used to test CServicesDB::ServiceStringLC
        * with UID as parameter
        * @since ?Series60_version
        * @param aItem Script line containing parameters.
        * @return Symbian OS error code.
        */
        TInt ServiceStringLCuidSeviceDB( CStifItemParser& aItem );
        
        /**
        * This method is used to test CServicesDB::ServiceNameLC
        * with Index as parameter
        * @since ?Series60_version
        * @param aItem Script line containing parameters.
        * @return Symbian OS error code.
        */
        TInt ServiceNameLCSeviceDB( CStifItemParser& aItem );
        
        /**
        * This method is used to test CServicesDB::ServiceNameLC
        * with UID as parameter
        * @since ?Series60_version
        * @param aItem Script line containing parameters.
        * @return Symbian OS error code.
        */
        TInt ServiceNameLCuidSeviceDB( CStifItemParser& aItem );
        
        /**
        * This is method encapsulates ServiceStringLC. 
        * This method can be TRAPD and used to help in testing ServiceStringLC
        * @since ?Series60_version
        * @param aIndex the index of the service
        * @param aParam parameter for the localized string
        * @return Symbian OS error code.
        */
        TInt CallServiceStringLCSeviceDBL(TInt aIndex,const TDes& aParam );
        
        /**
        * This is method encapsulates ServiceStringLC. 
        * This method can be TRAPD and used to help in testing ServiceStringLC
        * @since ?Series60_version
        * @param aServiceUid the Uid of the service
        * @param aParam parameter for the localized string
        * @return Symbian OS error code.
        */
        TInt CallServiceStringLCuidSeviceDBL( TUid aServiceUid, const TDes& aParam);
        
        /**
        * This is method encapsulates ServiceNameLC. 
        * This method can be TRAPD and used to help in testing ServiceNameLC
        * @since ?Series60_version
        * @param aIndex the index of the service
        * @return Symbian OS error code.
        */
        TInt CallServiceNameLCSeviceDBL(TInt aIndex);
        
        /**
        * This is method encapsulates ServiceNameLC. 
        * This method can be TRAPD and used to help in testing ServiceNameLC
        * @since ?Series60_version
        * @param aServiceUid the Uid of the service
        * @return Symbian OS error code.
        */
        TInt CallServiceNameLCuidSeviceDBL( TUid aServiceUid );
        
        
    private:    // Data
        
        // This is the pointer to object of the class being tested
        // Through this pointer all the Exported methods are tested. 
        CServicesDB *iServicesDB;
    
        
    };

#endif      // SERVICESDBAPITEST_H

// End of File