1 #ifndef _TCUTESTCONTEXT_HPP 2 #define _TCUTESTCONTEXT_HPP 3 /*------------------------------------------------------------------------- 4 * drawElements Quality Program Tester Core 5 * ---------------------------------------- 6 * 7 * Copyright 2014 The Android Open Source Project 8 * 9 * Licensed under the Apache License, Version 2.0 (the "License"); 10 * you may not use this file except in compliance with the License. 11 * You may obtain a copy of the License at 12 * 13 * http://www.apache.org/licenses/LICENSE-2.0 14 * 15 * Unless required by applicable law or agreed to in writing, software 16 * distributed under the License is distributed on an "AS IS" BASIS, 17 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 18 * See the License for the specific language governing permissions and 19 * limitations under the License. 20 * 21 *//*! 22 * \file 23 * \brief Context shared between test cases. 24 *//*--------------------------------------------------------------------*/ 25 26 #include "tcuDefs.hpp" 27 #include "qpWatchDog.h" 28 #include "qpTestLog.h" 29 30 #include <string> 31 32 namespace tcu 33 { 34 35 class Archive; 36 class Platform; 37 class CommandLine; 38 class TestLog; 39 40 /*--------------------------------------------------------------------*//*! 41 * \brief Test context 42 * 43 * Test context holds common resources that are available to test cases. 44 * This includes test log and resource archive. 45 * 46 * Test case can write to test log and must set test result to test context. 47 *//*--------------------------------------------------------------------*/ 48 class TestContext 49 { 50 public: 51 TestContext (Platform& platform, Archive& rootArchive, TestLog& log, const CommandLine& cmdLine, qpWatchDog* watchDog); ~TestContext(void)52 ~TestContext (void) {} 53 54 void writeSessionInfo (void); 55 56 // API for test cases getLog(void)57 TestLog& getLog (void) { return m_log; } getArchive(void)58 Archive& getArchive (void) { return *m_curArchive; } //!< \note Do not access in TestNode constructors. getPlatform(void)59 Platform& getPlatform (void) { return m_platform; } 60 void setTestResult (qpTestResult result, const char* description); 61 void touchWatchdog (void); 62 void touchWatchdogAndDisableIntervalTimeLimit (void); 63 void touchWatchdogAndEnableIntervalTimeLimit (void); getCommandLine(void) const64 const CommandLine& getCommandLine (void) const { return m_cmdLine; } 65 66 // API for test framework getTestResult(void) const67 qpTestResult getTestResult (void) const { return m_testResult; } getTestResultDesc(void) const68 const char* getTestResultDesc (void) const { return m_testResultDesc.c_str(); } getWatchDog(void)69 qpWatchDog* getWatchDog (void) { return m_watchDog; } 70 getRootArchive(void) const71 Archive& getRootArchive (void) const { return m_rootArchive; } setCurrentArchive(Archive & archive)72 void setCurrentArchive (Archive& archive) { m_curArchive = &archive; } 73 setTerminateAfter(bool terminate)74 void setTerminateAfter (bool terminate) { m_terminateAfter = terminate; } getTerminateAfter(void) const75 bool getTerminateAfter (void) const { return m_terminateAfter; } 76 77 protected: 78 TestContext (const TestContext&); 79 TestContext& operator= (const TestContext&); 80 81 Platform& m_platform; //!< Platform port implementation. 82 Archive& m_rootArchive; //!< Root archive. 83 TestLog& m_log; //!< Test log. 84 const CommandLine& m_cmdLine; //!< Command line. 85 qpWatchDog* m_watchDog; //!< Watchdog (can be null). 86 87 Archive* m_curArchive; //!< Current archive for test cases. 88 qpTestResult m_testResult; //!< Latest test result. 89 std::string m_testResultDesc; //!< Latest test result description. 90 bool m_terminateAfter; //!< Should tester terminate after execution of the current test 91 }; 92 93 } // tcu 94 95 #endif // _TCUTESTCONTEXT_HPP 96