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 definition of the CResolver unit test classes. sl@0: // sl@0: // sl@0: sl@0: #ifndef __RESOLVERUNITTESTS_H__ sl@0: #define __RESOLVERUNITTESTS_H__ sl@0: sl@0: #include "ResolverTransitions.h" sl@0: #include "ResolverStateAccessor.h" sl@0: #include "ResolverTransitionValidation.h" sl@0: sl@0: // ______________________________________________________________________________ sl@0: // sl@0: /** sl@0: @internalComponent sl@0: sl@0: Comments : Unit Test for CreateAndDestroy on CDefaultResolver, the class under test. sl@0: */ sl@0: class CDefaultResolver_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 CDefaultResolver_CreateAndDestroy_UnitTest* The constructed object. sl@0: @pre None. sl@0: @post CDefaultResolver_CreateAndDestroy_UnitTest is fully constructed, and initialised. sl@0: */ sl@0: static CDefaultResolver_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 CDefaultResolver_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 CDefaultResolver_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 ~CDefaultResolver_CreateAndDestroy_UnitTest() sl@0: Intended Usage : Standard Destructor. sl@0: Error Condition : None. sl@0: @since 7.0 sl@0: @pre CDefaultResolver_CreateAndDestroy_UnitTest is fully constructed. sl@0: @post CDefaultResolver_CreateAndDestroy_UnitTest is fully destroyed. sl@0: */ sl@0: ~CDefaultResolver_CreateAndDestroy_UnitTest(); sl@0: sl@0: /** sl@0: @fn PrepareUnitTestL() sl@0: Intended Usage : Called by test framework just before test is run to allow sl@0: any test preparation to take place. sl@0: Error Condition : sl@0: @since 7.0 sl@0: @pre CDefaultResolver_CreateAndDestroy_UnitTest is fully constructed. sl@0: @post This unit test is ready to run. sl@0: */ sl@0: void PrepareUnitTestL(); sl@0: sl@0: private: sl@0: /** sl@0: @fn CDefaultResolver_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 CDefaultResolver class. sl@0: @pre None. sl@0: @post CDefaultResolver_CreateAndDestroy_UnitTest is fully constructed. sl@0: */ sl@0: inline CDefaultResolver_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 CDefaultResolver_CreateAndDestroy_UnitTest is fully constructed. sl@0: @post CDefaultResolver_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 CDefaultResolver class tested by this UnitTest's transitions. sl@0: */ sl@0: CDefaultResolver_UnitTestContext* iUTContext; sl@0: TDefaultResolver_StateAccessor* iStateAccessor; sl@0: // C'tor, d'tor, and method transition validators sl@0: TDefaultResolver_Ctor_TransitionValidator* iCtorValidator; sl@0: TDefaultResolver_Dtor_TransitionValidator* iDtorValidator; sl@0: }; // CDefaultResolver_CreateAndDestroy_UnitTest sl@0: sl@0: // ______________________________________________________________________________ sl@0: // sl@0: /** sl@0: @internalComponent sl@0: sl@0: Comments : Unit Test for IdentifyImplementation on CDefaultResolver, the class under test. sl@0: */ sl@0: class CDefaultResolver_IdentifyImplementation_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 CDefaultResolver_IdentifyImplementation_UnitTest* The constructed object. sl@0: @pre None. sl@0: @post CDefaultResolver_IdentifyImplementation_UnitTest is fully constructed, and initialised. sl@0: */ sl@0: static CDefaultResolver_IdentifyImplementation_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 CDefaultResolver_IdentifyImplementation_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 CDefaultResolver_IdentifyImplementation_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 ~CDefaultResolver_IdentifyImplementation_UnitTest() sl@0: Intended Usage : Standard Destructor. sl@0: Error Condition : None. sl@0: @since 7.0 sl@0: @pre CDefaultResolver_IdentifyImplementation_UnitTest is fully constructed. sl@0: @post CDefaultResolver_IdentifyImplementation_UnitTest is fully destroyed. sl@0: */ sl@0: ~CDefaultResolver_IdentifyImplementation_UnitTest(); sl@0: sl@0: private: sl@0: /** sl@0: @fn CDefaultResolver_IdentifyImplementation_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 CDefaultResolver class. sl@0: @pre None. sl@0: @post CDefaultResolver_IdentifyImplementation_UnitTest is fully constructed. sl@0: */ sl@0: inline CDefaultResolver_IdentifyImplementation_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 CDefaultResolver_IdentifyImplementation_UnitTest is fully constructed. sl@0: @post CDefaultResolver_IdentifyImplementation_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 CDefaultResolver class tested by this UnitTest's transitions. sl@0: */ sl@0: CDefaultResolver_UnitTestContext* iUTContext; sl@0: TDefaultResolver_StateAccessor* iStateAccessor; sl@0: // C'tor, d'tor, and method transition validators sl@0: TDefaultResolver_Ctor_TransitionValidator* iCtorValidator; sl@0: TDefaultResolver_Default_TransitionValidator* iDefaultValidator; sl@0: TDefaultResolver_Match_TransitionValidator* iMatchValidator; sl@0: TDefaultResolver_IdentifyImplementationL_TransitionValidator* iIdentifyImplementationValidator; sl@0: TDefaultResolver_Dtor_TransitionValidator* iDtorValidator; sl@0: }; // CDefaultResolver_IdentifyImplementation_UnitTest sl@0: sl@0: #include "ResolverUnitTests.inl" sl@0: sl@0: #endif // __RESOLVERUNITTESTS_H__