• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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 Choose config tests.
22  *//*--------------------------------------------------------------------*/
23 
24 #include "teglChooseConfigTests.hpp"
25 #include "teglChooseConfigReference.hpp"
26 #include "tcuTestLog.hpp"
27 #include "egluStrUtil.hpp"
28 #include "deRandom.hpp"
29 #include "deStringUtil.hpp"
30 
31 #include <vector>
32 #include <algorithm>
33 #include <string>
34 #include <set>
35 #include <map>
36 
37 using std::set;
38 using std::vector;
39 using std::pair;
40 using std::string;
41 using tcu::TestLog;
42 
43 namespace deqp
44 {
45 namespace egl
46 {
47 
48 using eglu::ConfigInfo;
49 
50 namespace
51 {
52 
configListToString(const tcu::egl::Display & display,const vector<EGLConfig> & configs)53 string configListToString (const tcu::egl::Display& display, const vector<EGLConfig>& configs)
54 {
55 	string str = "";
56 	for (vector<EGLConfig>::const_iterator cfgIter = configs.begin(); cfgIter != configs.end(); cfgIter++)
57 	{
58 		EGLConfig	config		= *cfgIter;
59 		EGLint		configId	= display.getConfigAttrib(config, EGL_CONFIG_ID);
60 
61 		if (str.length() != 0)
62 			str += " ";
63 
64 		str += de::toString(configId);
65 	}
66 	return str;
67 }
68 
logConfigAttrib(TestLog & log,EGLenum attrib,EGLint value)69 void logConfigAttrib (TestLog& log, EGLenum attrib, EGLint value)
70 {
71 	const std::string	attribStr	= eglu::getConfigAttribName(attrib);
72 
73 	if (value == EGL_DONT_CARE)
74 	{
75 		log << TestLog::Message << "  " << attribStr << ": EGL_DONT_CARE" << TestLog::EndMessage;
76 		return;
77 	}
78 
79 	log << TestLog::Message << "  " << attribStr << ": " << eglu::getConfigAttribValueStr(attrib, value) << TestLog::EndMessage;
80 }
81 
82 } // anonymous
83 
84 class ChooseConfigCase : public TestCase
85 {
86 public:
ChooseConfigCase(EglTestContext & eglTestCtx,const char * name,const char * description,bool checkOrder,const EGLint * attributes)87 	ChooseConfigCase (EglTestContext& eglTestCtx, const char* name, const char* description, bool checkOrder, const EGLint* attributes)
88 		: TestCase		(eglTestCtx, name, description)
89 		, m_checkOrder	(checkOrder)
90 	{
91 		// Parse attributes
92 		while (attributes[0] != EGL_NONE)
93 		{
94 			m_attributes.push_back(std::make_pair((EGLenum)attributes[0], (EGLint)attributes[1]));
95 			attributes += 2;
96 		}
97 	}
98 
ChooseConfigCase(EglTestContext & eglTestCtx,const char * name,const char * description,bool checkOrder,const std::vector<std::pair<EGLenum,EGLint>> & attributes)99 	ChooseConfigCase (EglTestContext& eglTestCtx, const char* name, const char* description, bool checkOrder, const std::vector<std::pair<EGLenum, EGLint> >& attributes)
100 		: TestCase		(eglTestCtx, name, description)
101 		, m_checkOrder	(checkOrder)
102 		, m_attributes	(attributes)
103 	{
104 	}
105 
iterate(void)106 	IterateResult iterate (void)
107 	{
108 		m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass");
109 
110 		executeTest(m_attributes, m_checkOrder);
111 		return STOP;
112 	}
113 protected:
ChooseConfigCase(EglTestContext & eglTestCtx,const char * name,const char * description,bool checkOrder)114 	ChooseConfigCase (EglTestContext& eglTestCtx, const char* name, const char* description, bool checkOrder)
115 		: TestCase		(eglTestCtx, name, description)
116 		, m_checkOrder	(checkOrder)
117 	{
118 	}
119 
executeTest(const std::vector<std::pair<EGLenum,EGLint>> & attributes,bool checkOrder)120 	void executeTest (const std::vector<std::pair<EGLenum, EGLint> >& attributes, bool checkOrder)
121 	{
122 		TestLog&					log		= m_testCtx.getLog();
123 		const tcu::egl::Display&	display	= m_eglTestCtx.getDisplay();
124 
125 		// Build attributes for EGL
126 		vector<EGLint> attribList;
127 		for (vector<pair<EGLenum, EGLint> >::const_iterator i = attributes.begin(); i != attributes.end(); i++)
128 		{
129 			attribList.push_back(i->first);
130 			attribList.push_back(i->second);
131 		}
132 		attribList.push_back(EGL_NONE);
133 
134 		// Print attribList to log
135 		log << TestLog::Message << "Attributes:" << TestLog::EndMessage;
136 		for (vector<pair<EGLenum, EGLint> >::const_iterator i = attributes.begin(); i != attributes.end(); i++)
137 			logConfigAttrib(log, i->first, i->second);
138 
139 		std::vector<EGLConfig>	resultConfigs;
140 		std::vector<EGLConfig>	referenceConfigs;
141 
142 		// Query from EGL implementation
143 		{
144 			EGLint numConfigs = 0;
145 			TCU_CHECK_EGL_CALL(eglChooseConfig(display.getEGLDisplay(), &attribList[0], DE_NULL, 0, &numConfigs));
146 			resultConfigs.resize(numConfigs);
147 
148 			if (numConfigs > 0)
149 				TCU_CHECK_EGL_CALL(eglChooseConfig(display.getEGLDisplay(), &attribList[0], &resultConfigs[0], (EGLint)resultConfigs.size(), &numConfigs));
150 		}
151 
152 		// Build reference
153 		chooseConfigReference(display, referenceConfigs, attributes);
154 
155 		log << TestLog::Message << "Expected:\n  " << configListToString(display, referenceConfigs) << TestLog::EndMessage;
156 		log << TestLog::Message << "Got:\n  " << configListToString(display, resultConfigs) << TestLog::EndMessage;
157 
158 		bool isSetMatch		= (set<EGLConfig>(resultConfigs.begin(), resultConfigs.end()) == set<EGLConfig>(referenceConfigs.begin(), referenceConfigs.end()));
159 		bool isExactMatch	= (resultConfigs == referenceConfigs);
160 		bool isMatch		= isSetMatch && (checkOrder ? isExactMatch : true);
161 
162 		if (isMatch)
163 			log << TestLog::Message << "Pass" << TestLog::EndMessage;
164 		else if (!isSetMatch)
165 			log << TestLog::Message << "Fail, configs don't match" << TestLog::EndMessage;
166 		else if (!isExactMatch)
167 			log << TestLog::Message << "Fail, got correct configs but in invalid order" << TestLog::EndMessage;
168 
169 		if (!isMatch)
170 			m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Fail");
171 	}
172 
fillDontCare(std::vector<std::pair<EGLenum,EGLint>> & attributes)173 	void fillDontCare (std::vector<std::pair<EGLenum, EGLint> >& attributes)
174 	{
175 		static const EGLenum dontCareAttributes[] =
176 		{
177 			EGL_TRANSPARENT_TYPE,
178 			EGL_COLOR_BUFFER_TYPE,
179 			EGL_RENDERABLE_TYPE,
180 			EGL_SURFACE_TYPE
181 		};
182 
183 		// Fill appropriate unused attributes with EGL_DONT_CARE
184 		for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(dontCareAttributes); ndx++)
185 		{
186 			bool found = false;
187 			for (size_t findNdx = 0; findNdx < attributes.size(); findNdx++)
188 				if (attributes[findNdx].first == dontCareAttributes[ndx]) found = true;
189 
190 			if (!found) attributes.push_back(std::make_pair(dontCareAttributes[ndx], EGL_DONT_CARE));
191 		}
192 	}
193 
194 	bool							m_checkOrder;
195 	vector<pair<EGLenum, EGLint> >	m_attributes;
196 };
197 
198 class ChooseConfigSimpleCase : public ChooseConfigCase
199 {
200 protected:
getValue(EGLenum name)201 	EGLint getValue (EGLenum name)
202 	{
203 		static const struct
204 		{
205 			EGLenum		name;
206 			EGLint		value;
207 		} attributes[] = {
208 			{ EGL_BUFFER_SIZE,				0					},
209 			{ EGL_RED_SIZE,					0					},
210 			{ EGL_GREEN_SIZE,				0					},
211 			{ EGL_BLUE_SIZE,				0					},
212 			{ EGL_LUMINANCE_SIZE,			0					},
213 			{ EGL_ALPHA_SIZE,				0					},
214 			{ EGL_ALPHA_MASK_SIZE,			0					},
215 			{ EGL_BIND_TO_TEXTURE_RGB,		EGL_DONT_CARE		},
216 			{ EGL_BIND_TO_TEXTURE_RGBA,		EGL_DONT_CARE		},
217 			{ EGL_COLOR_BUFFER_TYPE,		EGL_DONT_CARE		},
218 			{ EGL_CONFIG_CAVEAT,			EGL_DONT_CARE		},
219 			//{ EGL_CONFIG_ID,				EGL_DONT_CARE		},
220 			{ EGL_DEPTH_SIZE,				0					},
221 			{ EGL_LEVEL,					0					},
222 			{ EGL_MAX_SWAP_INTERVAL,		EGL_DONT_CARE		},
223 			{ EGL_MIN_SWAP_INTERVAL,		EGL_DONT_CARE		},
224 			{ EGL_NATIVE_RENDERABLE,		EGL_DONT_CARE		},
225 			{ EGL_NATIVE_VISUAL_TYPE,		EGL_DONT_CARE		},
226 			{ EGL_SAMPLE_BUFFERS,			0					},
227 			{ EGL_SAMPLES,					0					},
228 			{ EGL_STENCIL_SIZE,				0					},
229 			{ EGL_TRANSPARENT_TYPE,			EGL_TRANSPARENT_RGB	},
230 			{ EGL_TRANSPARENT_RED_VALUE,	0					},
231 			{ EGL_TRANSPARENT_GREEN_VALUE,	0					},
232 			{ EGL_TRANSPARENT_BLUE_VALUE,	0					},
233 			{ EGL_CONFORMANT,				EGL_OPENGL_ES_BIT	},
234 			{ EGL_RENDERABLE_TYPE,			EGL_OPENGL_ES_BIT	},
235 			{ EGL_SURFACE_TYPE,				EGL_WINDOW_BIT		}
236 			//{ EGL_CONFORMANT,				EGL_OPENGL_BIT | EGL_OPENGL_ES_BIT | EGL_OPENGL_ES2_BIT | EGL_OPENVG_BIT	},
237 			//{ EGL_RENDERABLE_TYPE,			EGL_OPENGL_BIT | EGL_OPENGL_ES_BIT | EGL_OPENGL_ES2_BIT | EGL_OPENVG_BIT	},
238 			//{ EGL_SURFACE_TYPE,				EGL_WINDOW_BIT
239 			//								| EGL_PIXMAP_BIT
240 			//								| EGL_PBUFFER_BIT
241 			//								| EGL_MULTISAMPLE_RESOLVE_BOX_BIT
242 			//								| EGL_VG_ALPHA_FORMAT_PRE_BIT
243 			//								| EGL_SWAP_BEHAVIOR_PRESERVED_BIT
244 			//								| EGL_VG_COLORSPACE_LINEAR_BIT
245 			//								}
246 		};
247 
248 		if (name == EGL_CONFIG_ID)
249 		{
250 			de::Random rnd(0);
251 			return m_eglTestCtx.getConfigs()[rnd.getInt(0, (int)(m_eglTestCtx.getConfigs().size()-1))].configId;
252 		}
253 		else
254 		{
255 			for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(attributes); ndx++)
256 			{
257 				if (attributes[ndx].name == name) return attributes[ndx].value;
258 			}
259 		}
260 
261 		DE_ASSERT(DE_FALSE);
262 		return EGL_NONE;
263 	}
264 public:
ChooseConfigSimpleCase(EglTestContext & eglTestCtx,const char * name,const char * description,EGLenum attribute,bool checkOrder)265 	ChooseConfigSimpleCase (EglTestContext& eglTestCtx, const char* name, const char* description, EGLenum attribute, bool checkOrder)
266 		: ChooseConfigCase(eglTestCtx, name, description, checkOrder)
267 		, m_attribute(attribute)
268 	{
269 	}
270 
init(void)271 	void init (void)
272 	{
273 	}
274 
iterate(void)275 	TestCase::IterateResult iterate (void)
276 	{
277 		m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass");
278 
279 		std::vector<std::pair<EGLenum, EGLint> > attributes;
280 		attributes.push_back(std::pair<EGLenum, EGLint>(m_attribute, getValue(m_attribute)));
281 
282 		fillDontCare(attributes);
283 		executeTest(attributes, m_checkOrder);
284 
285 		return STOP;
286 	}
287 private:
288 	EGLenum	m_attribute;
289 };
290 
291 class ChooseConfigRandomCase : public ChooseConfigCase
292 {
293 public:
ChooseConfigRandomCase(EglTestContext & eglTestCtx,const char * name,const char * description,const set<EGLenum> & attribSet)294 	ChooseConfigRandomCase (EglTestContext& eglTestCtx, const char* name, const char* description, const set<EGLenum>& attribSet)
295 		: ChooseConfigCase	(eglTestCtx, name, description, true)
296 		, m_attribSet		(attribSet)
297 		, m_numIters		(10)
298 		, m_iterNdx			(0)
299 	{
300 	}
301 
init(void)302 	void init (void)
303 	{
304 		m_iterNdx = 0;
305 		m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass");
306 	}
307 
iterate(void)308 	TestCase::IterateResult iterate (void)
309 	{
310 		m_testCtx.getLog() << TestLog::Message << "Iteration :" << m_iterNdx << TestLog::EndMessage;
311 		m_iterNdx += 1;
312 
313 		// Build random list of attributes
314 		de::Random									rnd(m_iterNdx);
315 		const int									numAttribs	= rnd.getInt(0, (int)m_attribSet.size()*2);
316 
317 		std::vector<std::pair<EGLenum, EGLint> >	attributes	= genRandomAttributes(m_attribSet, numAttribs, rnd);
318 
319 		fillDontCare(attributes);
320 		executeTest(attributes, m_checkOrder);
321 
322 		return m_iterNdx < m_numIters ? CONTINUE : STOP;
323 	}
324 
getInt(de::Random & rnd)325 	template <int MinVal, int MaxVal> static EGLint getInt (de::Random& rnd)
326 	{
327 		return rnd.getInt(MinVal, MaxVal);
328 	}
329 
getBool(de::Random & rnd)330 	static EGLint getBool (de::Random& rnd)
331 	{
332 		return rnd.getBool() ? EGL_TRUE : EGL_FALSE;
333 	}
334 
getBufferType(de::Random & rnd)335 	static EGLint getBufferType (de::Random& rnd)
336 	{
337 		static const EGLint types[] = { EGL_RGB_BUFFER, EGL_LUMINANCE_BUFFER };
338 		return rnd.choose<EGLint>(types, types+DE_LENGTH_OF_ARRAY(types));
339 	}
340 
getConfigCaveat(de::Random & rnd)341 	static EGLint getConfigCaveat (de::Random& rnd)
342 	{
343 		static const EGLint caveats[] = { EGL_SLOW_CONFIG, EGL_NON_CONFORMANT_CONFIG };
344 		return rnd.choose<EGLint>(caveats, caveats+DE_LENGTH_OF_ARRAY(caveats));
345 	}
346 
getApiBits(de::Random & rnd)347 	static EGLint getApiBits (de::Random& rnd)
348 	{
349 		EGLint api = 0;
350 		api |= rnd.getBool() ? EGL_OPENGL_BIT		: 0;
351 		api |= rnd.getBool() ? EGL_OPENGL_ES_BIT	: 0;
352 		api |= rnd.getBool() ? EGL_OPENGL_ES2_BIT	: 0;
353 		api |= rnd.getBool() ? EGL_OPENVG_BIT		: 0;
354 		return api;
355 	}
356 
getSurfaceType(de::Random & rnd)357 	static EGLint getSurfaceType (de::Random& rnd)
358 	{
359 		EGLint bits = 0;
360 		bits |= rnd.getBool() ? EGL_WINDOW_BIT	: 0;
361 		bits |= rnd.getBool() ? EGL_PIXMAP_BIT	: 0;
362 		bits |= rnd.getBool() ? EGL_PBUFFER_BIT	: 0;
363 		return bits;
364 	}
365 
366 	struct AttribSpec
367 	{
368 		EGLenum			attribute;
369 		EGLint			(*getValue)(de::Random& rnd);
370 	};
371 
genRandomAttributes(const std::set<EGLenum> & attribSet,int numAttribs,de::Random & rnd)372 	std::vector<std::pair<EGLenum, EGLint> > genRandomAttributes (const std::set<EGLenum>& attribSet, int numAttribs, de::Random& rnd)
373 	{
374 		static const struct AttribSpec attributes[] =
375 		{
376 			{ EGL_BUFFER_SIZE,				ChooseConfigRandomCase::getInt<0, 32>,		},
377 			{ EGL_RED_SIZE,					ChooseConfigRandomCase::getInt<0, 8>,		},
378 			{ EGL_GREEN_SIZE,				ChooseConfigRandomCase::getInt<0, 8>,		},
379 			{ EGL_BLUE_SIZE,				ChooseConfigRandomCase::getInt<0, 8>,		},
380 			{ EGL_LUMINANCE_SIZE,			ChooseConfigRandomCase::getInt<0, 1>,		},
381 			{ EGL_ALPHA_SIZE,				ChooseConfigRandomCase::getInt<0, 8>,		},
382 			{ EGL_ALPHA_MASK_SIZE,			ChooseConfigRandomCase::getInt<0, 1>,		},
383 			{ EGL_BIND_TO_TEXTURE_RGB,		ChooseConfigRandomCase::getBool,			},
384 			{ EGL_BIND_TO_TEXTURE_RGBA,		ChooseConfigRandomCase::getBool,			},
385 			{ EGL_COLOR_BUFFER_TYPE,		ChooseConfigRandomCase::getBufferType,		},
386 			{ EGL_CONFIG_CAVEAT,			ChooseConfigRandomCase::getConfigCaveat,	},
387 //			{ EGL_CONFIG_ID,				0/*special*/,		},
388 			{ EGL_CONFORMANT,				ChooseConfigRandomCase::getApiBits,			},
389 			{ EGL_DEPTH_SIZE,				ChooseConfigRandomCase::getInt<0, 32>,		},
390 			{ EGL_LEVEL,					ChooseConfigRandomCase::getInt<0, 1>,		},
391 //			{ EGL_MATCH_NATIVE_PIXMAP,		EGL_NONE,			},
392 			{ EGL_MAX_SWAP_INTERVAL,		ChooseConfigRandomCase::getInt<0, 2>,		},
393 			{ EGL_MIN_SWAP_INTERVAL,		ChooseConfigRandomCase::getInt<0, 1>,		},
394 			{ EGL_NATIVE_RENDERABLE,		ChooseConfigRandomCase::getBool,			},
395 //			{ EGL_NATIVE_VISUAL_TYPE,		EGL_DONT_CARE,		},
396 			{ EGL_RENDERABLE_TYPE,			ChooseConfigRandomCase::getApiBits,			},
397 			{ EGL_SAMPLE_BUFFERS,			ChooseConfigRandomCase::getInt<0, 1>,		},
398 			{ EGL_SAMPLES,					ChooseConfigRandomCase::getInt<0, 1>,		},
399 			{ EGL_STENCIL_SIZE,				ChooseConfigRandomCase::getInt<0, 1>,		},
400 			{ EGL_SURFACE_TYPE,				ChooseConfigRandomCase::getSurfaceType,		},
401 //			{ EGL_TRANSPARENT_TYPE,			EGL_TRANSPARENT_RGB,},
402 //			{ EGL_TRANSPARENT_RED_VALUE,	ChooseConfigRandomCase::getInt<0, 255>,		},
403 //			{ EGL_TRANSPARENT_GREEN_VALUE,	ChooseConfigRandomCase::getInt<0, 255>,		},
404 //			{ EGL_TRANSPARENT_BLUE_VALUE,	ChooseConfigRandomCase::getInt<0, 255>,		}
405 		};
406 
407 		std::vector<std::pair<EGLenum, EGLint> > out;
408 
409 		// Build list to select from
410 		std::vector<AttribSpec> candidates;
411 		for (int ndx = 0; ndx < (int)DE_LENGTH_OF_ARRAY(attributes); ndx++)
412 		{
413 			if (attribSet.find(attributes[ndx].attribute) != attribSet.end())
414 				candidates.push_back(attributes[ndx]);
415 		}
416 
417 		for (int attribNdx = 0; attribNdx < numAttribs; attribNdx++)
418 		{
419 			AttribSpec spec = rnd.choose<AttribSpec>(candidates.begin(), candidates.end());
420 			out.push_back(std::make_pair(spec.attribute, spec.getValue(rnd)));
421 		}
422 
423 		return out;
424 	}
425 private:
426 	std::set<EGLenum>	m_attribSet;
427 	int					m_numIters;
428 	int					m_iterNdx;
429 };
430 
ChooseConfigTests(EglTestContext & eglTestCtx)431 ChooseConfigTests::ChooseConfigTests (EglTestContext& eglTestCtx)
432 	: TestCaseGroup(eglTestCtx, "choose_config", "eglChooseConfig() tests")
433 {
434 }
435 
~ChooseConfigTests(void)436 ChooseConfigTests::~ChooseConfigTests (void)
437 {
438 }
439 
440 namespace
441 {
442 
443 template <typename T, size_t N>
toSet(const T (& arr)[N])444 std::set<T> toSet (const T (&arr)[N])
445 {
446 	std::set<T> set;
447 	for (size_t i = 0; i < N; i++)
448 		set.insert(arr[i]);
449 	return set;
450 }
451 
452 } // anonymous
453 
init(void)454 void ChooseConfigTests::init (void)
455 {
456 	// Single attributes
457 	{
458 		static const struct
459 		{
460 			EGLenum			attribute;
461 			const char*		testName;
462 		} attributes[] =
463 		{
464 			{ EGL_BUFFER_SIZE,				"buffer_size"				},
465 			{ EGL_RED_SIZE,					"red_size"					},
466 			{ EGL_GREEN_SIZE,				"green_size"				},
467 			{ EGL_BLUE_SIZE,				"blue_size"					},
468 			{ EGL_LUMINANCE_SIZE,			"luminance_size"			},
469 			{ EGL_ALPHA_SIZE,				"alpha_size"				},
470 			{ EGL_ALPHA_MASK_SIZE,			"alpha_mask_size"			},
471 			{ EGL_BIND_TO_TEXTURE_RGB,		"bind_to_texture_rgb"		},
472 			{ EGL_BIND_TO_TEXTURE_RGBA,		"bind_to_texture_rgba"		},
473 			{ EGL_COLOR_BUFFER_TYPE,		"color_buffer_type"			},
474 			{ EGL_CONFIG_CAVEAT,			"config_caveat"				},
475 			{ EGL_CONFIG_ID,				"config_id"					},
476 			{ EGL_CONFORMANT,				"conformant"				},
477 			{ EGL_DEPTH_SIZE,				"depth_size"				},
478 			{ EGL_LEVEL,					"level"						},
479 			{ EGL_MAX_SWAP_INTERVAL,		"max_swap_interval"			},
480 			{ EGL_MIN_SWAP_INTERVAL,		"min_swap_interval"			},
481 			{ EGL_NATIVE_RENDERABLE,		"native_renderable"			},
482 			{ EGL_NATIVE_VISUAL_TYPE,		"native_visual_type"		},
483 			{ EGL_RENDERABLE_TYPE,			"renderable_type"			},
484 			{ EGL_SAMPLE_BUFFERS,			"sample_buffers"			},
485 			{ EGL_SAMPLES,					"samples"					},
486 			{ EGL_STENCIL_SIZE,				"stencil_size"				},
487 			{ EGL_SURFACE_TYPE,				"surface_type"				},
488 			{ EGL_TRANSPARENT_TYPE,			"transparent_type"			},
489 			{ EGL_TRANSPARENT_RED_VALUE,	"transparent_red_value"		},
490 			{ EGL_TRANSPARENT_GREEN_VALUE,	"transparent_green_value"	},
491 			{ EGL_TRANSPARENT_BLUE_VALUE,	"transparent_blue_value"	}
492 		};
493 
494 		tcu::TestCaseGroup* simpleGroup = new tcu::TestCaseGroup(m_testCtx, "simple", "Simple tests");
495 		addChild(simpleGroup);
496 
497 		tcu::TestCaseGroup* selectionGroup = new tcu::TestCaseGroup(m_testCtx, "selection_only", "Selection tests, order ignored");
498 		simpleGroup->addChild(selectionGroup);
499 
500 		tcu::TestCaseGroup* sortGroup = new tcu::TestCaseGroup(m_testCtx, "selection_and_sort", "Selection and ordering tests");
501 		simpleGroup->addChild(sortGroup);
502 
503 		for (int ndx = 0; ndx < (int)DE_LENGTH_OF_ARRAY(attributes); ndx++)
504 		{
505 			selectionGroup->addChild(new ChooseConfigSimpleCase(m_eglTestCtx, attributes[ndx].testName, "Simple config selection case", attributes[ndx].attribute, false));
506 			sortGroup->addChild(new ChooseConfigSimpleCase(m_eglTestCtx, attributes[ndx].testName, "Simple config selection and sort case", attributes[ndx].attribute, true));
507 		}
508 	}
509 
510 	// Random
511 	{
512 		tcu::TestCaseGroup* randomGroup = new tcu::TestCaseGroup(m_testCtx, "random", "Random eglChooseConfig() usage");
513 		addChild(randomGroup);
514 
515 		static const EGLenum rgbaSizes[] =
516 		{
517 			EGL_RED_SIZE,
518 			EGL_GREEN_SIZE,
519 			EGL_BLUE_SIZE,
520 			EGL_ALPHA_SIZE
521 		};
522 		randomGroup->addChild(new ChooseConfigRandomCase(m_eglTestCtx, "color_sizes", "Random color size rules", toSet(rgbaSizes)));
523 
524 		static const EGLenum colorDepthStencilSizes[] =
525 		{
526 			EGL_RED_SIZE,
527 			EGL_GREEN_SIZE,
528 			EGL_BLUE_SIZE,
529 			EGL_ALPHA_SIZE,
530 			EGL_DEPTH_SIZE,
531 			EGL_STENCIL_SIZE
532 		};
533 		randomGroup->addChild(new ChooseConfigRandomCase(m_eglTestCtx, "color_depth_stencil_sizes", "Random color, depth and stencil size rules", toSet(colorDepthStencilSizes)));
534 
535 		static const EGLenum bufferSizes[] =
536 		{
537 			EGL_BUFFER_SIZE,
538 			EGL_LUMINANCE_SIZE,
539 			EGL_ALPHA_MASK_SIZE,
540 			EGL_DEPTH_SIZE,
541 			EGL_STENCIL_SIZE
542 		};
543 		randomGroup->addChild(new ChooseConfigRandomCase(m_eglTestCtx, "buffer_sizes", "Various buffer size rules", toSet(bufferSizes)));
544 
545 		static const EGLenum surfaceType[] =
546 		{
547 			EGL_NATIVE_RENDERABLE,
548 			EGL_SURFACE_TYPE
549 		};
550 		randomGroup->addChild(new ChooseConfigRandomCase(m_eglTestCtx, "surface_type", "Surface type rules", toSet(surfaceType)));
551 
552 		static const EGLenum sampleBuffers[] =
553 		{
554 			EGL_SAMPLE_BUFFERS,
555 			EGL_SAMPLES
556 		};
557 		randomGroup->addChild(new ChooseConfigRandomCase(m_eglTestCtx, "sample_buffers", "Sample buffer rules", toSet(sampleBuffers)));
558 
559 		// \note Not every attribute is supported at the moment
560 		static const EGLenum allAttribs[] =
561 		{
562 			EGL_BUFFER_SIZE,
563 			EGL_RED_SIZE,
564 			EGL_GREEN_SIZE,
565 			EGL_BLUE_SIZE,
566 			EGL_ALPHA_SIZE,
567 			EGL_ALPHA_MASK_SIZE,
568 			EGL_BIND_TO_TEXTURE_RGB,
569 			EGL_BIND_TO_TEXTURE_RGBA,
570 			EGL_COLOR_BUFFER_TYPE,
571 			EGL_CONFIG_CAVEAT,
572 			EGL_CONFIG_ID,
573 			EGL_CONFORMANT,
574 			EGL_DEPTH_SIZE,
575 			EGL_LEVEL,
576 //			EGL_MATCH_NATIVE_PIXMAP,
577 			EGL_MAX_SWAP_INTERVAL,
578 			EGL_MIN_SWAP_INTERVAL,
579 			EGL_NATIVE_RENDERABLE,
580 			EGL_NATIVE_VISUAL_TYPE,
581 			EGL_RENDERABLE_TYPE,
582 			EGL_SAMPLE_BUFFERS,
583 			EGL_SAMPLES,
584 			EGL_STENCIL_SIZE,
585 			EGL_SURFACE_TYPE,
586 			EGL_TRANSPARENT_TYPE,
587 //			EGL_TRANSPARENT_RED_VALUE,
588 //			EGL_TRANSPARENT_GREEN_VALUE,
589 //			EGL_TRANSPARENT_BLUE_VALUE
590 		};
591 		randomGroup->addChild(new ChooseConfigRandomCase(m_eglTestCtx, "all", "All attributes", toSet(allAttribs)));
592 	}
593 }
594 
595 } // egl
596 } // deqp
597