1 /*-------------------------------------------------------------------------
2 * drawElements Quality Program EGL 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 API test case.
22 *//*--------------------------------------------------------------------*/
23
24 #include "teglApiCase.hpp"
25 #include "egluUtil.hpp"
26 #include "egluStrUtil.hpp"
27 #include "eglwLibrary.hpp"
28 #include "eglwEnums.hpp"
29 #include "deSTLUtil.hpp"
30
31 namespace deqp
32 {
33 namespace egl
34 {
35
36 using tcu::TestLog;
37 using std::vector;
38 using namespace eglw;
39
ApiCase(EglTestContext & eglTestCtx,const char * name,const char * description)40 ApiCase::ApiCase (EglTestContext& eglTestCtx, const char* name, const char* description)
41 : TestCase (eglTestCtx, name, description)
42 , CallLogWrapper(eglTestCtx.getLibrary(), eglTestCtx.getTestContext().getLog())
43 , m_display (EGL_NO_DISPLAY)
44 {
45 }
46
~ApiCase(void)47 ApiCase::~ApiCase (void)
48 {
49 }
50
init(void)51 void ApiCase::init (void)
52 {
53 m_display = eglu::getAndInitDisplay(m_eglTestCtx.getNativeDisplay());
54 m_supportedClientAPIs = eglu::getClientAPIs(m_eglTestCtx.getLibrary(), m_display);
55 }
56
deinit(void)57 void ApiCase::deinit (void)
58 {
59 const Library& egl = m_eglTestCtx.getLibrary();
60 egl.terminate(m_display);
61
62 m_display = EGL_NO_DISPLAY;
63 m_supportedClientAPIs.clear();
64 }
65
iterate(void)66 ApiCase::IterateResult ApiCase::iterate (void)
67 {
68 // Initialize result to pass.
69 m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass");
70
71 // Enable call logging.
72 enableLogging(true);
73
74 // Run test.
75 test();
76
77 return STOP;
78 }
79
isAPISupported(eglw::EGLenum api) const80 bool ApiCase::isAPISupported (eglw::EGLenum api) const
81 {
82 return de::contains(m_supportedClientAPIs.begin(), m_supportedClientAPIs.end(), api);
83 }
84
expectError(EGLenum expected)85 void ApiCase::expectError (EGLenum expected)
86 {
87 EGLenum err = m_eglTestCtx.getLibrary().getError();
88 if (err != expected)
89 {
90 m_testCtx.getLog() << TestLog::Message << "// ERROR expected: " << eglu::getErrorStr(expected) << ", Got: " << eglu::getErrorStr(err) << TestLog::EndMessage;
91 if (m_testCtx.getTestResult() == QP_TEST_RESULT_PASS)
92 m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Got invalid error");
93 }
94 }
95
expectEitherError(EGLenum expectedA,EGLenum expectedB)96 void ApiCase::expectEitherError (EGLenum expectedA, EGLenum expectedB)
97 {
98 EGLenum err = m_eglTestCtx.getLibrary().getError();
99 if (err != expectedA && err != expectedB)
100 {
101 m_testCtx.getLog() << TestLog::Message << "// ERROR expected: " << eglu::getErrorStr(expectedA) << " or " << eglu::getErrorStr(expectedB) << ", Got: " << eglu::getErrorStr(err) << TestLog::EndMessage;
102 if (m_testCtx.getTestResult() == QP_TEST_RESULT_PASS)
103 m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Got invalid error");
104 }
105 }
106
expectBoolean(EGLBoolean expected,EGLBoolean got)107 void ApiCase::expectBoolean (EGLBoolean expected, EGLBoolean got)
108 {
109 if (expected != got)
110 {
111 m_testCtx.getLog() << TestLog::Message << "// ERROR expected: " << eglu::getBooleanStr(expected) << ", Got: " << eglu::getBooleanStr(got) << TestLog::EndMessage;
112 if (m_testCtx.getTestResult() == QP_TEST_RESULT_PASS)
113 m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Got invalid value");
114 }
115 }
116
expectNoContext(EGLContext got)117 void ApiCase::expectNoContext (EGLContext got)
118 {
119 if (got != EGL_NO_CONTEXT)
120 {
121 m_testCtx.getLog() << TestLog::Message << "// ERROR expected: EGL_NO_CONTEXT" << TestLog::EndMessage;
122 if (m_testCtx.getTestResult() == QP_TEST_RESULT_PASS)
123 m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Got invalid value");
124 eglDestroyContext(getDisplay(), got);
125 }
126 }
127
expectNoSurface(EGLSurface got)128 void ApiCase::expectNoSurface (EGLSurface got)
129 {
130 if (got != EGL_NO_CONTEXT)
131 {
132 m_testCtx.getLog() << TestLog::Message << "// ERROR expected: EGL_NO_SURFACE" << TestLog::EndMessage;
133 if (m_testCtx.getTestResult() == QP_TEST_RESULT_PASS)
134 m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Got invalid value");
135 eglDestroySurface(getDisplay(), got);
136 }
137 }
138
expectNoDisplay(EGLDisplay got)139 void ApiCase::expectNoDisplay (EGLDisplay got)
140 {
141 if (got != EGL_NO_CONTEXT)
142 {
143 m_testCtx.getLog() << TestLog::Message << "// ERROR expected: EGL_NO_DISPLAY" << TestLog::EndMessage;
144 if (m_testCtx.getTestResult() == QP_TEST_RESULT_PASS)
145 m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Got invalid value");
146 }
147 }
148
expectNull(const void * got)149 void ApiCase::expectNull (const void* got)
150 {
151 if (got != EGL_NO_CONTEXT)
152 {
153 m_testCtx.getLog() << TestLog::Message << "// ERROR expected: NULL" << TestLog::EndMessage;
154 if (m_testCtx.getTestResult() == QP_TEST_RESULT_PASS)
155 m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Got invalid value");
156 }
157 }
158
getConfig(EGLConfig * config,const eglu::FilterList & filters)159 bool ApiCase::getConfig (EGLConfig* config, const eglu::FilterList& filters)
160 {
161 try
162 {
163 *config = eglu::chooseSingleConfig(m_eglTestCtx.getLibrary(), m_display, filters);
164 return true;
165 }
166 catch (const tcu::NotSupportedError&)
167 {
168 return false;
169 }
170 }
171
172 } // egl
173 } // deqp
174