startupservices/startupanimation/tsrc/tsanimsvg/inc/TSanimsvg.h
author hgs
Thu, 07 Oct 2010 06:25:45 +0300
changeset 77 b01c07dfcf84
permissions -rw-r--r--
201039

/*
* Copyright (c) 2009 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: STIF testclass declaration
*
*/

#ifndef TSANIMSVG_H
#define TSANIMSVG_H

//  INCLUDES
#include <StifLogger.h>
#include <TestScripterInternal.h>
#include <StifTestModule.h>
#include <TestclassAssert.h>


#include <e32def.h>
#include <f32file.h>
#include "sanimobserver.h"

class CSAnimImagePlugin;
class CTestWaiter;
// FORWARD DECLARATIONS
//class ?FORWARD_CLASSNAME;
class CTSanimsvg;



NONSHARABLE_CLASS( TMockSvgAnimationObserver ) : public MSAnimObserver
    {
public:
    TMockSvgAnimationObserver( CTSanimsvg& aTestSuite ) : iTestSuite( aTestSuite ) {}
    virtual void UpdateScreen( const CFbsBitmap& /*aFrame*/, const CFbsBitmap& /*aMask*/ );
    virtual void UpdateScreen( const CFbsBitmap& /*aFrame*/ );
private:
    CTSanimsvg& iTestSuite;
    };



// CONSTANTS
//const ?type ?constant_var = ?constant;

// MACROS
//#define ?macro ?macro_def
#define TEST_CLASS_VERSION_MAJOR 0
#define TEST_CLASS_VERSION_MINOR 0
#define TEST_CLASS_VERSION_BUILD 0

// Logging path
_LIT( KTSanimsvgLogPath, "\\logs\\testframework\\TSanimsvg\\" ); 
// Log file
_LIT( KTSanimsvgLogFile, "TSanimsvg.txt" ); 
_LIT( KTSanimsvgLogFileWithTitle, "TSanimsvg_[%S].txt" );

// FUNCTION PROTOTYPES
//?type ?function_name(?arg_list);


// DATA TYPES
//enum ?declaration
//typedef ?declaration
//extern ?data_type;

// CLASS DECLARATION

/**
*  CTSanimsvg test class for STIF Test Framework TestScripter.
*  ?other_description_lines
*
*  @lib ?library
*  @since ?Series60_version
*/
NONSHARABLE_CLASS(CTSanimsvg) : public CScriptBase
    {
    public:  // Constructors and destructor

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

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

    public: // New functions

        /**
        * ?member_description.
        * @since ?Series60_version
        * @param ?arg1 ?description
        * @return ?description
        */
        //?type ?member_function( ?type ?arg1 );

    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 );

    protected:  // New functions

        /**
        * ?member_description.
        * @since ?Series60_version
        * @param ?arg1 ?description
        * @return ?description
        */
        //?type ?member_function( ?type ?arg1 );

    protected:  // Functions from base classes

        /**
        * From ?base_class ?member_description
        */
        //?type ?member_function();

    private:

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

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

        // Prohibit copy constructor if not deriving from CBase.
        // ?classname( const ?classname& );
        // Prohibit assigment operator if not deriving from CBase.
        // ?classname& operator=( const ?classname& );

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

        /**
        * Test methods are listed below. 
        */

        /**
        * Example test method.
        * @since ?Series60_version
        * @param aItem Script line containing parameters.
        * @return Symbian OS error code.
        */
        virtual TInt ExampleL( CStifItemParser& aItem );
        
        /**
         * Method used to log version of test class
         */
        void SendTestClassVersion();
        
        
        TInt SetupEmptyL();
        TInt SetupObjL();
           void SetupFileL( const TDesC& aFileName );
           TInt SetupStillImageL();
           TInt SetupScaledAnimationL();
           TInt SetupUnscaledAnimationL();
           TInt SetupAnimationWithTextL();
           TInt SetupStillImageBinaryL();
           TInt SetupScaledAnimationBinaryL();
           TInt SetupFinishedL();
           TInt Teardown();

           TInt TestConstructorL();
           TInt TestConstructorNoMemoryL();
           TInt TestUnknownFileL();
           TInt TestCorruptFileL();
           TInt TestLoadStillImageL();
           TInt TestLoadScaledAnimationL();
           TInt TestLoadUnscaledAnimationL();
           TInt TestLoadAnimationWithTextL();
           TInt TestLoadStillImageBinaryL();
           TInt TestLoadScaledAnimationBinaryL();
           TInt TestLoadNoMemoryL();
           TInt TestCancelLoadL();
           TInt TestShowStillImageL();
           TInt TestShowAnimationL();
           TInt TestShowNoMemoryL();
           TInt TestCancelStillImageL();
           TInt TestCancelAnimationL();
           TInt TestCancelNotActiveL();
           TInt TestShowBeforeLoadL();
           TInt TestSetDisplayModeL();
           TInt TestSetSizeL();
           TInt TestSetFrameDelayL();
           TInt TestBackroundColourL();

    private: // data

    
        friend class TMockSvgAnimationObserver;

        /** File server session used in testing. */
        RFs iFs;

        /** Instance of the class that this test suite is testing. */
        CSAnimImagePlugin* iTestObj;

        /** A 32 bit identifer returned by ECom to identify this instance to the framework. */
        TUid iDtorKey;

        /** For testing async calls. */
        CTestWaiter* iWaiter;

        /** For testing correct number of calls to animation observer. */
        TInt iFrameCounter;

        /** Animation observer for testing. */
        TMockSvgAnimationObserver iObserver;

    };

#endif      // TSANIMSVG_H

// End of File