--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/cryptomgmtlibs/securitytestfw/test/testhandler2/t_testrunner.h Wed Jul 08 11:25:26 2009 +0100
@@ -0,0 +1,144 @@
+/*
+* Copyright (c) 2004-2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "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:
+*
+*/
+
+
+#ifndef __T_TESTRUNNER_H__
+#define __T_TESTRUNNER_H__
+
+#include <e32base.h>
+
+class Output;
+class CTestAction;
+
+/**
+ * A class that is used to invoke individual tests. This can be derived to
+ * implement OOM testing, cancel testing and the like. The default
+ * implementation just runs the test.
+ *
+ * One instance of this class is used to run multiple tests. A CTestHandler
+ * owns an instance of this class (or a class derived from it).
+ *
+ * Note that this class provides a synchronous interface, which is implemented
+ * in terms of CTestActions's asynchronous interface.
+ */
+class CTestRunner : public CActive
+ {
+ public:
+ IMPORT_C CTestRunner(Output& aOut);
+ IMPORT_C virtual ~CTestRunner();
+
+ // The following methods return the status code from test action, but leave
+ // if there is an error in the test handler.
+
+ IMPORT_C virtual TInt PerformPrerequisiteL(CTestAction* aAction);
+ IMPORT_C virtual TInt PerformActionL(CTestAction* aAction);
+ IMPORT_C virtual TInt PerformPostrequisiteL(CTestAction* aAction, TInt aInitialStatus);
+
+ protected:
+ /// Typedef for any of CTestAction's async methods
+ typedef void (CTestAction::*TTestMethod)(TRequestStatus&);
+
+ /// Run one of CTestAction's async methods synchronously and return the result
+ TInt RunAsyncMethodL(TTestMethod aMethod, CTestAction* aAction, TInt aInitialStatus);
+
+ /// Run the active scheduler until our request is completed
+ void RunSchedulerL();
+
+ /// Run the active scheduler to process one outstanding request
+ /// @return If our request has been completed yet
+ TBool StepScheduler();
+
+ protected:
+ Output& iOut;
+
+ private:
+ IMPORT_C virtual TInt RunError(TInt aError);
+ IMPORT_C virtual void DoCancel();
+ IMPORT_C virtual void RunL();
+
+ private:
+ /// Whether an async method is currently being executed by the active scheduler
+ TBool iSchedulerRunning;
+ };
+
+/**
+ * Abstract base class for a test runner that implements OOM testing.
+ */
+class COOMTestRunnerBase : public CTestRunner
+ {
+ public:
+ IMPORT_C virtual ~COOMTestRunnerBase();
+
+ protected:
+ IMPORT_C COOMTestRunnerBase(Output& aOut);
+
+ /// Called at the start of the OOM test
+ virtual void StartOOMTestL() = 0;
+ /// Increment the simulated heap fail point
+ virtual void IncHeapFailPoint() = 0;
+ /// Reset simulated heap failures
+ virtual void ResetHeapFail() = 0;
+ /// Get the number of cells currently allocated
+ virtual TInt AllocCount() = 0;
+ /// Called at the end of the OOM test
+ virtual void EndOOMTestL() = 0;
+
+ private:
+ // Override CTestRunner interface
+ IMPORT_C virtual TInt PerformActionL(CTestAction* aAction);
+ };
+
+/**
+ * Implementation of an test runner for OOM testing.
+ */
+class COOMTestRunner : public COOMTestRunnerBase
+ {
+ public:
+ COOMTestRunner(Output& aOut);
+ virtual ~COOMTestRunner();
+
+ private:
+ // Implement interface defined by COOMTestRunnerBase
+ virtual void StartOOMTestL();
+ virtual void IncHeapFailPoint();
+ virtual void ResetHeapFail();
+ virtual TInt AllocCount();
+ virtual void EndOOMTestL();
+
+ private:
+ TInt iFailPoint;
+ };
+
+/// A test runner that performs cancellation tests.
+class CCancelTestRunner : public CTestRunner
+ {
+ public:
+ CCancelTestRunner(Output& aOut);
+ virtual ~CCancelTestRunner();
+
+ virtual TInt PerformActionL(CTestAction* aAction);
+
+ private:
+ TInt RunAndCancelPeformActionMethod(CTestAction* aAction, TInt aInitialStatus,
+ TInt aCancelStep, TInt& aStep);
+ TInt RunAndCancelTestAction(CTestAction* aAction, TInt aCancelStep);
+
+ private:
+ TBool iAbort; ///< Set when we want to abort the test
+ };
+
+#endif