tcuTestContext.hpp revision 3c827367444ee418f129b2c238299f49d3264554
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 32namespace tcu 33{ 34 35class Archive; 36class Platform; 37class CommandLine; 38class 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 *//*--------------------------------------------------------------------*/ 48class TestContext 49{ 50public: 51 TestContext (Platform& platform, Archive& rootArchive, TestLog& log, const CommandLine& cmdLine, qpWatchDog* watchDog); 52 ~TestContext (void) {} 53 54 // API for test cases 55 TestLog& getLog (void) { return m_log; } 56 Archive& getArchive (void) { return *m_curArchive; } //!< \note Do not access in TestNode constructors. 57 Platform& getPlatform (void) { return m_platform; } 58 void setTestResult (qpTestResult result, const char* description); 59 void touchWatchdog (void); 60 const CommandLine& getCommandLine (void) const { return m_cmdLine; } 61 62 // API for test framework 63 qpTestResult getTestResult (void) const { return m_testResult; } 64 const char* getTestResultDesc (void) const { return m_testResultDesc.c_str(); } 65 qpWatchDog* getWatchDog (void) { return m_watchDog; } 66 67 Archive& getRootArchive (void) const { return m_rootArchive; } 68 void setCurrentArchive (Archive& archive) { m_curArchive = &archive; } 69 70protected: 71 Platform& m_platform; //!< Platform port implementation. 72 Archive& m_rootArchive; //!< Root archive. 73 TestLog& m_log; //!< Test log. 74 const CommandLine& m_cmdLine; //!< Command line. 75 qpWatchDog* m_watchDog; //!< Watchdog (can be null). 76 77 Archive* m_curArchive; //!< Current archive for test cases. 78 qpTestResult m_testResult; //!< Latest test result. 79 std::string m_testResultDesc; //!< Latest test result description. 80}; 81 82/*--------------------------------------------------------------------*//*! 83 * \brief Test result collector 84 * 85 * This utility class collects test results with associated messages, 86 * optionally logs them, and finally sets the test result of a TestContext to 87 * the most severe collected result. This allows multiple problems to be 88 * easily reported from a single test run. 89 *//*--------------------------------------------------------------------*/ 90class ResultCollector 91{ 92public: 93 ResultCollector (void); 94 ResultCollector (TestLog& log, const std::string& prefix = ""); 95 96 qpTestResult getResult (void) const { return m_result; } 97 98 void fail (const std::string& msg); 99 bool check (bool condition, const std::string& msg); 100 101 void addResult (qpTestResult result, const std::string& msg); 102 bool checkResult (bool condition, qpTestResult result, const std::string& msg); 103 104 void setTestContextResult (TestContext& testCtx); 105 106private: 107 TestLog* m_log; 108 std::string m_prefix; 109 qpTestResult m_result; 110 std::string m_message; 111}; 112 113} // tcu 114 115#endif // _TCUTESTCONTEXT_HPP 116