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