Update contrib.
1 // Copyright (c) 1997-2009 Nokia Corporation and/or its subsidiary(-ies).
2 // All rights reserved.
3 // This component and the accompanying materials are made available
4 // under the terms of "Eclipse Public License v1.0"
5 // which accompanies this distribution, and is available
6 // at the URL "http://www.eclipse.org/legal/epl-v10.html".
8 // Initial Contributors:
9 // Nokia Corporation - initial contribution.
14 // The unit test class definitions for the CUnitTest class.
18 #ifndef __UNITTESTUNITTEST_H__
19 #define __UNITTESTUNITTEST_H__
21 #include <ecom/test_bed/testbeddefinitions.h>
22 #include "UnitTestStateAccessor.h"
23 #include "UnitTestTransitionValidation.h"
24 #include "UnitTestTransitions.h"
26 // ______________________________________________________________________________
31 Comments : Unit Test for CreateAndDestroy on CUnitTest, the class under test.
33 class CUnitTest_CreateAndDestroy_UnitTest : public CUnitTest
37 @fn NewL(CDataLogger& aDataLogger,
38 MUnitTestObserver& aObserver)
39 Intended Usage : Standard two-phase construction which leaves nothing on the
41 Error Condition : Leaves with the error code.
44 @param aDataLogger The output logging object.
45 @param aObserver The observer of this UnitTest.
46 @return CUnitTest_CreateAndDestroy_UnitTest* The constructed object.
48 @post CUnitTest_CreateAndDestroy_UnitTest is fully constructed, and initialised.
50 static CUnitTest_CreateAndDestroy_UnitTest* NewL(CDataLogger& aDataLogger,
51 MUnitTestObserver& aObserver);
54 @fn RunError(TInt aError)
55 Intended Usage : Intercept the panic caused by a RunL leave,
56 to restore the CUnitTest_CreateAndDestroy_UnitTest
57 object to a sensible state.
58 (called by the Active Scheduler immediately before the Panic).
59 Error Condition : @see CUnitTest::RunError().
61 @return TInt KErrNone if cleanup successful, otherwise
62 @see CUnitTest::RunError()
63 @pre CUnitTest_CreateAndDestroy_UnitTest is fully constructed, and initialised.
64 @post The object has been restored to a sensible state.
66 inline TInt RunError(TInt aError);
69 @fn ~CUnitTest_CreateAndDestroy_UnitTest()
70 Intended Usage : Standard Destructor.
71 Error Condition : None.
73 @pre CUnitTest_CreateAndDestroy_UnitTest is fully constructed.
74 @post CUnitTest_CreateAndDestroy_UnitTest is fully destroyed.
76 ~CUnitTest_CreateAndDestroy_UnitTest();
80 @fn CUnitTest_CreateAndDestroy_UnitTest(CDataLogger& aDataLogger,
81 MUnitTestObserver& aObserver)
82 Intended Usage : Default constructor.
83 Error Condition : None.
85 @param aDataLogger The output logging object.
86 @param aObserver The observer of this UnitTest.
87 @param aStateAccessor WhiteBox state access to the CUnitTest class.
89 @post CUnitTest_CreateAndDestroy_UnitTest is fully constructed.
91 inline CUnitTest_CreateAndDestroy_UnitTest(CDataLogger& aDataLogger,
92 MUnitTestObserver& aObserver);
96 Intended Usage : Second phase of safe two phase construction,
97 to complete the object initialisation.
98 Error Condition : Leaves with an error code.
99 @leave KErrNoMemory, and @see CUnitTest::BaseNewL().
102 @pre CUnitTest_CreateAndDestroy_UnitTest is fully constructed.
103 @post CUnitTest_CreateAndDestroy_UnitTest is fully initialised.
108 The context of the Unit Test.
109 i.e The CUnitTest class tested by this UnitTest's transitions.
111 CUnitTest_UnitTestContext* iUTContext;
112 TUnitTest_StateAccessor* iStateAccessor;
113 // C'tor, d'tor, and method transition validators
114 TUnitTest_Ctor_TransitionValidator* iCtorValidator;
115 TUnitTest_Dtor_TransitionValidator* iDtorValidator;
116 }; // CUnitTest_CreateAndDestroy_UnitTest
118 // ______________________________________________________________________________
123 Comments : Unit Test for ManageTransitions on CUnitTest, the class under test.
125 class CUnitTest_ManageTransitions_UnitTest : public CUnitTest
129 @fn NewL(CDataLogger& aDataLogger,
130 MUnitTestObserver& aObserver)
131 Intended Usage : Standard two-phase construction which leaves nothing on the
133 Error Condition : Leaves with the error code.
136 @param aDataLogger The output logging object.
137 @param aObserver The observer of this UnitTest.
138 @return CUnitTest_ManageTransitions_UnitTest* The constructed object.
140 @post CUnitTest_ManageTransitions_UnitTest is fully constructed, and initialised.
142 static CUnitTest_ManageTransitions_UnitTest* NewL(CDataLogger& aDataLogger,
143 MUnitTestObserver& aObserver);
146 @fn RunError(TInt aError)
147 Intended Usage : Intercept the panic caused by a RunL leave,
148 to restore the CUnitTest_ManageTransitions_UnitTest
149 object to a sensible state.
150 (called by the Active Scheduler immediately before the Panic).
151 Error Condition : @see CUnitTest::RunError().
153 @return TInt KErrNone if cleanup successful, otherwise
154 @see CUnitTest::RunError()
155 @pre CUnitTest_ManageTransitions_UnitTest is fully constructed, and initialised.
156 @post The object has been restored to a sensible state.
158 inline TInt RunError(TInt aError);
161 @fn ~CUnitTest_ManageTransitions_UnitTest()
162 Intended Usage : Standard Destructor.
163 Error Condition : None.
165 @pre CUnitTest_ManageTransitions_UnitTest is fully constructed.
166 @post CUnitTest_ManageTransitions_UnitTest is fully destroyed.
168 ~CUnitTest_ManageTransitions_UnitTest();
172 @fn CUnitTest_ManageTransitions_UnitTest(CDataLogger& aDataLogger,
173 MUnitTestObserver& aObserver)
174 Intended Usage : Default constructor.
175 Error Condition : None.
177 @param aDataLogger The output logging object.
178 @param aObserver The observer of this UnitTest.
179 @param aStateAccessor WhiteBox state access to the CUnitTest class.
181 @post CUnitTest_ManageTransitions_UnitTest is fully constructed.
183 inline CUnitTest_ManageTransitions_UnitTest(CDataLogger& aDataLogger,
184 MUnitTestObserver& aObserver);
187 @fn void ConstructL()
188 Intended Usage : Second phase of safe two phase construction,
189 to complete the object initialisation.
190 Error Condition : Leaves with an error code.
191 @leave KErrNoMemory, and @see CUnitTest::BaseNewL().
194 @pre CUnitTest_ManageTransitions_UnitTest is fully constructed.
195 @post CUnitTest_ManageTransitions_UnitTest is fully initialised.
200 The context of the Unit Test.
201 i.e The CUnitTest class tested by this UnitTest's transitions.
203 CUnitTest_UnitTestContext* iUTContext;
204 TUnitTest_StateAccessor* iStateAccessor;
205 // C'tor, d'tor, and method transition validators
206 TUnitTest_Ctor_TransitionValidator* iCtorValidator;
207 TUnitTest_TransitionSet_TransitionValidator* iTransitionSetValidator;
208 TUnitTest_SetCurrentTransition_TransitionValidator* iSetCurrentTransitionValidator;
209 TUnitTest_GetCurrentTransition_TransitionValidator* iGetCurrentTransitionValidator;
210 TUnitTest_Dtor_TransitionValidator* iDtorValidator;
211 }; // CUnitTest_ManageTransitions_UnitTest
213 // ______________________________________________________________________________
218 Comments : Unit Test for RunTests on CUnitTest, the class under test.
220 class CUnitTest_RunTests_UnitTest : public CUnitTest
224 @fn NewL(CDataLogger& aDataLogger,
225 MUnitTestObserver& aObserver)
226 Intended Usage : Standard two-phase construction which leaves nothing on the
228 Error Condition : Leaves with the error code.
231 @param aDataLogger The output logging object.
232 @param aObserver The observer of this UnitTest.
233 @return CUnitTest_RunTests_UnitTest* The constructed object.
235 @post CUnitTest_RunTests_UnitTest is fully constructed, and initialised.
237 static CUnitTest_RunTests_UnitTest* NewL(CDataLogger& aDataLogger,
238 MUnitTestObserver& aObserver);
241 @fn RunError(TInt aError)
242 Intended Usage : Intercept the panic caused by a RunL leave,
243 to restore the CUnitTest_RunTests_UnitTest
244 object to a sensible state.
245 (called by the Active Scheduler immediately before the Panic).
246 Error Condition : @see CUnitTest::RunError().
248 @return TInt KErrNone if cleanup successful, otherwise
249 @see CUnitTest::RunError()
250 @pre CUnitTest_RunTests_UnitTest is fully constructed, and initialised.
251 @post The object has been restored to a sensible state.
253 inline TInt RunError(TInt aError);
256 @fn ~CUnitTest_RunTests_UnitTest()
257 Intended Usage : Standard Destructor.
258 Error Condition : None.
260 @pre CUnitTest_RunTests_UnitTest is fully constructed.
261 @post CUnitTest_RunTests_UnitTest is fully destroyed.
263 ~CUnitTest_RunTests_UnitTest();
267 @fn CUnitTest_RunTests_UnitTest(CDataLogger& aDataLogger,
268 MUnitTestObserver& aObserver)
269 Intended Usage : Default constructor.
270 Error Condition : None.
272 @param aDataLogger The output logging object.
273 @param aObserver The observer of this UnitTest.
274 @param aStateAccessor WhiteBox state access to the CUnitTest class.
276 @post CUnitTest_RunTests_UnitTest is fully constructed.
278 inline CUnitTest_RunTests_UnitTest(CDataLogger& aDataLogger,
279 MUnitTestObserver& aObserver);
282 @fn void ConstructL()
283 Intended Usage : Second phase of safe two phase construction,
284 to complete the object initialisation.
285 Error Condition : Leaves with an error code.
286 @leave KErrNoMemory, and @see CUnitTest::BaseNewL().
289 @pre CUnitTest_RunTests_UnitTest is fully constructed.
290 @post CUnitTest_RunTests_UnitTest is fully initialised.
295 The context of the Unit Test.
296 i.e The CUnitTest class tested by this UnitTest's transitions.
298 CUnitTest_UnitTestContext* iUTContext;
299 TUnitTest_StateAccessor* iStateAccessor;
300 // C'tor, d'tor, and method transition validators
301 TUnitTest_Ctor_TransitionValidator* iCtorValidator;
302 TUnitTest_SetParameters_TransitionValidator* iSetParametersValidator;
303 TUnitTest_PrepareUnitTest_TransitionValidator* iPrepareUnitTestValidator;
304 TUnitTest_RunTest_TransitionValidator* iRunTestValidator;
305 TUnitTest_Dtor_TransitionValidator* iDtorValidator;
306 }; // CUnitTest_RunTests_UnitTest
308 // ______________________________________________________________________________
313 Comments : Unit Test for AllOther on CUnitTest, the class under test.
315 class CUnitTest_AllOther_UnitTest : public CUnitTest
319 @fn NewL(CDataLogger& aDataLogger,
320 MUnitTestObserver& aObserver)
321 Intended Usage : Standard two-phase construction which leaves nothing on the
323 Error Condition : Leaves with the error code.
326 @param aDataLogger The output logging object.
327 @param aObserver The observer of this UnitTest.
328 @return CUnitTest_AllOther_UnitTest* The constructed object.
330 @post CUnitTest_AllOther_UnitTest is fully constructed, and initialised.
332 static CUnitTest_AllOther_UnitTest* NewL(CDataLogger& aDataLogger,
333 MUnitTestObserver& aObserver);
336 @fn RunError(TInt aError)
337 Intended Usage : Intercept the panic caused by a RunL leave,
338 to restore the CUnitTest_AllOther_UnitTest
339 object to a sensible state.
340 (called by the Active Scheduler immediately before the Panic).
341 Error Condition : @see CUnitTest::RunError().
343 @return TInt KErrNone if cleanup successful, otherwise
344 @see CUnitTest::RunError()
345 @pre CUnitTest_AllOther_UnitTest is fully constructed, and initialised.
346 @post The object has been restored to a sensible state.
348 inline TInt RunError(TInt aError);
351 @fn ~CUnitTest_AllOther_UnitTest()
352 Intended Usage : Standard Destructor.
353 Error Condition : None.
355 @pre CUnitTest_AllOther_UnitTest is fully constructed.
356 @post CUnitTest_AllOther_UnitTest is fully destroyed.
358 ~CUnitTest_AllOther_UnitTest();
362 @fn CUnitTest_AllOther_UnitTest(CDataLogger& aDataLogger,
363 MUnitTestObserver& aObserver)
364 Intended Usage : Default constructor.
365 Error Condition : None.
367 @param aDataLogger The output logging object.
368 @param aObserver The observer of this UnitTest.
369 @param aStateAccessor WhiteBox state access to the CUnitTest class.
371 @post CUnitTest_AllOther_UnitTest is fully constructed.
373 inline CUnitTest_AllOther_UnitTest(CDataLogger& aDataLogger,
374 MUnitTestObserver& aObserver);
377 @fn void ConstructL()
378 Intended Usage : Second phase of safe two phase construction,
379 to complete the object initialisation.
380 Error Condition : Leaves with an error code.
381 @leave KErrNoMemory, and @see CUnitTest::BaseNewL().
384 @pre CUnitTest_AllOther_UnitTest is fully constructed.
385 @post CUnitTest_AllOther_UnitTest is fully initialised.
390 The context of the Unit Test.
391 i.e The CUnitTest class tested by this UnitTest's transitions.
393 CUnitTest_UnitTestContext* iUTContext;
394 TUnitTest_StateAccessor* iStateAccessor;
395 // C'tor, d'tor, and method transition validators
396 TUnitTest_Ctor_TransitionValidator* iCtorValidator;
397 TUnitTest_AddTransition_TransitionValidator* iAddTransitionValidator;
398 TUnitTest_AddBlockingTransition_TransitionValidator* iAddBlockingTransitionValidator;
399 TUnitTest_AddLeaveErrorCode_TransitionValidator* iAddLeaveErrorCodeValidator;
400 TUnitTest_UnitTestName_TransitionValidator* iUnitTestNameValidator;
401 TUnitTest_Dtor_TransitionValidator* iDtorValidator;
402 }; // CUnitTest_AllOther_UnitTest
405 #endif // __UNITTESTUNITTEST_H__