sl@0: // Copyright (c) 1997-2009 Nokia Corporation and/or its subsidiary(-ies). sl@0: // All rights reserved. sl@0: // This component and the accompanying materials are made available sl@0: // under the terms of "Eclipse Public License v1.0" sl@0: // which accompanies this distribution, and is available sl@0: // at the URL "http://www.eclipse.org/legal/epl-v10.html". sl@0: // sl@0: // Initial Contributors: sl@0: // Nokia Corporation - initial contribution. sl@0: // sl@0: // Contributors: sl@0: // sl@0: // Description: sl@0: // The unit test class definitions for the CComponentTester class. sl@0: // sl@0: // sl@0: sl@0: #ifndef __COMPONENTTESTERUNITTEST_H__ sl@0: #define __COMPONENTTESTERUNITTEST_H__ sl@0: sl@0: #include sl@0: #include "ComponentTesterStateAccessor.h" sl@0: #include "ComponentTesterTransitionValidation.h" sl@0: #include "ComponentTesterTransitions.h" sl@0: sl@0: // ______________________________________________________________________________ sl@0: // sl@0: /** sl@0: @internalComponent sl@0: sl@0: Comments : Unit Test for CreateAndDestroy on CComponentTester, the class under test. sl@0: */ sl@0: class CComponentTester_CreateAndDestroy_UnitTest : public CUnitTest sl@0: { sl@0: public: sl@0: /** sl@0: @fn NewL(CDataLogger& aDataLogger, sl@0: MUnitTestObserver& aObserver) sl@0: Intended Usage : Standard two-phase construction which leaves nothing on the sl@0: cleanup stack. sl@0: Error Condition : Leaves with the error code. sl@0: @leave KErrNoMemory sl@0: @since 7.0 sl@0: @param aDataLogger The output logging object. sl@0: @param aObserver The observer of this UnitTest. sl@0: @return CComponentTester_CreateAndDestroy_UnitTest* The constructed object. sl@0: @pre None. sl@0: @post CComponentTester_CreateAndDestroy_UnitTest is fully constructed, and initialised. sl@0: */ sl@0: static CComponentTester_CreateAndDestroy_UnitTest* NewL(CDataLogger& aDataLogger, sl@0: MUnitTestObserver& aObserver); sl@0: sl@0: /** sl@0: @fn RunError(TInt aError) sl@0: Intended Usage : Intercept the panic caused by a RunL leave, sl@0: to restore the CComponentTester_CreateAndDestroy_UnitTest sl@0: object to a sensible state. sl@0: (called by the Active Scheduler immediately before the Panic). sl@0: Error Condition : @see CUnitTest::RunError(). sl@0: @since 7.0 sl@0: @return TInt KErrNone if cleanup successful, otherwise sl@0: @see CUnitTest::RunError() sl@0: @pre CComponentTester_CreateAndDestroy_UnitTest is fully constructed, and initialised. sl@0: @post The object has been restored to a sensible state. sl@0: */ sl@0: inline TInt RunError(TInt aError); sl@0: sl@0: /** sl@0: @fn ~CComponentTester_CreateAndDestroy_UnitTest() sl@0: Intended Usage : Standard Destructor. sl@0: Error Condition : None. sl@0: @since 7.0 sl@0: @pre CComponentTester_CreateAndDestroy_UnitTest is fully constructed. sl@0: @post CComponentTester_CreateAndDestroy_UnitTest is fully destroyed. sl@0: */ sl@0: ~CComponentTester_CreateAndDestroy_UnitTest(); sl@0: sl@0: private: sl@0: /** sl@0: @fn CComponentTester_CreateAndDestroy_UnitTest(CDataLogger& aDataLogger, sl@0: MUnitTestObserver& aObserver) sl@0: Intended Usage : Default constructor. sl@0: Error Condition : None. sl@0: @since 7.0 sl@0: @param aDataLogger The output logging object. sl@0: @param aObserver The observer of this UnitTest. sl@0: @param aStateAccessor WhiteBox state access to the CComponentTester class. sl@0: @pre None. sl@0: @post CComponentTester_CreateAndDestroy_UnitTest is fully constructed. sl@0: */ sl@0: inline CComponentTester_CreateAndDestroy_UnitTest(CDataLogger& aDataLogger, sl@0: MUnitTestObserver& aObserver); sl@0: sl@0: /** sl@0: @fn void ConstructL() sl@0: Intended Usage : Second phase of safe two phase construction, sl@0: to complete the object initialisation. sl@0: Error Condition : Leaves with an error code. sl@0: @leave KErrNoMemory, and @see CUnitTest::BaseNewL(). sl@0: @since 7.0 sl@0: @return None sl@0: @pre CComponentTester_CreateAndDestroy_UnitTest is fully constructed. sl@0: @post CComponentTester_CreateAndDestroy_UnitTest is fully initialised. sl@0: */ sl@0: void ConstructL(); sl@0: sl@0: /** sl@0: The context of the Unit Test. sl@0: i.e The CComponentTester class tested by this UnitTest's transitions. sl@0: */ sl@0: CComponentTester_UnitTestContext* iUTContext; sl@0: TComponentTester_StateAccessor* iStateAccessor; sl@0: // C'tor, d'tor, and method transition validators sl@0: TComponentTester_Ctor_TransitionValidator* iCtorValidator; sl@0: TComponentTester_Dtor_TransitionValidator* iDtorValidator; sl@0: }; // CComponentTester_CreateAndDestroy_UnitTest sl@0: sl@0: // ______________________________________________________________________________ sl@0: // sl@0: /** sl@0: @internalComponent sl@0: sl@0: Comments : Unit Test for ManageUnitTests on CComponentTester, the class under test. sl@0: */ sl@0: class CComponentTester_ManageUnitTests_UnitTest : public CUnitTest sl@0: { sl@0: public: sl@0: /** sl@0: @fn NewL(CDataLogger& aDataLogger, sl@0: MUnitTestObserver& aObserver) sl@0: Intended Usage : Standard two-phase construction which leaves nothing on the sl@0: cleanup stack. sl@0: Error Condition : Leaves with the error code. sl@0: @leave KErrNoMemory sl@0: @since 7.0 sl@0: @param aDataLogger The output logging object. sl@0: @param aObserver The observer of this UnitTest. sl@0: @return CComponentTester_ManageUnitTests_UnitTest* The constructed object. sl@0: @pre None. sl@0: @post CComponentTester_ManageUnitTests_UnitTest is fully constructed, and initialised. sl@0: */ sl@0: static CComponentTester_ManageUnitTests_UnitTest* NewL(CDataLogger& aDataLogger, sl@0: MUnitTestObserver& aObserver); sl@0: sl@0: /** sl@0: @fn RunError(TInt aError) sl@0: Intended Usage : Intercept the panic caused by a RunL leave, sl@0: to restore the CComponentTester_ManageUnitTests_UnitTest sl@0: object to a sensible state. sl@0: (called by the Active Scheduler immediately before the Panic). sl@0: Error Condition : @see CUnitTest::RunError(). sl@0: @since 7.0 sl@0: @return TInt KErrNone if cleanup successful, otherwise sl@0: @see CUnitTest::RunError() sl@0: @pre CComponentTester_ManageUnitTests_UnitTest is fully constructed, and initialised. sl@0: @post The object has been restored to a sensible state. sl@0: */ sl@0: inline TInt RunError(TInt aError); sl@0: sl@0: /** sl@0: @fn ~CComponentTester_ManageUnitTests_UnitTest() sl@0: Intended Usage : Standard Destructor. sl@0: Error Condition : None. sl@0: @since 7.0 sl@0: @pre CComponentTester_ManageUnitTests_UnitTest is fully constructed. sl@0: @post CComponentTester_ManageUnitTests_UnitTest is fully destroyed. sl@0: */ sl@0: ~CComponentTester_ManageUnitTests_UnitTest(); sl@0: sl@0: private: sl@0: /** sl@0: @fn CComponentTester_ManageUnitTests_UnitTest(CDataLogger& aDataLogger, sl@0: MUnitTestObserver& aObserver) sl@0: Intended Usage : Default constructor. sl@0: Error Condition : None. sl@0: @since 7.0 sl@0: @param aDataLogger The output logging object. sl@0: @param aObserver The observer of this UnitTest. sl@0: @param aStateAccessor WhiteBox state access to the CComponentTester class. sl@0: @pre None. sl@0: @post CComponentTester_ManageUnitTests_UnitTest is fully constructed. sl@0: */ sl@0: inline CComponentTester_ManageUnitTests_UnitTest(CDataLogger& aDataLogger, sl@0: MUnitTestObserver& aObserver); sl@0: sl@0: /** sl@0: @fn void ConstructL() sl@0: Intended Usage : Second phase of safe two phase construction, sl@0: to complete the object initialisation. sl@0: Error Condition : Leaves with an error code. sl@0: @leave KErrNoMemory, and @see CUnitTest::BaseNewL(). sl@0: @since 7.0 sl@0: @return None sl@0: @pre CComponentTester_ManageUnitTests_UnitTest is fully constructed. sl@0: @post CComponentTester_ManageUnitTests_UnitTest is fully initialised. sl@0: */ sl@0: void ConstructL(); sl@0: sl@0: /** sl@0: The context of the Unit Test. sl@0: i.e The CComponentTester class tested by this UnitTest's transitions. sl@0: */ sl@0: CComponentTester_UnitTestContext* iUTContext; sl@0: TComponentTester_StateAccessor* iStateAccessor; sl@0: // C'tor, d'tor, and method transition validators sl@0: TComponentTester_Ctor_TransitionValidator* iCtorValidator; sl@0: TComponentTester_TransitionSets_TransitionValidator* iTransitionSetsValidator; sl@0: TComponentTester_AddUnitTest_TransitionValidator* iAddUnitTestValidator; sl@0: TComponentTester_AddParamUnitTest_TransitionValidator* iAddParamUnitTestValidator; sl@0: TComponentTester_Dtor_TransitionValidator* iDtorValidator; sl@0: }; // CComponentTester_ManageUnitTests_UnitTest sl@0: sl@0: // ______________________________________________________________________________ sl@0: // sl@0: /** sl@0: @internalComponent sl@0: sl@0: Comments : Unit Test for RunTests on CComponentTester, the class under test. sl@0: */ sl@0: class CComponentTester_RunTests_UnitTest : public CUnitTest sl@0: { sl@0: public: sl@0: /** sl@0: @fn NewL(CDataLogger& aDataLogger, sl@0: MUnitTestObserver& aObserver) sl@0: Intended Usage : Standard two-phase construction which leaves nothing on the sl@0: cleanup stack. sl@0: Error Condition : Leaves with the error code. sl@0: @leave KErrNoMemory sl@0: @since 7.0 sl@0: @param aDataLogger The output logging object. sl@0: @param aObserver The observer of this UnitTest. sl@0: @return CComponentTester_RunTests_UnitTest* The constructed object. sl@0: @pre None. sl@0: @post CComponentTester_RunTests_UnitTest is fully constructed, and initialised. sl@0: */ sl@0: static CComponentTester_RunTests_UnitTest* NewL(CDataLogger& aDataLogger, sl@0: MUnitTestObserver& aObserver); sl@0: sl@0: /** sl@0: @fn RunError(TInt aError) sl@0: Intended Usage : Intercept the panic caused by a RunL leave, sl@0: to restore the CComponentTester_RunTests_UnitTest sl@0: object to a sensible state. sl@0: (called by the Active Scheduler immediately before the Panic). sl@0: Error Condition : @see CUnitTest::RunError(). sl@0: @since 7.0 sl@0: @return TInt KErrNone if cleanup successful, otherwise sl@0: @see CUnitTest::RunError() sl@0: @pre CComponentTester_RunTests_UnitTest is fully constructed, and initialised. sl@0: @post The object has been restored to a sensible state. sl@0: */ sl@0: inline TInt RunError(TInt aError); sl@0: sl@0: /** sl@0: @fn ~CComponentTester_RunTests_UnitTest() sl@0: Intended Usage : Standard Destructor. sl@0: Error Condition : None. sl@0: @since 7.0 sl@0: @pre CComponentTester_RunTests_UnitTest is fully constructed. sl@0: @post CComponentTester_RunTests_UnitTest is fully destroyed. sl@0: */ sl@0: ~CComponentTester_RunTests_UnitTest(); sl@0: sl@0: private: sl@0: /** sl@0: @fn CComponentTester_RunTests_UnitTest(CDataLogger& aDataLogger, sl@0: MUnitTestObserver& aObserver) sl@0: Intended Usage : Default constructor. sl@0: Error Condition : None. sl@0: @since 7.0 sl@0: @param aDataLogger The output logging object. sl@0: @param aObserver The observer of this UnitTest. sl@0: @param aStateAccessor WhiteBox state access to the CComponentTester class. sl@0: @pre None. sl@0: @post CComponentTester_RunTests_UnitTest is fully constructed. sl@0: */ sl@0: inline CComponentTester_RunTests_UnitTest(CDataLogger& aDataLogger, sl@0: MUnitTestObserver& aObserver); sl@0: sl@0: /** sl@0: @fn void ConstructL() sl@0: Intended Usage : Second phase of safe two phase construction, sl@0: to complete the object initialisation. sl@0: Error Condition : Leaves with an error code. sl@0: @leave KErrNoMemory, and @see CUnitTest::BaseNewL(). sl@0: @since 7.0 sl@0: @return None sl@0: @pre CComponentTester_RunTests_UnitTest is fully constructed. sl@0: @post CComponentTester_RunTests_UnitTest is fully initialised. sl@0: */ sl@0: void ConstructL(); sl@0: sl@0: /** sl@0: The context of the Unit Test. sl@0: i.e The CComponentTester class tested by this UnitTest's transitions. sl@0: */ sl@0: CComponentTester_UnitTestContext* iUTContext; sl@0: TComponentTester_StateAccessor* iStateAccessor; sl@0: // C'tor, d'tor, and method transition validators sl@0: TComponentTester_Ctor_TransitionValidator* iCtorValidator; sl@0: TComponentTester_TestComponent_TransitionValidator* iTestComponentValidator; sl@0: TComponentTester_Run_TransitionValidator* iRunValidator; sl@0: TComponentTester_Complete_TransitionValidator* iCompleteValidator; sl@0: TComponentTester_Dtor_TransitionValidator* iDtorValidator; sl@0: }; // CComponentTester_RunTests_UnitTest sl@0: sl@0: sl@0: #endif // __COMPONENTTESTERUNITTEST_H__