1/*-------------------------------------------------------------------------
2 * drawElements Quality Program OpenGL ES 2.0 Module
3 * -------------------------------------------------
4 *
5 * Copyright 2014 The Android Open Source Project
6 *
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
10 *
11 *      http://www.apache.org/licenses/LICENSE-2.0
12 *
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 *
19 *//*!
20 * \file
21 * \brief OpenGL ES 2.0 Test Case Wrapper.
22 *//*--------------------------------------------------------------------*/
23
24#include "tes2TestCaseWrapper.hpp"
25#include "tcuTestLog.hpp"
26#include "gluDefs.hpp"
27#include "gluStateReset.hpp"
28#include "glwEnums.hpp"
29#include "glwFunctions.hpp"
30
31namespace deqp
32{
33namespace gles2
34{
35
36using tcu::TestLog;
37
38TestCaseWrapper::TestCaseWrapper (tcu::TestContext& testCtx, glu::RenderContext& renderCtx)
39	: tcu::TestCaseWrapper	(testCtx)
40	, m_renderCtx			(renderCtx)
41{
42	TCU_CHECK(contextSupports(renderCtx.getType(), glu::ApiType::es(2,0)));
43}
44
45TestCaseWrapper::~TestCaseWrapper (void)
46{
47}
48
49bool TestCaseWrapper::initTestCase (tcu::TestCase* testCase)
50{
51	return tcu::TestCaseWrapper::initTestCase(testCase);
52}
53
54bool TestCaseWrapper::deinitTestCase (tcu::TestCase* testCase)
55{
56	TestLog& log = m_testCtx.getLog();
57
58	if (!tcu::TestCaseWrapper::deinitTestCase(testCase))
59		return false;
60
61	try
62	{
63		// Reset state
64		glu::resetState(m_renderCtx);
65	}
66	catch (const std::exception& e)
67	{
68		log << e;
69		log << TestLog::Message << "Error in state reset, test program will terminate." << TestLog::EndMessage;
70		return false;
71	}
72
73	return true;
74}
75
76tcu::TestNode::IterateResult TestCaseWrapper::iterateTestCase (tcu::TestCase* testCase)
77{
78	TestLog&						log		= m_testCtx.getLog();
79	const glw::Functions&			gl		= m_renderCtx.getFunctions();
80	tcu::TestCase::IterateResult	result	= tcu::TestNode::STOP;
81
82	// Clear to surrender-blue
83	gl.clearColor(0.125f, 0.25f, 0.5f, 1.f);
84	gl.clear(GL_COLOR_BUFFER_BIT);
85
86	result = tcu::TestCaseWrapper::iterateTestCase(testCase);
87
88	// Call implementation specific post-iterate routine (usually handles native events and swaps buffers)
89	try
90	{
91		m_renderCtx.postIterate();
92		return result;
93	}
94	catch (const tcu::ResourceError& e)
95	{
96		m_testCtx.getLog() << e;
97		m_testCtx.setTestResult(QP_TEST_RESULT_RESOURCE_ERROR, "Resource error in context post-iteration routine");
98		m_testCtx.setTerminateAfter(true);
99		return tcu::TestNode::STOP;
100	}
101	catch (const std::exception& e)
102	{
103		log << e;
104		m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Error in context post-iteration routine");
105		return tcu::TestNode::STOP;
106	}
107}
108
109} // gles2
110} // deqp
111