Home | History | Annotate | Download | only in common
      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);
     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 
     70 protected:
     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  *//*--------------------------------------------------------------------*/
     90 class ResultCollector
     91 {
     92 public:
     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 
    106 private:
    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