Merge "Check only what's needed and use threshold"
[platform/upstream/VK-GL-CTS.git] / modules / glshared / glsTextureStateQueryTests.cpp
1 /*-------------------------------------------------------------------------
2  * drawElements Quality Program OpenGL (ES) Module
3  * -----------------------------------------------
4  *
5  * Copyright 2015 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 Texture State Query tests.
22  *//*--------------------------------------------------------------------*/
23
24 #include "glsTextureStateQueryTests.hpp"
25 #include "gluStrUtil.hpp"
26 #include "gluObjectWrapper.hpp"
27 #include "gluCallLogWrapper.hpp"
28 #include "gluContextInfo.hpp"
29 #include "gluTextureUtil.hpp"
30 #include "glwEnums.hpp"
31 #include "deUniquePtr.hpp"
32 #include "deRandom.hpp"
33 #include "deStringUtil.hpp"
34
35 namespace deqp
36 {
37 namespace gls
38 {
39 namespace TextureStateQueryTests
40 {
41 namespace
42 {
43
44 using namespace glw;
45 using namespace gls::StateQueryUtil;
46
47 static glw::GLenum mapTesterToPname (TesterType tester)
48 {
49
50 #define CASE_ALL_SETTERS(X) case X: case X ## _SET_PURE_INT: case X ## _SET_PURE_UINT
51
52         switch (tester)
53         {
54                 CASE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_R):                             return GL_TEXTURE_SWIZZLE_R;
55                 CASE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_G):                             return GL_TEXTURE_SWIZZLE_G;
56                 CASE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_B):                             return GL_TEXTURE_SWIZZLE_B;
57                 CASE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_A):                             return GL_TEXTURE_SWIZZLE_A;
58
59                 CASE_ALL_SETTERS(TESTER_TEXTURE_WRAP_S):
60                 case TESTER_TEXTURE_WRAP_S_CLAMP_TO_BORDER:                             return GL_TEXTURE_WRAP_S;
61
62                 CASE_ALL_SETTERS(TESTER_TEXTURE_WRAP_T):
63                 case TESTER_TEXTURE_WRAP_T_CLAMP_TO_BORDER:                             return GL_TEXTURE_WRAP_T;
64
65                 CASE_ALL_SETTERS(TESTER_TEXTURE_WRAP_R):
66                 case TESTER_TEXTURE_WRAP_R_CLAMP_TO_BORDER:                             return GL_TEXTURE_WRAP_R;
67
68                 CASE_ALL_SETTERS(TESTER_TEXTURE_MAG_FILTER):                    return GL_TEXTURE_MAG_FILTER;
69                 CASE_ALL_SETTERS(TESTER_TEXTURE_MIN_FILTER):                    return GL_TEXTURE_MIN_FILTER;
70                 CASE_ALL_SETTERS(TESTER_TEXTURE_MIN_LOD):                               return GL_TEXTURE_MIN_LOD;
71                 CASE_ALL_SETTERS(TESTER_TEXTURE_MAX_LOD):                               return GL_TEXTURE_MAX_LOD;
72                 CASE_ALL_SETTERS(TESTER_TEXTURE_BASE_LEVEL):                    return GL_TEXTURE_BASE_LEVEL;
73                 CASE_ALL_SETTERS(TESTER_TEXTURE_MAX_LEVEL):                             return GL_TEXTURE_MAX_LEVEL;
74                 CASE_ALL_SETTERS(TESTER_TEXTURE_COMPARE_MODE):                  return GL_TEXTURE_COMPARE_MODE;
75                 CASE_ALL_SETTERS(TESTER_TEXTURE_COMPARE_FUNC):                  return GL_TEXTURE_COMPARE_FUNC;
76                 case TESTER_TEXTURE_IMMUTABLE_LEVELS:                                   return GL_TEXTURE_IMMUTABLE_LEVELS;
77                 case TESTER_TEXTURE_IMMUTABLE_FORMAT:                                   return GL_TEXTURE_IMMUTABLE_FORMAT;
78                 CASE_ALL_SETTERS(TESTER_DEPTH_STENCIL_TEXTURE_MODE):    return GL_DEPTH_STENCIL_TEXTURE_MODE;
79                 CASE_ALL_SETTERS(TESTER_TEXTURE_SRGB_DECODE_EXT):               return GL_TEXTURE_SRGB_DECODE_EXT;
80                 case TESTER_TEXTURE_BORDER_COLOR:                                               return GL_TEXTURE_BORDER_COLOR;
81
82                 default:
83                         DE_ASSERT(false);
84                         return -1;
85         }
86
87 #undef CASE_PURE_SETTERS
88 }
89
90 static bool querySupportsSigned (QueryType type)
91 {
92         return  type != QUERY_TEXTURE_PARAM_PURE_UNSIGNED_INTEGER &&
93                         type != QUERY_SAMPLER_PARAM_PURE_UNSIGNED_INTEGER;
94 }
95
96 static bool isPureIntTester (TesterType tester)
97 {
98 #define HANDLE_ALL_SETTERS(X) \
99                 case X: \
100                 case X ## _SET_PURE_UINT: return false; \
101                 case X ## _SET_PURE_INT: return true;
102
103         switch (tester)
104         {
105                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_R)
106                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_G)
107                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_B)
108                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_A)
109                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_WRAP_S)
110                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_WRAP_T)
111                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_WRAP_R)
112                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_MAG_FILTER)
113                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_MIN_FILTER)
114                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_MIN_LOD)
115                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_MAX_LOD)
116                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_BASE_LEVEL)
117                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_MAX_LEVEL)
118                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_COMPARE_MODE)
119                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_COMPARE_FUNC)
120                 HANDLE_ALL_SETTERS(TESTER_DEPTH_STENCIL_TEXTURE_MODE)
121                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_SRGB_DECODE_EXT)
122
123                 case TESTER_TEXTURE_IMMUTABLE_LEVELS:
124                 case TESTER_TEXTURE_IMMUTABLE_FORMAT:
125                 case TESTER_TEXTURE_WRAP_S_CLAMP_TO_BORDER:
126                 case TESTER_TEXTURE_WRAP_T_CLAMP_TO_BORDER:
127                 case TESTER_TEXTURE_WRAP_R_CLAMP_TO_BORDER:
128                 case TESTER_TEXTURE_BORDER_COLOR:
129                         return false;
130
131                 default:
132                         DE_ASSERT(false);
133                         return false;
134         }
135
136 #undef HANDLE_ALL_SETTERS
137 }
138
139 static bool isPureUintTester (TesterType tester)
140 {
141 #define HANDLE_ALL_SETTERS(X) \
142                 case X: \
143                 case X ## _SET_PURE_INT: return false; \
144                 case X ## _SET_PURE_UINT: return true;
145
146         switch (tester)
147         {
148                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_R)
149                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_G)
150                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_B)
151                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_A)
152                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_WRAP_S)
153                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_WRAP_T)
154                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_WRAP_R)
155                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_MAG_FILTER)
156                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_MIN_FILTER)
157                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_MIN_LOD)
158                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_MAX_LOD)
159                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_BASE_LEVEL)
160                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_MAX_LEVEL)
161                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_COMPARE_MODE)
162                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_COMPARE_FUNC)
163                 HANDLE_ALL_SETTERS(TESTER_DEPTH_STENCIL_TEXTURE_MODE)
164                 HANDLE_ALL_SETTERS(TESTER_TEXTURE_SRGB_DECODE_EXT)
165
166                 case TESTER_TEXTURE_IMMUTABLE_LEVELS:
167                 case TESTER_TEXTURE_IMMUTABLE_FORMAT:
168                 case TESTER_TEXTURE_WRAP_S_CLAMP_TO_BORDER:
169                 case TESTER_TEXTURE_WRAP_T_CLAMP_TO_BORDER:
170                 case TESTER_TEXTURE_WRAP_R_CLAMP_TO_BORDER:
171                 case TESTER_TEXTURE_BORDER_COLOR:
172                         return false;
173
174                 default:
175                         DE_ASSERT(false);
176                         return false;
177         }
178
179 #undef HANDLE_ALL_SETTERS
180 }
181
182 class RequiredExtensions
183 {
184 public:
185                                                                 RequiredExtensions      (void)                                                                  { }
186         explicit                                        RequiredExtensions      (const char* ext)                                               { add(ext);                             }
187                                                                 RequiredExtensions      (const char* extA, const char* extB)    { add(extA); add(extB); }
188
189         void                                            add                                     (const char* ext);
190         void                                            add                                     (const RequiredExtensions& other);
191         void                                            check                           (const glu::ContextInfo&) const;
192
193 private:
194         std::vector<const char*>        m_extensions;
195 };
196
197 void RequiredExtensions::add (const char* ext)
198 {
199         for (int ndx = 0; ndx < (int)m_extensions.size(); ++ndx)
200                 if (deStringEqual(m_extensions[ndx], ext) == DE_TRUE)
201                         return;
202         m_extensions.push_back(ext);
203 }
204
205 void RequiredExtensions::add (const RequiredExtensions& other)
206 {
207         for (int ndx = 0; ndx < (int)other.m_extensions.size(); ++ndx)
208                 add(other.m_extensions[ndx]);
209 }
210
211 void RequiredExtensions::check (const glu::ContextInfo& ctxInfo) const
212 {
213         std::vector<const char*> failedExtensions;
214
215         for (int ndx = 0; ndx < (int)m_extensions.size(); ++ndx)
216                 if (!ctxInfo.isExtensionSupported(m_extensions[ndx]))
217                         failedExtensions.push_back(m_extensions[ndx]);
218
219         if (!failedExtensions.empty())
220         {
221                 std::ostringstream buf;
222                 buf << "Test requires extension: ";
223
224                 for (int ndx = 0; ndx < (int)failedExtensions.size(); ++ndx)
225                 {
226                         if (ndx)
227                                 buf << ", ";
228                         buf << failedExtensions[ndx];
229                 }
230
231                 throw tcu::NotSupportedError(buf.str());
232         }
233 }
234
235 namespace es30
236 {
237
238 static bool isCoreTextureTarget (glw::GLenum target)
239 {
240         return  target == GL_TEXTURE_2D                 ||
241                         target == GL_TEXTURE_3D                 ||
242                         target == GL_TEXTURE_2D_ARRAY   ||
243                         target == GL_TEXTURE_CUBE_MAP;
244 }
245
246 static RequiredExtensions getTextureTargetExtension (glw::GLenum target)
247 {
248         DE_UNREF(target);
249         DE_ASSERT(false);
250         return RequiredExtensions();
251 }
252
253 static bool isCoreTextureParam (glw::GLenum pname)
254 {
255         return  pname == GL_TEXTURE_BASE_LEVEL                  ||
256                         pname == GL_TEXTURE_COMPARE_MODE                ||
257                         pname == GL_TEXTURE_COMPARE_FUNC                ||
258                         pname == GL_TEXTURE_MAG_FILTER                  ||
259                         pname == GL_TEXTURE_MAX_LEVEL                   ||
260                         pname == GL_TEXTURE_MAX_LOD                             ||
261                         pname == GL_TEXTURE_MIN_FILTER                  ||
262                         pname == GL_TEXTURE_MIN_LOD                             ||
263                         pname == GL_TEXTURE_SWIZZLE_R                   ||
264                         pname == GL_TEXTURE_SWIZZLE_G                   ||
265                         pname == GL_TEXTURE_SWIZZLE_B                   ||
266                         pname == GL_TEXTURE_SWIZZLE_A                   ||
267                         pname == GL_TEXTURE_WRAP_S                              ||
268                         pname == GL_TEXTURE_WRAP_T                              ||
269                         pname == GL_TEXTURE_WRAP_R                              ||
270                         pname == GL_TEXTURE_IMMUTABLE_FORMAT    ||
271                         pname == GL_TEXTURE_IMMUTABLE_LEVELS;
272 }
273
274 static RequiredExtensions getTextureParamExtension (glw::GLenum pname)
275 {
276         DE_UNREF(pname);
277         DE_ASSERT(false);
278         return RequiredExtensions();
279 }
280
281 static bool isCoreQuery (QueryType query)
282 {
283         return  query == QUERY_TEXTURE_PARAM_INTEGER            ||
284                         query == QUERY_TEXTURE_PARAM_FLOAT                      ||
285                         query == QUERY_TEXTURE_PARAM_INTEGER_VEC4       ||
286                         query == QUERY_TEXTURE_PARAM_FLOAT_VEC4         ||
287                         query == QUERY_SAMPLER_PARAM_INTEGER            ||
288                         query == QUERY_SAMPLER_PARAM_FLOAT                      ||
289                         query == QUERY_SAMPLER_PARAM_INTEGER_VEC4       ||
290                         query == QUERY_SAMPLER_PARAM_FLOAT_VEC4;
291 }
292
293 static RequiredExtensions getQueryExtension (QueryType query)
294 {
295         DE_UNREF(query);
296         DE_ASSERT(false);
297         return RequiredExtensions();
298 }
299
300 static bool isCoreTester (TesterType tester)
301 {
302         return  tester == TESTER_TEXTURE_SWIZZLE_R                      ||
303                         tester == TESTER_TEXTURE_SWIZZLE_G                      ||
304                         tester == TESTER_TEXTURE_SWIZZLE_B                      ||
305                         tester == TESTER_TEXTURE_SWIZZLE_A                      ||
306                         tester == TESTER_TEXTURE_WRAP_S                         ||
307                         tester == TESTER_TEXTURE_WRAP_T                         ||
308                         tester == TESTER_TEXTURE_WRAP_R                         ||
309                         tester == TESTER_TEXTURE_MAG_FILTER                     ||
310                         tester == TESTER_TEXTURE_MIN_FILTER                     ||
311                         tester == TESTER_TEXTURE_MIN_LOD                        ||
312                         tester == TESTER_TEXTURE_MAX_LOD                        ||
313                         tester == TESTER_TEXTURE_BASE_LEVEL                     ||
314                         tester == TESTER_TEXTURE_MAX_LEVEL                      ||
315                         tester == TESTER_TEXTURE_COMPARE_MODE           ||
316                         tester == TESTER_TEXTURE_COMPARE_FUNC           ||
317                         tester == TESTER_TEXTURE_IMMUTABLE_LEVELS       ||
318                         tester == TESTER_TEXTURE_IMMUTABLE_FORMAT;
319 }
320
321 static RequiredExtensions getTesterExtension (TesterType tester)
322 {
323         DE_UNREF(tester);
324         DE_ASSERT(false);
325         return RequiredExtensions();
326 }
327
328 } // es30
329
330 namespace es31
331 {
332
333 static bool isCoreTextureTarget (glw::GLenum target)
334 {
335         return  es30::isCoreTextureTarget(target) ||
336                         target == GL_TEXTURE_2D_MULTISAMPLE;
337 }
338
339 static RequiredExtensions getTextureTargetExtension (glw::GLenum target)
340 {
341         switch (target)
342         {
343                 case GL_TEXTURE_2D_MULTISAMPLE_ARRAY:   return RequiredExtensions("GL_OES_texture_storage_multisample_2d_array");
344                 case GL_TEXTURE_BUFFER:                                 return RequiredExtensions("GL_EXT_texture_buffer");
345                 case GL_TEXTURE_CUBE_MAP_ARRAY:                 return RequiredExtensions("GL_EXT_texture_cube_map_array");
346                 default:
347                         DE_ASSERT(false);
348                         return RequiredExtensions();
349         }
350 }
351
352 static bool isCoreTextureParam (glw::GLenum pname)
353 {
354         return  es30::isCoreTextureParam(pname) ||
355                         pname == GL_DEPTH_STENCIL_TEXTURE_MODE;
356 }
357
358 static RequiredExtensions getTextureParamExtension (glw::GLenum pname)
359 {
360         switch (pname)
361         {
362                 case GL_TEXTURE_SRGB_DECODE_EXT:        return RequiredExtensions("GL_EXT_texture_sRGB_decode");
363                 case GL_TEXTURE_BORDER_COLOR:           return RequiredExtensions("GL_EXT_texture_border_clamp");
364                 default:
365                         DE_ASSERT(false);
366                         return RequiredExtensions();
367         }
368 }
369
370 static bool isCoreQuery (QueryType query)
371 {
372         return es30::isCoreQuery(query);
373 }
374
375 static RequiredExtensions getQueryExtension (QueryType query)
376 {
377         switch (query)
378         {
379                 case QUERY_TEXTURE_PARAM_PURE_INTEGER:
380                 case QUERY_TEXTURE_PARAM_PURE_UNSIGNED_INTEGER:
381                 case QUERY_TEXTURE_PARAM_PURE_INTEGER_VEC4:
382                 case QUERY_TEXTURE_PARAM_PURE_UNSIGNED_INTEGER_VEC4:
383                 case QUERY_SAMPLER_PARAM_PURE_INTEGER:
384                 case QUERY_SAMPLER_PARAM_PURE_UNSIGNED_INTEGER:
385                 case QUERY_SAMPLER_PARAM_PURE_INTEGER_VEC4:
386                 case QUERY_SAMPLER_PARAM_PURE_UNSIGNED_INTEGER_VEC4:
387                         return RequiredExtensions("GL_EXT_texture_border_clamp");
388
389                 default:
390                         DE_ASSERT(false);
391                         return RequiredExtensions();
392         }
393 }
394
395 static bool isCoreTester (TesterType tester)
396 {
397         return  es30::isCoreTester(tester)                                                      ||
398                         tester == TESTER_DEPTH_STENCIL_TEXTURE_MODE;
399 }
400
401 static RequiredExtensions getTesterExtension (TesterType tester)
402 {
403 #define CASE_PURE_SETTERS(X) case X ## _SET_PURE_INT: case X ## _SET_PURE_UINT
404
405         switch (tester)
406         {
407                 CASE_PURE_SETTERS(TESTER_TEXTURE_SWIZZLE_R):
408                 CASE_PURE_SETTERS(TESTER_TEXTURE_SWIZZLE_G):
409                 CASE_PURE_SETTERS(TESTER_TEXTURE_SWIZZLE_B):
410                 CASE_PURE_SETTERS(TESTER_TEXTURE_SWIZZLE_A):
411                 CASE_PURE_SETTERS(TESTER_TEXTURE_WRAP_S):
412                 CASE_PURE_SETTERS(TESTER_TEXTURE_WRAP_T):
413                 CASE_PURE_SETTERS(TESTER_TEXTURE_WRAP_R):
414                 CASE_PURE_SETTERS(TESTER_TEXTURE_MAG_FILTER):
415                 CASE_PURE_SETTERS(TESTER_TEXTURE_MIN_FILTER):
416                 CASE_PURE_SETTERS(TESTER_TEXTURE_MIN_LOD):
417                 CASE_PURE_SETTERS(TESTER_TEXTURE_MAX_LOD):
418                 CASE_PURE_SETTERS(TESTER_TEXTURE_BASE_LEVEL):
419                 CASE_PURE_SETTERS(TESTER_TEXTURE_MAX_LEVEL):
420                 CASE_PURE_SETTERS(TESTER_TEXTURE_COMPARE_MODE):
421                 CASE_PURE_SETTERS(TESTER_TEXTURE_COMPARE_FUNC):
422                 CASE_PURE_SETTERS(TESTER_DEPTH_STENCIL_TEXTURE_MODE):
423                 case TESTER_TEXTURE_WRAP_S_CLAMP_TO_BORDER:
424                 case TESTER_TEXTURE_WRAP_T_CLAMP_TO_BORDER:
425                 case TESTER_TEXTURE_WRAP_R_CLAMP_TO_BORDER:
426                 case TESTER_TEXTURE_BORDER_COLOR:
427                         return RequiredExtensions("GL_EXT_texture_border_clamp");
428
429                 case TESTER_TEXTURE_SRGB_DECODE_EXT:
430                         return RequiredExtensions("GL_EXT_texture_sRGB_decode");
431
432                 CASE_PURE_SETTERS(TESTER_TEXTURE_SRGB_DECODE_EXT):
433                         return RequiredExtensions("GL_EXT_texture_sRGB_decode", "GL_EXT_texture_border_clamp");
434
435                 default:
436                         DE_ASSERT(false);
437                         return RequiredExtensions();
438         }
439
440 #undef CASE_PURE_SETTERS
441 }
442
443 } // es31
444
445 namespace es32
446 {
447
448 static bool isCoreTextureTarget (glw::GLenum target)
449 {
450         return  es31::isCoreTextureTarget(target)                       ||
451                         target == GL_TEXTURE_2D_MULTISAMPLE_ARRAY       ||
452                         target == GL_TEXTURE_BUFFER                                     ||
453                         target == GL_TEXTURE_CUBE_MAP_ARRAY;
454 }
455
456 static RequiredExtensions getTextureTargetExtension (glw::GLenum target)
457 {
458         DE_UNREF(target);
459         DE_ASSERT(false);
460         return RequiredExtensions();
461 }
462
463 static bool isCoreTextureParam (glw::GLenum pname)
464 {
465         return  es31::isCoreTextureParam(pname)         ||
466                         pname == GL_TEXTURE_BORDER_COLOR;
467 }
468
469 static RequiredExtensions getTextureParamExtension (glw::GLenum pname)
470 {
471         switch (pname)
472         {
473                 case GL_TEXTURE_SRGB_DECODE_EXT:        return RequiredExtensions("GL_EXT_texture_sRGB_decode");
474                 default:
475                         DE_ASSERT(false);
476                         return RequiredExtensions();
477         }
478 }
479
480 static bool isCoreQuery (QueryType query)
481 {
482         return  es31::isCoreQuery(query)                                                                ||
483                         query == QUERY_TEXTURE_PARAM_PURE_INTEGER                               ||
484                         query == QUERY_TEXTURE_PARAM_PURE_INTEGER                               ||
485                         query == QUERY_TEXTURE_PARAM_PURE_UNSIGNED_INTEGER              ||
486                         query == QUERY_TEXTURE_PARAM_PURE_INTEGER_VEC4                  ||
487                         query == QUERY_TEXTURE_PARAM_PURE_UNSIGNED_INTEGER_VEC4 ||
488                         query == QUERY_SAMPLER_PARAM_PURE_INTEGER                               ||
489                         query == QUERY_SAMPLER_PARAM_PURE_UNSIGNED_INTEGER              ||
490                         query == QUERY_SAMPLER_PARAM_PURE_INTEGER_VEC4                  ||
491                         query == QUERY_SAMPLER_PARAM_PURE_UNSIGNED_INTEGER_VEC4;
492 }
493
494 static RequiredExtensions getQueryExtension (QueryType query)
495 {
496         DE_UNREF(query);
497         DE_ASSERT(false);
498         return RequiredExtensions();
499 }
500
501 static bool isCoreTester (TesterType tester)
502 {
503 #define COMPARE_PURE_SETTERS(TESTER, X) ((TESTER) == X ## _SET_PURE_INT) || ((TESTER) == X ## _SET_PURE_UINT)
504
505         return  es31::isCoreTester(tester)                                                                              ||
506                         COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_SWIZZLE_R)                  ||
507                         COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_SWIZZLE_G)                  ||
508                         COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_SWIZZLE_B)                  ||
509                         COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_SWIZZLE_A)                  ||
510                         COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_WRAP_S)                             ||
511                         COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_WRAP_T)                             ||
512                         COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_WRAP_R)                             ||
513                         COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_MAG_FILTER)                 ||
514                         COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_MIN_FILTER)                 ||
515                         COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_MIN_LOD)                    ||
516                         COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_MAX_LOD)                    ||
517                         COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_BASE_LEVEL)                 ||
518                         COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_MAX_LEVEL)                  ||
519                         COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_COMPARE_MODE)               ||
520                         COMPARE_PURE_SETTERS(tester, TESTER_TEXTURE_COMPARE_FUNC)               ||
521                         COMPARE_PURE_SETTERS(tester, TESTER_DEPTH_STENCIL_TEXTURE_MODE) ||
522                         tester == TESTER_TEXTURE_WRAP_S_CLAMP_TO_BORDER                                 ||
523                         tester == TESTER_TEXTURE_WRAP_T_CLAMP_TO_BORDER                                 ||
524                         tester == TESTER_TEXTURE_WRAP_R_CLAMP_TO_BORDER                                 ||
525                         tester == TESTER_TEXTURE_BORDER_COLOR;
526
527 #undef COMPARE_PURE_SETTERS
528 }
529
530 static RequiredExtensions getTesterExtension (TesterType tester)
531 {
532 #define CASE_PURE_SETTERS(X) case X ## _SET_PURE_INT: case X ## _SET_PURE_UINT
533
534         switch (tester)
535         {
536                 CASE_PURE_SETTERS(TESTER_TEXTURE_SRGB_DECODE_EXT):
537                 case TESTER_TEXTURE_SRGB_DECODE_EXT:
538                         return RequiredExtensions("GL_EXT_texture_sRGB_decode");
539
540                 default:
541                         DE_ASSERT(false);
542                         return RequiredExtensions();
543         }
544
545 #undef CASE_PURE_SETTERS
546 }
547
548 } // es32
549
550 static bool isCoreTextureTarget (const glu::ContextType& contextType, glw::GLenum target)
551 {
552         if (contextSupports(contextType, glu::ApiType::es(3,2)))
553                 return es32::isCoreTextureTarget(target);
554         else if (contextSupports(contextType, glu::ApiType::es(3,1)))
555                 return es31::isCoreTextureTarget(target);
556         else if (contextSupports(contextType, glu::ApiType::es(3,0)))
557                 return es30::isCoreTextureTarget(target);
558         else
559         {
560                 DE_ASSERT(false);
561                 return DE_NULL;
562         }
563 }
564
565 static bool isCoreTextureParam (const glu::ContextType& contextType, glw::GLenum pname)
566 {
567         if (contextSupports(contextType, glu::ApiType::es(3,2)))
568                 return es32::isCoreTextureParam(pname);
569         else if (contextSupports(contextType, glu::ApiType::es(3,1)))
570                 return es31::isCoreTextureParam(pname);
571         else if (contextSupports(contextType, glu::ApiType::es(3,0)))
572                 return es30::isCoreTextureParam(pname);
573         else
574         {
575                 DE_ASSERT(false);
576                 return DE_NULL;
577         }
578 }
579
580 static bool isCoreQuery (const glu::ContextType& contextType, QueryType query)
581 {
582         if (contextSupports(contextType, glu::ApiType::es(3,2)))
583                 return es32::isCoreQuery(query);
584         else if (contextSupports(contextType, glu::ApiType::es(3,1)))
585                 return es31::isCoreQuery(query);
586         else if (contextSupports(contextType, glu::ApiType::es(3,0)))
587                 return es30::isCoreQuery(query);
588         else
589         {
590                 DE_ASSERT(false);
591                 return DE_NULL;
592         }
593 }
594
595 static bool isCoreTester (const glu::ContextType& contextType, TesterType tester)
596 {
597         if (contextSupports(contextType, glu::ApiType::es(3,2)))
598                 return es32::isCoreTester(tester);
599         else if (contextSupports(contextType, glu::ApiType::es(3,1)))
600                 return es31::isCoreTester(tester);
601         else if (contextSupports(contextType, glu::ApiType::es(3,0)))
602                 return es30::isCoreTester(tester);
603         else
604         {
605                 DE_ASSERT(false);
606                 return DE_NULL;
607         }
608 }
609
610 static RequiredExtensions getTextureTargetExtension (const glu::ContextType& contextType, glw::GLenum target)
611 {
612         DE_ASSERT(!isCoreTextureTarget(contextType, target));
613
614         if (contextSupports(contextType, glu::ApiType::es(3,2)))
615                 return es32::getTextureTargetExtension(target);
616         if (contextSupports(contextType, glu::ApiType::es(3,1)))
617                 return es31::getTextureTargetExtension(target);
618         else if (contextSupports(contextType, glu::ApiType::es(3,0)))
619                 return es30::getTextureTargetExtension(target);
620         else
621         {
622                 DE_ASSERT(false);
623                 return RequiredExtensions();
624         }
625 }
626
627 static RequiredExtensions getTextureParamExtension (const glu::ContextType& contextType, glw::GLenum pname)
628 {
629         DE_ASSERT(!isCoreTextureParam(contextType, pname));
630
631         if (contextSupports(contextType, glu::ApiType::es(3,2)))
632                 return es32::getTextureParamExtension(pname);
633         else if (contextSupports(contextType, glu::ApiType::es(3,1)))
634                 return es31::getTextureParamExtension(pname);
635         else if (contextSupports(contextType, glu::ApiType::es(3,0)))
636                 return es30::getTextureParamExtension(pname);
637         else
638         {
639                 DE_ASSERT(false);
640                 return RequiredExtensions();
641         }
642 }
643
644 static RequiredExtensions getQueryExtension (const glu::ContextType& contextType, QueryType query)
645 {
646         DE_ASSERT(!isCoreQuery(contextType, query));
647
648         if (contextSupports(contextType, glu::ApiType::es(3,2)))
649                 return es32::getQueryExtension(query);
650         else if (contextSupports(contextType, glu::ApiType::es(3,1)))
651                 return es31::getQueryExtension(query);
652         else if (contextSupports(contextType, glu::ApiType::es(3,0)))
653                 return es30::getQueryExtension(query);
654         else
655         {
656                 DE_ASSERT(false);
657                 return RequiredExtensions();
658         }
659 }
660
661 static RequiredExtensions getTesterExtension (const glu::ContextType& contextType, TesterType tester)
662 {
663         DE_ASSERT(!isCoreTester(contextType, tester));
664
665         if (contextSupports(contextType, glu::ApiType::es(3,2)))
666                 return es32::getTesterExtension(tester);
667         else if (contextSupports(contextType, glu::ApiType::es(3,1)))
668                 return es31::getTesterExtension(tester);
669         else if (contextSupports(contextType, glu::ApiType::es(3,0)))
670                 return es30::getTesterExtension(tester);
671         else
672         {
673                 DE_ASSERT(false);
674                 return RequiredExtensions();
675         }
676 }
677
678 class TextureTest : public tcu::TestCase
679 {
680 public:
681                                                 TextureTest     (tcu::TestContext&                      testCtx,
682                                                                          const glu::RenderContext&      renderCtx,
683                                                                          const char*                            name,
684                                                                          const char*                            desc,
685                                                                          glw::GLenum                            target,
686                                                                          TesterType                                     tester,
687                                                                          QueryType                                      type);
688
689         void                            init            (void);
690         IterateResult           iterate         (void);
691
692         virtual void            test            (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const = 0;
693
694 protected:
695         const glu::RenderContext&       m_renderCtx;
696         const glw::GLenum                       m_target;
697         const glw::GLenum                       m_pname;
698         const TesterType                        m_tester;
699         const QueryType                         m_type;
700 };
701
702 TextureTest::TextureTest (tcu::TestContext&                     testCtx,
703                                                   const glu::RenderContext&     renderCtx,
704                                                   const char*                           name,
705                                                   const char*                           desc,
706                                                   glw::GLenum                           target,
707                                                   TesterType                            tester,
708                                                   QueryType                                     type)
709         : TestCase              (testCtx, name, desc)
710         , m_renderCtx   (renderCtx)
711         , m_target              (target)
712         , m_pname               (mapTesterToPname(tester))
713         , m_tester              (tester)
714         , m_type                (type)
715 {
716 }
717
718 void TextureTest::init (void)
719 {
720         const de::UniquePtr<glu::ContextInfo>   ctxInfo         (glu::ContextInfo::create(m_renderCtx));
721         RequiredExtensions                                              extensions;
722
723         // target
724         if (!isCoreTextureTarget(m_renderCtx.getType(), m_target))
725                 extensions.add(getTextureTargetExtension(m_renderCtx.getType(), m_target));
726
727         // param
728         if (!isCoreTextureParam(m_renderCtx.getType(), m_pname))
729                 extensions.add(getTextureParamExtension(m_renderCtx.getType(), m_pname));
730
731         // query
732         if (!isCoreQuery(m_renderCtx.getType(), m_type))
733                 extensions.add(getQueryExtension(m_renderCtx.getType(), m_type));
734
735         // test type
736         if (!isCoreTester(m_renderCtx.getType(), m_tester))
737                 extensions.add(getTesterExtension(m_renderCtx.getType(), m_tester));
738
739         extensions.check(*ctxInfo);
740 }
741
742 TextureTest::IterateResult TextureTest::iterate (void)
743 {
744         glu::CallLogWrapper             gl              (m_renderCtx.getFunctions(), m_testCtx.getLog());
745         tcu::ResultCollector    result  (m_testCtx.getLog(), " // ERROR: ");
746
747         gl.enableLogging(true);
748         test(gl, result);
749
750         result.setTestContextResult(m_testCtx);
751         return STOP;
752 }
753
754 class IsTextureCase : public tcu::TestCase
755 {
756 public:
757                                                                 IsTextureCase   (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target);
758
759         void                                            init                    (void);
760         IterateResult                           iterate                 (void);
761
762 protected:
763         const glu::RenderContext&       m_renderCtx;
764         const glw::GLenum                       m_target;
765 };
766
767 IsTextureCase::IsTextureCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target)
768         : tcu::TestCase (testCtx, name, desc)
769         , m_renderCtx   (renderCtx)
770         , m_target              (target)
771 {
772 }
773
774 void IsTextureCase::init (void)
775 {
776         const de::UniquePtr<glu::ContextInfo>   ctxInfo         (glu::ContextInfo::create(m_renderCtx));
777         RequiredExtensions                                              extensions;
778
779         // target
780         if (!isCoreTextureTarget(m_renderCtx.getType(), m_target))
781                 extensions.add(getTextureTargetExtension(m_renderCtx.getType(), m_target));
782
783         extensions.check(*ctxInfo);
784 }
785
786 IsTextureCase::IterateResult IsTextureCase::iterate (void)
787 {
788         glu::CallLogWrapper             gl                      (m_renderCtx.getFunctions(), m_testCtx.getLog());
789         tcu::ResultCollector    result          (m_testCtx.getLog(), " // ERROR: ");
790         glw::GLuint                             textureId       = 0;
791
792         gl.enableLogging(true);
793
794         gl.glGenTextures(1, &textureId);
795         gl.glBindTexture(m_target, textureId);
796         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glBindTexture");
797
798         verifyStateObjectBoolean(result, gl, textureId, true, QUERY_ISTEXTURE);
799
800         gl.glDeleteTextures(1, &textureId);
801         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glDeleteTextures");
802
803         verifyStateObjectBoolean(result, gl, textureId, false, QUERY_ISTEXTURE);
804
805         result.setTestContextResult(m_testCtx);
806         return STOP;
807 }
808
809 class DepthStencilModeCase : public TextureTest
810 {
811 public:
812                         DepthStencilModeCase    (tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type);
813         void    test                                    (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
814 };
815
816 DepthStencilModeCase::DepthStencilModeCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type)
817         : TextureTest(testCtx, renderCtx, name, desc, target, tester, type)
818 {
819 }
820
821 void DepthStencilModeCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
822 {
823         const bool              isPureCase      = isPureIntTester(m_tester) || isPureUintTester(m_tester);
824         glu::Texture    texture         (m_renderCtx);
825
826         gl.glBindTexture(m_target, *texture);
827         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "bind");
828
829         if (!isPureCase)
830         {
831                 const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
832                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_DEPTH_COMPONENT, m_type);
833         }
834
835         if (!isPureCase)
836         {
837                 const tcu::ScopedLogSection     section                         (m_testCtx.getLog(), "Toggle", "Toggle");
838                 const glw::GLint                        depthComponentInt       = GL_DEPTH_COMPONENT;
839                 const glw::GLfloat                      depthComponentFloat     = (glw::GLfloat)GL_DEPTH_COMPONENT;
840
841                 gl.glTexParameteri(m_target, m_pname, GL_STENCIL_INDEX);
842                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
843                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_STENCIL_INDEX, m_type);
844
845                 gl.glTexParameteriv(m_target, m_pname, &depthComponentInt);
846                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
847                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_DEPTH_COMPONENT, m_type);
848
849                 gl.glTexParameterf(m_target, m_pname, GL_STENCIL_INDEX);
850                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
851                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_STENCIL_INDEX, m_type);
852
853                 gl.glTexParameterfv(m_target, m_pname, &depthComponentFloat);
854                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
855                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_DEPTH_COMPONENT, m_type);
856         }
857
858         if (isPureIntTester(m_tester))
859         {
860                 const glw::GLint depthComponent = GL_DEPTH_COMPONENT;
861                 const glw::GLint stencilIndex   = GL_STENCIL_INDEX;
862
863                 gl.glTexParameterIiv(m_target, m_pname, &stencilIndex);
864                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
865                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_STENCIL_INDEX, m_type);
866
867                 gl.glTexParameterIiv(m_target, m_pname, &depthComponent);
868                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
869                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_DEPTH_COMPONENT, m_type);
870         }
871
872         if (isPureUintTester(m_tester))
873         {
874                 const glw::GLuint depthComponent        = GL_DEPTH_COMPONENT;
875                 const glw::GLuint stencilIndex  = GL_STENCIL_INDEX;
876
877                 gl.glTexParameterIuiv(m_target, m_pname, &stencilIndex);
878                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
879                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_STENCIL_INDEX, m_type);
880
881                 gl.glTexParameterIuiv(m_target, m_pname, &depthComponent);
882                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
883                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_DEPTH_COMPONENT, m_type);
884         }
885 }
886
887 class TextureSRGBDecodeCase : public TextureTest
888 {
889 public:
890                         TextureSRGBDecodeCase   (tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type);
891         void    test                                    (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
892 };
893
894 TextureSRGBDecodeCase::TextureSRGBDecodeCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type)
895         : TextureTest(testCtx, renderCtx, name, desc, target, tester, type)
896 {
897 }
898
899 void TextureSRGBDecodeCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
900 {
901         const bool              isPureCase      = isPureIntTester(m_tester) || isPureUintTester(m_tester);
902         glu::Texture    texture         (m_renderCtx);
903
904         gl.glBindTexture(m_target, *texture);
905         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "bind");
906
907         if (!isPureCase)
908         {
909                 const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
910                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_DECODE_EXT, m_type);
911         }
912
913         if (!isPureCase)
914         {
915                 const tcu::ScopedLogSection     section                 (m_testCtx.getLog(), "Toggle", "Toggle");
916                 const glw::GLint                        decodeInt               = GL_DECODE_EXT;
917                 const glw::GLfloat                      decodeFloat             = (glw::GLfloat)GL_DECODE_EXT;
918
919                 gl.glTexParameteri(m_target, m_pname, GL_SKIP_DECODE_EXT);
920                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
921                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_SKIP_DECODE_EXT, m_type);
922
923                 gl.glTexParameteriv(m_target, m_pname, &decodeInt);
924                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
925                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_DECODE_EXT, m_type);
926
927                 gl.glTexParameterf(m_target, m_pname, GL_SKIP_DECODE_EXT);
928                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
929                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_SKIP_DECODE_EXT, m_type);
930
931                 gl.glTexParameterfv(m_target, m_pname, &decodeFloat);
932                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
933                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_DECODE_EXT, m_type);
934         }
935
936         if (isPureIntTester(m_tester))
937         {
938                 const glw::GLint skipDecode     = GL_SKIP_DECODE_EXT;
939                 const glw::GLint decode         = GL_DECODE_EXT;
940
941                 gl.glTexParameterIiv(m_target, m_pname, &skipDecode);
942                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
943                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_SKIP_DECODE_EXT, m_type);
944
945                 gl.glTexParameterIiv(m_target, m_pname, &decode);
946                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
947                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_DECODE_EXT, m_type);
948         }
949
950         if (isPureUintTester(m_tester))
951         {
952                 const glw::GLuint skipDecode    = GL_SKIP_DECODE_EXT;
953                 const glw::GLuint decode                = GL_DECODE_EXT;
954
955                 gl.glTexParameterIuiv(m_target, m_pname, &skipDecode);
956                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
957                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_SKIP_DECODE_EXT, m_type);
958
959                 gl.glTexParameterIuiv(m_target, m_pname, &decode);
960                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
961                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_DECODE_EXT, m_type);
962         }
963 }
964
965 class TextureSwizzleCase : public TextureTest
966 {
967 public:
968                         TextureSwizzleCase      (tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type);
969         void    test                            (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
970 };
971
972 TextureSwizzleCase::TextureSwizzleCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type)
973         : TextureTest(testCtx, renderCtx, name, desc, target, tester, type)
974 {
975 }
976
977 void TextureSwizzleCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
978 {
979         const bool      isPureCase              = isPureIntTester(m_tester) || isPureUintTester(m_tester);
980         const int       initialValue    = (m_pname == GL_TEXTURE_SWIZZLE_R) ? (GL_RED) :
981                                                                   (m_pname == GL_TEXTURE_SWIZZLE_G) ? (GL_GREEN) :
982                                                                   (m_pname == GL_TEXTURE_SWIZZLE_B) ? (GL_BLUE) :
983                                                                   (m_pname == GL_TEXTURE_SWIZZLE_A) ? (GL_ALPHA) :
984                                                                   (-1);
985
986         if (!isPureCase)
987         {
988                 const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
989                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, initialValue, m_type);
990         }
991
992         {
993                 const tcu::ScopedLogSection     section                 (m_testCtx.getLog(), "Set", "Set");
994                 const GLenum                            swizzleValues[] = {GL_RED, GL_GREEN, GL_BLUE, GL_ALPHA, GL_ZERO, GL_ONE};
995
996                 if (isPureCase)
997                 {
998                         for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(swizzleValues); ++ndx)
999                         {
1000                                 if (isPureIntTester(m_tester))
1001                                 {
1002                                         const glw::GLint value = (glw::GLint)swizzleValues[ndx];
1003                                         gl.glTexParameterIiv(m_target, m_pname, &value);
1004                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
1005                                 }
1006                                 else
1007                                 {
1008                                         DE_ASSERT(isPureUintTester(m_tester));
1009
1010                                         const glw::GLuint value = swizzleValues[ndx];
1011                                         gl.glTexParameterIuiv(m_target, m_pname, &value);
1012                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
1013                                 }
1014
1015                                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, swizzleValues[ndx], m_type);
1016                         }
1017                 }
1018                 else
1019                 {
1020                         for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(swizzleValues); ++ndx)
1021                         {
1022                                 gl.glTexParameteri(m_target, m_pname, swizzleValues[ndx]);
1023                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteri");
1024
1025                                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, swizzleValues[ndx], m_type);
1026                         }
1027
1028                         //check unit conversions with float
1029
1030                         for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(swizzleValues); ++ndx)
1031                         {
1032                                 gl.glTexParameterf(m_target, m_pname, (GLfloat)swizzleValues[ndx]);
1033                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterf");
1034
1035                                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, swizzleValues[ndx], m_type);
1036                         }
1037                 }
1038         }
1039 }
1040
1041 class TextureWrapCase : public TextureTest
1042 {
1043 public:
1044                         TextureWrapCase (tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type);
1045         void    test                    (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1046 };
1047
1048 TextureWrapCase::TextureWrapCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type)
1049         : TextureTest(testCtx, renderCtx, name, desc, target, tester, type)
1050 {
1051 }
1052
1053 void TextureWrapCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1054 {
1055         const bool isPureCase = isPureIntTester(m_tester) || isPureUintTester(m_tester);
1056
1057         if (!isPureCase)
1058         {
1059                 const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1060                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_REPEAT, m_type);
1061         }
1062
1063         {
1064                 const tcu::ScopedLogSection     section                 (m_testCtx.getLog(), "Set", "Set");
1065                 const GLenum                            wrapValues[]    = {GL_CLAMP_TO_EDGE, GL_REPEAT, GL_MIRRORED_REPEAT};
1066
1067                 if (isPureCase)
1068                 {
1069                         for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(wrapValues); ++ndx)
1070                         {
1071                                 if (isPureIntTester(m_tester))
1072                                 {
1073                                         const glw::GLint value = (glw::GLint)wrapValues[ndx];
1074                                         gl.glTexParameterIiv(m_target, m_pname, &value);
1075                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
1076                                 }
1077                                 else
1078                                 {
1079                                         DE_ASSERT(isPureUintTester(m_tester));
1080
1081                                         const glw::GLuint value = wrapValues[ndx];
1082                                         gl.glTexParameterIuiv(m_target, m_pname, &value);
1083                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
1084                                 }
1085
1086                                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, wrapValues[ndx], m_type);
1087                         }
1088                 }
1089                 else
1090                 {
1091                         for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(wrapValues); ++ndx)
1092                         {
1093                                 gl.glTexParameteri(m_target, m_pname, wrapValues[ndx]);
1094                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteri");
1095
1096                                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, wrapValues[ndx], m_type);
1097                         }
1098
1099                         //check unit conversions with float
1100
1101                         for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(wrapValues); ++ndx)
1102                         {
1103                                 gl.glTexParameterf(m_target, m_pname, (GLfloat)wrapValues[ndx]);
1104                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterf");
1105
1106                                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, wrapValues[ndx], m_type);
1107                         }
1108                 }
1109         }
1110 }
1111
1112 class TextureFilterCase : public TextureTest
1113 {
1114 public:
1115                         TextureFilterCase       (tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type);
1116         void    test                            (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1117 };
1118
1119 TextureFilterCase::TextureFilterCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type)
1120         : TextureTest(testCtx, renderCtx, name, desc, target, tester, type)
1121 {
1122 }
1123
1124 void TextureFilterCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1125 {
1126         const bool                      isPureCase      = isPureIntTester(m_tester) || isPureUintTester(m_tester);
1127         const glw::GLenum       initial         = (m_pname == GL_TEXTURE_MAG_FILTER) ? (GL_LINEAR)
1128                                                                         : (m_pname == GL_TEXTURE_MIN_FILTER) ? (GL_NEAREST_MIPMAP_LINEAR)
1129                                                                         : (0);
1130
1131         if (!isPureCase)
1132         {
1133                 const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1134                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, initial, m_type);
1135         }
1136
1137         {
1138                 const tcu::ScopedLogSection     section         (m_testCtx.getLog(), "Set", "Set");
1139                 std::vector<GLenum>                     values;
1140
1141                 values.push_back(GL_NEAREST);
1142                 values.push_back(GL_LINEAR);
1143                 if (m_pname == GL_TEXTURE_MIN_FILTER)
1144                 {
1145                         values.push_back(GL_NEAREST_MIPMAP_NEAREST);
1146                         values.push_back(GL_NEAREST_MIPMAP_LINEAR);
1147                         values.push_back(GL_LINEAR_MIPMAP_NEAREST);
1148                         values.push_back(GL_LINEAR_MIPMAP_LINEAR);
1149                 }
1150
1151                 if (isPureCase)
1152                 {
1153                         for (int ndx = 0; ndx < (int)values.size(); ++ndx)
1154                         {
1155                                 if (isPureIntTester(m_tester))
1156                                 {
1157                                         const glw::GLint value = (glw::GLint)values[ndx];
1158                                         gl.glTexParameterIiv(m_target, m_pname, &value);
1159                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
1160                                 }
1161                                 else
1162                                 {
1163                                         DE_ASSERT(isPureUintTester(m_tester));
1164
1165                                         const glw::GLuint value = values[ndx];
1166                                         gl.glTexParameterIuiv(m_target, m_pname, &value);
1167                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
1168                                 }
1169
1170                                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, values[ndx], m_type);
1171                         }
1172                 }
1173                 else
1174                 {
1175                         for (int ndx = 0; ndx < (int)values.size(); ++ndx)
1176                         {
1177                                 gl.glTexParameteri(m_target, m_pname, values[ndx]);
1178                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteri");
1179
1180                                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, values[ndx], m_type);
1181                         }
1182
1183                         //check unit conversions with float
1184
1185                         for (int ndx = 0; ndx < (int)values.size(); ++ndx)
1186                         {
1187                                 gl.glTexParameterf(m_target, m_pname, (GLfloat)values[ndx]);
1188                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterf");
1189
1190                                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, values[ndx], m_type);
1191                         }
1192                 }
1193         }
1194 }
1195
1196 class TextureLODCase : public TextureTest
1197 {
1198 public:
1199                         TextureLODCase  (tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type);
1200         void    test                    (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1201 };
1202
1203 TextureLODCase::TextureLODCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type)
1204         : TextureTest(testCtx, renderCtx, name, desc, target, tester, type)
1205 {
1206 }
1207
1208 void TextureLODCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1209 {
1210         const bool      isPureCase              = isPureIntTester(m_tester) || isPureUintTester(m_tester);
1211         const int       initialValue    = (m_pname == GL_TEXTURE_MIN_LOD) ? (-1000)
1212                                                                 : (m_pname == GL_TEXTURE_MAX_LOD) ? (1000)
1213                                                                 : (-1);
1214
1215         if ((querySupportsSigned(m_type) || initialValue >= 0) && !isPureCase)
1216         {
1217                 const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1218                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, initialValue, m_type);
1219         }
1220
1221         {
1222                 const tcu::ScopedLogSection     section                 (m_testCtx.getLog(), "Set", "Set");
1223                 const int                                       numIterations   = 20;
1224                 de::Random                                      rnd                             (0xabcdef);
1225
1226                 if (isPureCase)
1227                 {
1228                         if (isPureIntTester(m_tester))
1229                         {
1230                                 for (int ndx = 0; ndx < numIterations; ++ndx)
1231                                 {
1232                                         const GLint ref = rnd.getInt(-1000, 1000);
1233
1234                                         gl.glTexParameterIiv(m_target, m_pname, &ref);
1235                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
1236
1237                                         verifyStateTextureParamFloat(result, gl, m_target, m_pname, (float)ref, m_type);
1238                                 }
1239                         }
1240                         else
1241                         {
1242                                 DE_ASSERT(isPureUintTester(m_tester));
1243
1244                                 for (int ndx = 0; ndx < numIterations; ++ndx)
1245                                 {
1246                                         const GLuint ref = (glw::GLuint)rnd.getInt(0, 1000);
1247
1248                                         gl.glTexParameterIuiv(m_target, m_pname, &ref);
1249                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
1250
1251                                         verifyStateTextureParamFloat(result, gl, m_target, m_pname, (float)ref, m_type);
1252                                 }
1253                         }
1254                 }
1255                 else
1256                 {
1257                         const int minLimit = (querySupportsSigned(m_type)) ? (-1000) : (0);
1258
1259                         for (int ndx = 0; ndx < numIterations; ++ndx)
1260                         {
1261                                 const GLfloat ref = rnd.getFloat((float)minLimit, 1000.f);
1262
1263                                 gl.glTexParameterf(m_target, m_pname, ref);
1264                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterf");
1265
1266                                 verifyStateTextureParamFloat(result, gl, m_target, m_pname, ref, m_type);
1267                         }
1268
1269                         // check unit conversions with int
1270
1271                         for (int ndx = 0; ndx < numIterations; ++ndx)
1272                         {
1273                                 const GLint ref = rnd.getInt(minLimit, 1000);
1274
1275                                 gl.glTexParameteri(m_target, m_pname, ref);
1276                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteri");
1277
1278                                 verifyStateTextureParamFloat(result, gl, m_target, m_pname, (float)ref, m_type);
1279                         }
1280                 }
1281         }
1282 }
1283
1284 class TextureLevelCase : public TextureTest
1285 {
1286 public:
1287                         TextureLevelCase        (tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type);
1288         void    test                            (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1289 };
1290
1291 TextureLevelCase::TextureLevelCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type)
1292         : TextureTest(testCtx, renderCtx, name, desc, target, tester, type)
1293 {
1294 }
1295
1296 void TextureLevelCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1297 {
1298         const bool      isPureCase              = isPureIntTester(m_tester) || isPureUintTester(m_tester);
1299         const int       initialValue    = (m_pname == GL_TEXTURE_BASE_LEVEL) ? (0)
1300                                                                 : (m_pname == GL_TEXTURE_MAX_LEVEL)     ? (1000)
1301                                                                 : (-1);
1302
1303         if (!isPureCase)
1304         {
1305                 const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1306                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, initialValue, m_type);
1307         }
1308
1309         if (m_target == GL_TEXTURE_2D_MULTISAMPLE               ||
1310                 m_target == GL_TEXTURE_2D_MULTISAMPLE_ARRAY)
1311         {
1312                 // only 0 allowed
1313                 {
1314                         const tcu::ScopedLogSection section(m_testCtx.getLog(), "Set", "Set");
1315
1316                         gl.glTexParameteri(m_target, m_pname, 0);
1317                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteri");
1318                         verifyStateTextureParamInteger(result, gl, m_target, m_pname, 0, m_type);
1319
1320                         gl.glTexParameterf(m_target, m_pname, 0.0f);
1321                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterf");
1322                         verifyStateTextureParamInteger(result, gl, m_target, m_pname, 0, m_type);
1323                 }
1324         }
1325         else
1326         {
1327                 const tcu::ScopedLogSection     section                 (m_testCtx.getLog(), "Set", "Set");
1328                 const int                                       numIterations   = 20;
1329                 de::Random                                      rnd                             (0xabcdef);
1330
1331                 if (isPureCase)
1332                 {
1333                         for (int ndx = 0; ndx < numIterations; ++ndx)
1334                         {
1335                                 const GLint             ref             = rnd.getInt(0, 64000);
1336                                 const GLuint    uRef    = (glw::GLuint)ref;
1337
1338                                 if (isPureIntTester(m_tester))
1339                                 {
1340                                         gl.glTexParameterIiv(m_target, m_pname, &ref);
1341                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
1342                                 }
1343                                 else
1344                                 {
1345                                         DE_ASSERT(isPureUintTester(m_tester));
1346                                         gl.glTexParameterIuiv(m_target, m_pname, &uRef);
1347                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
1348                                 }
1349
1350                                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, ref, m_type);
1351                         }
1352                 }
1353                 else
1354                 {
1355                         for (int ndx = 0; ndx < numIterations; ++ndx)
1356                         {
1357                                 const GLint ref = rnd.getInt(0, 64000);
1358
1359                                 gl.glTexParameteri(m_target, m_pname, ref);
1360                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteri");
1361
1362                                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, ref, m_type);
1363                         }
1364
1365                         // check unit conversions with float
1366
1367                         const float nonSignificantOffsets[] = {-0.45f, -0.25f, 0, 0.45f}; // offsets O so that for any integers z in Z, o in O roundToClosestInt(z+o)==z
1368
1369                         const int numConversionIterations = 30;
1370                         for (int ndx = 0; ndx < numConversionIterations; ++ndx)
1371                         {
1372                                 const GLint ref = rnd.getInt(1, 64000);
1373
1374                                 for (int offsetNdx = 0; offsetNdx < DE_LENGTH_OF_ARRAY(nonSignificantOffsets); ++offsetNdx)
1375                                 {
1376                                         gl.glTexParameterf(m_target, m_pname, ((GLfloat)ref) + nonSignificantOffsets[offsetNdx]);
1377                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterf");
1378
1379                                         verifyStateTextureParamInteger(result, gl, m_target, m_pname, ref, m_type);
1380                                 }
1381                         }
1382                 }
1383         }
1384 }
1385
1386 class TextureCompareModeCase : public TextureTest
1387 {
1388 public:
1389                         TextureCompareModeCase  (tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type);
1390         void    test                                    (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1391 };
1392
1393 TextureCompareModeCase::TextureCompareModeCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type)
1394         : TextureTest(testCtx, renderCtx, name, desc, target, tester, type)
1395 {
1396 }
1397
1398 void TextureCompareModeCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1399 {
1400         const bool isPureCase = isPureIntTester(m_tester) || isPureUintTester(m_tester);
1401
1402         if (!isPureCase)
1403         {
1404                 const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1405                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_NONE, m_type);
1406         }
1407
1408         {
1409                 const tcu::ScopedLogSection     section         (m_testCtx.getLog(), "Set", "Set");
1410                 const GLenum                            modes[]         = {GL_COMPARE_REF_TO_TEXTURE, GL_NONE};
1411
1412                 if (isPureCase)
1413                 {
1414                         for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(modes); ++ndx)
1415                         {
1416                                 if (isPureIntTester(m_tester))
1417                                 {
1418                                         const glw::GLint value = (glw::GLint)modes[ndx];
1419                                         gl.glTexParameterIiv(m_target, m_pname, &value);
1420                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
1421                                 }
1422                                 else
1423                                 {
1424                                         DE_ASSERT(isPureUintTester(m_tester));
1425
1426                                         const glw::GLuint value = modes[ndx];
1427                                         gl.glTexParameterIuiv(m_target, m_pname, &value);
1428                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
1429                                 }
1430
1431                                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, modes[ndx], m_type);
1432                         }
1433                 }
1434                 else
1435                 {
1436                         for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(modes); ++ndx)
1437                         {
1438                                 gl.glTexParameteri(m_target, m_pname, modes[ndx]);
1439                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteri");
1440
1441                                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, modes[ndx], m_type);
1442                         }
1443
1444                         //check unit conversions with float
1445
1446                         for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(modes); ++ndx)
1447                         {
1448                                 gl.glTexParameterf(m_target, m_pname, (GLfloat)modes[ndx]);
1449                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterf");
1450
1451                                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, modes[ndx], m_type);
1452                         }
1453                 }
1454         }
1455 }
1456
1457 class TextureCompareFuncCase : public TextureTest
1458 {
1459 public:
1460                         TextureCompareFuncCase  (tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type);
1461         void    test                                    (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1462 };
1463
1464 TextureCompareFuncCase::TextureCompareFuncCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type)
1465         : TextureTest(testCtx, renderCtx, name, desc, target, tester, type)
1466 {
1467 }
1468
1469 void TextureCompareFuncCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1470 {
1471         const bool isPureCase = isPureIntTester(m_tester) || isPureUintTester(m_tester);
1472
1473         if (!isPureCase)
1474         {
1475                 const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1476                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_LEQUAL, m_type);
1477         }
1478
1479         {
1480                 const tcu::ScopedLogSection     section                 (m_testCtx.getLog(), "Set", "Set");
1481                 const GLenum                            compareFuncs[]  = {GL_LEQUAL, GL_GEQUAL, GL_LESS, GL_GREATER, GL_EQUAL, GL_NOTEQUAL, GL_ALWAYS, GL_NEVER};
1482
1483                 if (isPureCase)
1484                 {
1485                         for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(compareFuncs); ++ndx)
1486                         {
1487                                 if (isPureIntTester(m_tester))
1488                                 {
1489                                         const glw::GLint value = (glw::GLint)compareFuncs[ndx];
1490                                         gl.glTexParameterIiv(m_target, m_pname, &value);
1491                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
1492                                 }
1493                                 else
1494                                 {
1495                                         DE_ASSERT(isPureUintTester(m_tester));
1496
1497                                         const glw::GLuint value = compareFuncs[ndx];
1498                                         gl.glTexParameterIuiv(m_target, m_pname, &value);
1499                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
1500                                 }
1501
1502                                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, compareFuncs[ndx], m_type);
1503                         }
1504                 }
1505                 else
1506                 {
1507                         for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(compareFuncs); ++ndx)
1508                         {
1509                                 gl.glTexParameteri(m_target, m_pname, compareFuncs[ndx]);
1510                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteri");
1511
1512                                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, compareFuncs[ndx], m_type);
1513                         }
1514
1515                         //check unit conversions with float
1516
1517                         for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(compareFuncs); ++ndx)
1518                         {
1519                                 gl.glTexParameterf(m_target, m_pname, (GLfloat)compareFuncs[ndx]);
1520                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterf");
1521
1522                                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, compareFuncs[ndx], m_type);
1523                         }
1524                 }
1525         }
1526 }
1527
1528 class TextureImmutableLevelsCase : public TextureTest
1529 {
1530 public:
1531                         TextureImmutableLevelsCase      (tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, QueryType type);
1532         void    test                                            (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1533 };
1534
1535 TextureImmutableLevelsCase::TextureImmutableLevelsCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, QueryType type)
1536         : TextureTest(testCtx, renderCtx, name, desc, target, TESTER_TEXTURE_IMMUTABLE_LEVELS, type)
1537 {
1538 }
1539
1540 void TextureImmutableLevelsCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1541 {
1542         {
1543                 const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1544                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, 0, m_type);
1545         }
1546
1547         if (m_target == GL_TEXTURE_2D_MULTISAMPLE               ||
1548                 m_target == GL_TEXTURE_2D_MULTISAMPLE_ARRAY)
1549         {
1550                 // no levels
1551                 const tcu::ScopedLogSection     section         (m_testCtx.getLog(), "Level", "Level");
1552                 GLuint                                          textureID       = 0;
1553
1554                 gl.glGenTextures(1, &textureID);
1555                 gl.glBindTexture(m_target, textureID);
1556                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glBindTexture");
1557
1558                 if (m_target == GL_TEXTURE_2D_MULTISAMPLE)
1559                         gl.glTexStorage2DMultisample(m_target, 2, GL_RGB8, 64, 64, GL_FALSE);
1560                 else if (m_target == GL_TEXTURE_2D_MULTISAMPLE_ARRAY)
1561                         gl.glTexStorage3DMultisample(m_target, 2, GL_RGB8, 64, 64, 2, GL_FALSE);
1562                 else
1563                         DE_ASSERT(false);
1564                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexStorage");
1565
1566                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, 1, m_type);
1567
1568                 gl.glDeleteTextures(1, &textureID);
1569                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glDeleteTextures");
1570         }
1571         else
1572         {
1573                 for (int level = 1; level <= 7; ++level)
1574                 {
1575                         const tcu::ScopedLogSection     section         (m_testCtx.getLog(), "Levels", "Levels = " + de::toString(level));
1576                         GLuint                                          textureID       = 0;
1577
1578                         gl.glGenTextures(1, &textureID);
1579                         gl.glBindTexture(m_target, textureID);
1580                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glBindTexture");
1581
1582                         if (m_target == GL_TEXTURE_2D || m_target == GL_TEXTURE_CUBE_MAP)
1583                                 gl.glTexStorage2D(m_target, level, GL_RGB8, 64, 64);
1584                         else if (m_target == GL_TEXTURE_2D_ARRAY || m_target == GL_TEXTURE_3D)
1585                                 gl.glTexStorage3D(m_target, level, GL_RGB8, 64, 64, 64);
1586                         else if (m_target == GL_TEXTURE_CUBE_MAP_ARRAY)
1587                                 gl.glTexStorage3D(m_target, level, GL_RGB8, 64, 64, 6 * 2);
1588                         else
1589                                 DE_ASSERT(false);
1590                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexStorage");
1591
1592                         verifyStateTextureParamInteger(result, gl, m_target, m_pname, level, m_type);
1593
1594                         gl.glDeleteTextures(1, &textureID);
1595                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glDeleteTextures");
1596                 }
1597         }
1598 }
1599
1600 class TextureImmutableFormatCase : public TextureTest
1601 {
1602 public:
1603                         TextureImmutableFormatCase      (tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, QueryType type);
1604         void    test                                            (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1605 };
1606
1607 TextureImmutableFormatCase::TextureImmutableFormatCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, QueryType type)
1608         : TextureTest(testCtx, renderCtx, name, desc, target, TESTER_TEXTURE_IMMUTABLE_FORMAT, type)
1609 {
1610 }
1611
1612 void TextureImmutableFormatCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1613 {
1614         {
1615                 const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1616                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, 0, m_type);
1617         }
1618
1619         {
1620                 const tcu::ScopedLogSection     subsection      (m_testCtx.getLog(), "Immutable", "Immutable");
1621                 GLuint                                          textureID       = 0;
1622
1623                 gl.glGenTextures(1, &textureID);
1624                 gl.glBindTexture(m_target, textureID);
1625                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glBindTexture");
1626
1627                 switch (m_target)
1628                 {
1629                         case GL_TEXTURE_2D:
1630                         case GL_TEXTURE_CUBE_MAP:
1631                         {
1632                                 gl.glTexStorage2D(m_target, 1, GL_RGBA8, 32, 32);
1633                                 break;
1634                         }
1635                         case GL_TEXTURE_2D_ARRAY:
1636                         case GL_TEXTURE_3D:
1637                         {
1638                                 gl.glTexStorage3D(m_target, 1, GL_RGBA8, 32, 32, 8);
1639                                 break;
1640                         }
1641                         case GL_TEXTURE_2D_MULTISAMPLE:
1642                         {
1643                                 gl.glTexStorage2DMultisample(m_target, 2, GL_RGB8, 64, 64, GL_FALSE);
1644                                 break;
1645                         }
1646                         case GL_TEXTURE_2D_MULTISAMPLE_ARRAY:
1647                         {
1648                                 gl.glTexStorage3DMultisample(m_target, 2, GL_RGB8, 64, 64, 2, GL_FALSE);
1649                                 break;
1650                         }
1651                         case GL_TEXTURE_CUBE_MAP_ARRAY:
1652                         {
1653                                 gl.glTexStorage3D(m_target, 1, GL_RGBA8, 32, 32, 6 * 2);
1654                                 break;
1655                         }
1656                         default:
1657                                 DE_ASSERT(false);
1658                 }
1659                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "setup texture");
1660
1661                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, 1, m_type);
1662
1663                 gl.glDeleteTextures(1, &textureID);
1664                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glDeleteTextures");
1665         }
1666
1667         // no mutable
1668         if (m_target == GL_TEXTURE_2D_MULTISAMPLE ||
1669                 m_target == GL_TEXTURE_2D_MULTISAMPLE_ARRAY)
1670                 return;
1671
1672         // test mutable
1673         {
1674                 const tcu::ScopedLogSection     subsection              (m_testCtx.getLog(), "Mutable", "Mutable");
1675                 GLuint                                          textureID               = 0;
1676
1677                 gl.glGenTextures(1, &textureID);
1678                 gl.glBindTexture(m_target, textureID);
1679                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glBindTexture");
1680
1681                 switch (m_target)
1682                 {
1683                         case GL_TEXTURE_2D:
1684                         {
1685                                 gl.glTexImage2D(m_target, 0, GL_RGBA8, 32, 32, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
1686                                 break;
1687                         }
1688                         case GL_TEXTURE_CUBE_MAP:
1689                         {
1690                                 gl.glTexImage2D(GL_TEXTURE_CUBE_MAP_NEGATIVE_Y, 0, GL_RGBA8, 32, 32, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
1691                                 break;
1692                         }
1693                         case GL_TEXTURE_2D_ARRAY:
1694                         case GL_TEXTURE_3D:
1695                         {
1696                                 gl.glTexImage3D(m_target, 0, GL_RGBA8, 32, 32, 8, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
1697                                 break;
1698                         }
1699                         case GL_TEXTURE_CUBE_MAP_ARRAY:
1700                         {
1701                                 gl.glTexImage3D(m_target, 0, GL_RGBA8, 32, 32, 6 * 2, 0, GL_RGBA, GL_UNSIGNED_BYTE, DE_NULL);
1702                                 break;
1703                         }
1704                         default:
1705                                 DE_ASSERT(false);
1706                 }
1707                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "setup texture");
1708
1709                 verifyStateTextureParamInteger(result, gl, m_target, m_pname, 0, m_type);
1710
1711                 gl.glDeleteTextures(1, &textureID);
1712                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glDeleteTextures");
1713         }
1714 }
1715
1716 class TextureWrapClampToBorderCase : public TextureTest
1717 {
1718 public:
1719                         TextureWrapClampToBorderCase    (tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type);
1720         void    test                                                    (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1721 };
1722
1723 TextureWrapClampToBorderCase::TextureWrapClampToBorderCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, TesterType tester, QueryType type)
1724         : TextureTest(testCtx, renderCtx, name, desc, target, tester, type)
1725 {
1726 }
1727
1728 void TextureWrapClampToBorderCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1729 {
1730         gl.glTexParameteri(m_target, m_pname, GL_CLAMP_TO_BORDER_EXT);
1731         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteri");
1732         verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_CLAMP_TO_BORDER_EXT, m_type);
1733
1734         gl.glTexParameteri(m_target, m_pname, GL_REPEAT);
1735         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteri");
1736
1737         gl.glTexParameterf(m_target, m_pname, (GLfloat)GL_CLAMP_TO_BORDER_EXT);
1738         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterf");
1739
1740         verifyStateTextureParamInteger(result, gl, m_target, m_pname, GL_CLAMP_TO_BORDER_EXT, m_type);
1741 }
1742
1743 class TextureBorderColorCase : public TextureTest
1744 {
1745 public:
1746                         TextureBorderColorCase  (tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, glw::GLenum target, QueryType type);
1747         void    test                                    (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1748 };
1749
1750 TextureBorderColorCase::TextureBorderColorCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, glw::GLenum target, QueryType type)
1751         : TextureTest(testCtx, renderCtx, name, desc, target, TESTER_TEXTURE_BORDER_COLOR, type)
1752 {
1753 }
1754
1755 void TextureBorderColorCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1756 {
1757         // border color is undefined if queried with pure type and was not set to pure value
1758         if (m_type == QUERY_TEXTURE_PARAM_INTEGER_VEC4 || m_type == QUERY_TEXTURE_PARAM_FLOAT_VEC4)
1759         {
1760                 const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1761                 verifyStateTextureParamFloatVec4(result, gl, m_target, m_pname, tcu::Vec4(0.0f, 0.0f, 0.0f, 0.0f), m_type);
1762         }
1763
1764         if (m_type == QUERY_TEXTURE_PARAM_PURE_INTEGER_VEC4)
1765         {
1766                 const tcu::ScopedLogSection     section                 (m_testCtx.getLog(), "Set", "Set");
1767                 const tcu::IVec4                        color                   (0x7FFFFFFF, -2, 3, -128);
1768
1769                 gl.glTexParameterIiv(m_target, m_pname, color.getPtr());
1770                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIiv");
1771
1772                 verifyStateTextureParamIntegerVec4(result, gl, m_target, m_pname, color, m_type);
1773         }
1774         else if (m_type == QUERY_TEXTURE_PARAM_PURE_UNSIGNED_INTEGER_VEC4)
1775         {
1776                 const tcu::ScopedLogSection     section                 (m_testCtx.getLog(), "Set", "Set");
1777                 const tcu::UVec4                        color                   (0x8000000ul, 2, 3, 128);
1778
1779                 gl.glTexParameterIuiv(m_target, m_pname, color.getPtr());
1780                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterIuiv");
1781
1782                 verifyStateTextureParamUnsignedIntegerVec4(result, gl, m_target, m_pname, color, m_type);
1783         }
1784         else
1785         {
1786                 DE_ASSERT(m_type == QUERY_TEXTURE_PARAM_INTEGER_VEC4 || m_type == QUERY_TEXTURE_PARAM_FLOAT_VEC4);
1787
1788                 const tcu::ScopedLogSection     section                 (m_testCtx.getLog(), "Set", "Set");
1789                 const tcu::Vec4                         color                   (0.25f, 1.0f, 0.0f, 0.77f);
1790                 const tcu::IVec4                        icolor                  (0x8000000ul, 0x7FFFFFFF, 0, 0x0FFFFFFF);
1791
1792                 gl.glTexParameterfv(m_target, m_pname, color.getPtr());
1793                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameterfv");
1794
1795                 verifyStateTextureParamFloatVec4(result, gl, m_target, m_pname, color, m_type);
1796
1797                 gl.glTexParameteriv(m_target, m_pname, icolor.getPtr());
1798                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glTexParameteriv");
1799
1800                 verifyStateTextureParamNormalizedI32Vec4(result, gl, m_target, m_pname, icolor, m_type);
1801         }
1802 }
1803
1804 class SamplerTest : public tcu::TestCase
1805 {
1806 public:
1807                                                 SamplerTest     (tcu::TestContext&                      testCtx,
1808                                                                          const glu::RenderContext&      renderCtx,
1809                                                                          const char*                            name,
1810                                                                          const char*                            desc,
1811                                                                          TesterType                                     tester,
1812                                                                          QueryType                                      type);
1813
1814         void                            init            (void);
1815         IterateResult           iterate         (void);
1816
1817         virtual void            test            (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const = 0;
1818
1819 protected:
1820         const glu::RenderContext&       m_renderCtx;
1821         const glw::GLenum                       m_pname;
1822         const TesterType                        m_tester;
1823         const QueryType                         m_type;
1824         glw::GLuint                                     m_target;
1825 };
1826
1827 SamplerTest::SamplerTest (tcu::TestContext&                     testCtx,
1828                                                   const glu::RenderContext&     renderCtx,
1829                                                   const char*                           name,
1830                                                   const char*                           desc,
1831                                                   TesterType                            tester,
1832                                                   QueryType                                     type)
1833         : TestCase              (testCtx, name, desc)
1834         , m_renderCtx   (renderCtx)
1835         , m_pname               (mapTesterToPname(tester))
1836         , m_tester              (tester)
1837         , m_type                (type)
1838         , m_target              (0)
1839 {
1840 }
1841
1842 void SamplerTest::init (void)
1843 {
1844         const de::UniquePtr<glu::ContextInfo>   ctxInfo         (glu::ContextInfo::create(m_renderCtx));
1845         RequiredExtensions                                              extensions;
1846
1847         // param
1848         if (!isCoreTextureParam(m_renderCtx.getType(), m_pname))
1849                 extensions.add(getTextureParamExtension(m_renderCtx.getType(), m_pname));
1850
1851         // query
1852         if (!isCoreQuery(m_renderCtx.getType(), m_type))
1853                 extensions.add(getQueryExtension(m_renderCtx.getType(), m_type));
1854
1855         // test type
1856         if (!isCoreTester(m_renderCtx.getType(), m_tester))
1857                 extensions.add(getTesterExtension(m_renderCtx.getType(), m_tester));
1858
1859         extensions.check(*ctxInfo);
1860 }
1861
1862 SamplerTest::IterateResult SamplerTest::iterate (void)
1863 {
1864         glu::CallLogWrapper             gl              (m_renderCtx.getFunctions(), m_testCtx.getLog());
1865         tcu::ResultCollector    result  (m_testCtx.getLog(), " // ERROR: ");
1866         glu::Sampler                    sampler (m_renderCtx);
1867
1868         gl.enableLogging(true);
1869
1870         m_target = *sampler;
1871         test(gl, result);
1872         m_target = 0;
1873
1874         result.setTestContextResult(m_testCtx);
1875         return STOP;
1876 }
1877
1878 class SamplerWrapCase : public SamplerTest
1879 {
1880 public:
1881                         SamplerWrapCase (tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, TesterType tester, QueryType type);
1882         void    test                    (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1883 };
1884
1885 SamplerWrapCase::SamplerWrapCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, TesterType tester, QueryType type)
1886         : SamplerTest(testCtx, renderCtx, name, desc, tester, type)
1887 {
1888 }
1889
1890 void SamplerWrapCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1891 {
1892         const bool isPureCase = isPureIntTester(m_tester) || isPureUintTester(m_tester);
1893
1894         if (!isPureCase)
1895         {
1896                 const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1897                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_REPEAT, m_type);
1898         }
1899
1900         {
1901                 const tcu::ScopedLogSection     section                 (m_testCtx.getLog(), "Set", "Set");
1902                 const GLenum                            wrapValues[]    = {GL_CLAMP_TO_EDGE, GL_REPEAT, GL_MIRRORED_REPEAT};
1903
1904                 if (isPureCase)
1905                 {
1906                         for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(wrapValues); ++ndx)
1907                         {
1908                                 if (isPureIntTester(m_tester))
1909                                 {
1910                                         const glw::GLint value = (glw::GLint)wrapValues[ndx];
1911                                         gl.glSamplerParameterIiv(m_target, m_pname, &value);
1912                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIiv");
1913                                 }
1914                                 else
1915                                 {
1916                                         DE_ASSERT(isPureUintTester(m_tester));
1917
1918                                         const glw::GLuint value = wrapValues[ndx];
1919                                         gl.glSamplerParameterIuiv(m_target, m_pname, &value);
1920                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIuiv");
1921                                 }
1922
1923                                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, wrapValues[ndx], m_type);
1924                         }
1925                 }
1926                 else
1927                 {
1928                         for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(wrapValues); ++ndx)
1929                         {
1930                                 gl.glSamplerParameteri(m_target, m_pname, wrapValues[ndx]);
1931                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameteri");
1932
1933                                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, wrapValues[ndx], m_type);
1934                         }
1935
1936                         //check unit conversions with float
1937
1938                         for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(wrapValues); ++ndx)
1939                         {
1940                                 gl.glSamplerParameterf(m_target, m_pname, (GLfloat)wrapValues[ndx]);
1941                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterf");
1942
1943                                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, wrapValues[ndx], m_type);
1944                         }
1945                 }
1946         }
1947 }
1948
1949 class SamplerFilterCase : public SamplerTest
1950 {
1951 public:
1952                         SamplerFilterCase       (tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, TesterType tester, QueryType type);
1953         void    test                            (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
1954 };
1955
1956 SamplerFilterCase::SamplerFilterCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, TesterType tester, QueryType type)
1957         : SamplerTest(testCtx, renderCtx, name, desc, tester, type)
1958 {
1959 }
1960
1961 void SamplerFilterCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
1962 {
1963         const bool                      isPureCase      = isPureIntTester(m_tester) || isPureUintTester(m_tester);
1964         const glw::GLenum       initial         = (m_pname == GL_TEXTURE_MAG_FILTER) ? (GL_LINEAR)
1965                                                                         : (m_pname == GL_TEXTURE_MIN_FILTER) ? (GL_NEAREST_MIPMAP_LINEAR)
1966                                                                         : (0);
1967
1968         if (!isPureCase)
1969         {
1970                 const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
1971                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, initial, m_type);
1972         }
1973
1974         {
1975                 const tcu::ScopedLogSection     section         (m_testCtx.getLog(), "Set", "Set");
1976                 std::vector<GLenum>                     values;
1977
1978                 values.push_back(GL_NEAREST);
1979                 values.push_back(GL_LINEAR);
1980                 if (m_pname == GL_TEXTURE_MIN_FILTER)
1981                 {
1982                         values.push_back(GL_NEAREST_MIPMAP_NEAREST);
1983                         values.push_back(GL_NEAREST_MIPMAP_LINEAR);
1984                         values.push_back(GL_LINEAR_MIPMAP_NEAREST);
1985                         values.push_back(GL_LINEAR_MIPMAP_LINEAR);
1986                 }
1987
1988                 if (isPureCase)
1989                 {
1990                         for (int ndx = 0; ndx < (int)values.size(); ++ndx)
1991                         {
1992                                 if (isPureIntTester(m_tester))
1993                                 {
1994                                         const glw::GLint value = (glw::GLint)values[ndx];
1995                                         gl.glSamplerParameterIiv(m_target, m_pname, &value);
1996                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIiv");
1997                                 }
1998                                 else
1999                                 {
2000                                         DE_ASSERT(isPureUintTester(m_tester));
2001
2002                                         const glw::GLuint value = values[ndx];
2003                                         gl.glSamplerParameterIuiv(m_target, m_pname, &value);
2004                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIuiv");
2005                                 }
2006
2007                                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, values[ndx], m_type);
2008                         }
2009                 }
2010                 else
2011                 {
2012                         for (int ndx = 0; ndx < (int)values.size(); ++ndx)
2013                         {
2014                                 gl.glSamplerParameteri(m_target, m_pname, values[ndx]);
2015                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameteri");
2016
2017                                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, values[ndx], m_type);
2018                         }
2019
2020                         //check unit conversions with float
2021
2022                         for (int ndx = 0; ndx < (int)values.size(); ++ndx)
2023                         {
2024                                 gl.glSamplerParameterf(m_target, m_pname, (GLfloat)values[ndx]);
2025                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterf");
2026
2027                                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, values[ndx], m_type);
2028                         }
2029                 }
2030         }
2031 }
2032
2033 class SamplerLODCase : public SamplerTest
2034 {
2035 public:
2036                         SamplerLODCase  (tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, TesterType tester, QueryType type);
2037         void    test                    (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
2038 };
2039
2040 SamplerLODCase::SamplerLODCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, TesterType tester, QueryType type)
2041         : SamplerTest(testCtx, renderCtx, name, desc, tester, type)
2042 {
2043 }
2044
2045 void SamplerLODCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
2046 {
2047         const bool      isPureCase              = isPureIntTester(m_tester) || isPureUintTester(m_tester);
2048         const int       initialValue    = (m_pname == GL_TEXTURE_MIN_LOD) ? (-1000)
2049                                                                 : (m_pname == GL_TEXTURE_MAX_LOD) ? (1000)
2050                                                                 : (-1);
2051
2052         if ((querySupportsSigned(m_type) || initialValue >= 0) && !isPureCase)
2053         {
2054                 const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
2055                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, initialValue, m_type);
2056         }
2057
2058         {
2059                 const tcu::ScopedLogSection     section                 (m_testCtx.getLog(), "Set", "Set");
2060                 const int                                       numIterations   = 20;
2061                 de::Random                                      rnd                             (0xabcdef);
2062
2063                 if (isPureCase)
2064                 {
2065                         if (isPureIntTester(m_tester))
2066                         {
2067                                 for (int ndx = 0; ndx < numIterations; ++ndx)
2068                                 {
2069                                         const GLint ref = rnd.getInt(-1000, 1000);
2070
2071                                         gl.glSamplerParameterIiv(m_target, m_pname, &ref);
2072                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIiv");
2073
2074                                         verifyStateSamplerParamFloat(result, gl, m_target, m_pname, (float)ref, m_type);
2075                                 }
2076                         }
2077                         else
2078                         {
2079                                 DE_ASSERT(isPureUintTester(m_tester));
2080
2081                                 for (int ndx = 0; ndx < numIterations; ++ndx)
2082                                 {
2083                                         const GLuint ref = (glw::GLuint)rnd.getInt(0, 1000);
2084
2085                                         gl.glSamplerParameterIuiv(m_target, m_pname, &ref);
2086                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIuiv");
2087
2088                                         verifyStateSamplerParamFloat(result, gl, m_target, m_pname, (float)ref, m_type);
2089                                 }
2090                         }
2091                 }
2092                 else
2093                 {
2094                         const int minLimit = (querySupportsSigned(m_type)) ? (-1000) : (0);
2095
2096                         for (int ndx = 0; ndx < numIterations; ++ndx)
2097                         {
2098                                 const GLfloat ref = rnd.getFloat((float)minLimit, 1000.f);
2099
2100                                 gl.glSamplerParameterf(m_target, m_pname, ref);
2101                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterf");
2102
2103                                 verifyStateSamplerParamFloat(result, gl, m_target, m_pname, ref, m_type);
2104                         }
2105
2106                         // check unit conversions with int
2107
2108                         for (int ndx = 0; ndx < numIterations; ++ndx)
2109                         {
2110                                 const GLint ref = rnd.getInt(minLimit, 1000);
2111
2112                                 gl.glSamplerParameteri(m_target, m_pname, ref);
2113                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameteri");
2114
2115                                 verifyStateSamplerParamFloat(result, gl, m_target, m_pname, (float)ref, m_type);
2116                         }
2117                 }
2118         }
2119 }
2120
2121 class SamplerCompareModeCase : public SamplerTest
2122 {
2123 public:
2124                         SamplerCompareModeCase  (tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, TesterType tester, QueryType type);
2125         void    test                                    (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
2126 };
2127
2128 SamplerCompareModeCase::SamplerCompareModeCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, TesterType tester, QueryType type)
2129         : SamplerTest(testCtx, renderCtx, name, desc, tester, type)
2130 {
2131 }
2132
2133 void SamplerCompareModeCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
2134 {
2135         const bool isPureCase = isPureIntTester(m_tester) || isPureUintTester(m_tester);
2136
2137         if (!isPureCase)
2138         {
2139                 const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
2140                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_NONE, m_type);
2141         }
2142
2143         {
2144                 const tcu::ScopedLogSection     section         (m_testCtx.getLog(), "Set", "Set");
2145                 const GLenum                            modes[]         = {GL_COMPARE_REF_TO_TEXTURE, GL_NONE};
2146
2147                 if (isPureCase)
2148                 {
2149                         for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(modes); ++ndx)
2150                         {
2151                                 if (isPureIntTester(m_tester))
2152                                 {
2153                                         const glw::GLint value = (glw::GLint)modes[ndx];
2154                                         gl.glSamplerParameterIiv(m_target, m_pname, &value);
2155                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIiv");
2156                                 }
2157                                 else
2158                                 {
2159                                         DE_ASSERT(isPureUintTester(m_tester));
2160
2161                                         const glw::GLuint value = modes[ndx];
2162                                         gl.glSamplerParameterIuiv(m_target, m_pname, &value);
2163                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIuiv");
2164                                 }
2165
2166                                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, modes[ndx], m_type);
2167                         }
2168                 }
2169                 else
2170                 {
2171                         for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(modes); ++ndx)
2172                         {
2173                                 gl.glSamplerParameteri(m_target, m_pname, modes[ndx]);
2174                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameteri");
2175
2176                                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, modes[ndx], m_type);
2177                         }
2178
2179                         //check unit conversions with float
2180
2181                         for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(modes); ++ndx)
2182                         {
2183                                 gl.glSamplerParameterf(m_target, m_pname, (GLfloat)modes[ndx]);
2184                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterf");
2185
2186                                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, modes[ndx], m_type);
2187                         }
2188                 }
2189         }
2190 }
2191
2192 class SamplerCompareFuncCase : public SamplerTest
2193 {
2194 public:
2195                         SamplerCompareFuncCase  (tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, TesterType tester, QueryType type);
2196         void    test                                    (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
2197 };
2198
2199 SamplerCompareFuncCase::SamplerCompareFuncCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, TesterType tester, QueryType type)
2200         : SamplerTest(testCtx, renderCtx, name, desc, tester, type)
2201 {
2202 }
2203
2204 void SamplerCompareFuncCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
2205 {
2206         const bool isPureCase = isPureIntTester(m_tester) || isPureUintTester(m_tester);
2207
2208         if (!isPureCase)
2209         {
2210                 const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
2211                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_LEQUAL, m_type);
2212         }
2213
2214         {
2215                 const tcu::ScopedLogSection     section                 (m_testCtx.getLog(), "Set", "Set");
2216                 const GLenum                            compareFuncs[]  = {GL_LEQUAL, GL_GEQUAL, GL_LESS, GL_GREATER, GL_EQUAL, GL_NOTEQUAL, GL_ALWAYS, GL_NEVER};
2217
2218                 if (isPureCase)
2219                 {
2220                         for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(compareFuncs); ++ndx)
2221                         {
2222                                 if (isPureIntTester(m_tester))
2223                                 {
2224                                         const glw::GLint value = (glw::GLint)compareFuncs[ndx];
2225                                         gl.glSamplerParameterIiv(m_target, m_pname, &value);
2226                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIiv");
2227                                 }
2228                                 else
2229                                 {
2230                                         DE_ASSERT(isPureUintTester(m_tester));
2231
2232                                         const glw::GLuint value = compareFuncs[ndx];
2233                                         gl.glSamplerParameterIuiv(m_target, m_pname, &value);
2234                                         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIuiv");
2235                                 }
2236
2237                                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, compareFuncs[ndx], m_type);
2238                         }
2239                 }
2240                 else
2241                 {
2242                         for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(compareFuncs); ++ndx)
2243                         {
2244                                 gl.glSamplerParameteri(m_target, m_pname, compareFuncs[ndx]);
2245                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameteri");
2246
2247                                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, compareFuncs[ndx], m_type);
2248                         }
2249
2250                         //check unit conversions with float
2251
2252                         for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(compareFuncs); ++ndx)
2253                         {
2254                                 gl.glSamplerParameterf(m_target, m_pname, (GLfloat)compareFuncs[ndx]);
2255                                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterf");
2256
2257                                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, compareFuncs[ndx], m_type);
2258                         }
2259                 }
2260         }
2261 }
2262
2263 class SamplerWrapClampToBorderCase : public SamplerTest
2264 {
2265 public:
2266                         SamplerWrapClampToBorderCase    (tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, TesterType tester, QueryType type);
2267         void    test                                                    (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
2268 };
2269
2270 SamplerWrapClampToBorderCase::SamplerWrapClampToBorderCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, TesterType tester, QueryType type)
2271         : SamplerTest(testCtx, renderCtx, name, desc, tester, type)
2272 {
2273 }
2274
2275 void SamplerWrapClampToBorderCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
2276 {
2277         gl.glSamplerParameteri(m_target, m_pname, GL_CLAMP_TO_BORDER_EXT);
2278         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameteri");
2279         verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_CLAMP_TO_BORDER_EXT, m_type);
2280
2281         gl.glSamplerParameteri(m_target, m_pname, GL_REPEAT);
2282         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameteri");
2283
2284         gl.glSamplerParameterf(m_target, m_pname, (GLfloat)GL_CLAMP_TO_BORDER_EXT);
2285         GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterf");
2286
2287         verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_CLAMP_TO_BORDER_EXT, m_type);
2288 }
2289
2290 class SamplerSRGBDecodeCase : public SamplerTest
2291 {
2292 public:
2293                         SamplerSRGBDecodeCase   (tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, TesterType tester, QueryType type);
2294         void    test                                    (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
2295 };
2296
2297 SamplerSRGBDecodeCase::SamplerSRGBDecodeCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, TesterType tester, QueryType type)
2298         : SamplerTest(testCtx, renderCtx, name, desc, tester, type)
2299 {
2300 }
2301
2302 void SamplerSRGBDecodeCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
2303 {
2304         const bool isPureCase = isPureIntTester(m_tester) || isPureUintTester(m_tester);
2305
2306         if (!isPureCase)
2307         {
2308                 const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
2309                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_DECODE_EXT, m_type);
2310         }
2311
2312         {
2313                 const tcu::ScopedLogSection     section                 (m_testCtx.getLog(), "Toggle", "Toggle");
2314                 const glw::GLint                        decodeInt               = GL_DECODE_EXT;
2315                 const glw::GLfloat                      decodeFloat             = (glw::GLfloat)GL_DECODE_EXT;
2316
2317                 gl.glSamplerParameteri(m_target, m_pname, GL_SKIP_DECODE_EXT);
2318                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
2319                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_SKIP_DECODE_EXT, m_type);
2320
2321                 gl.glSamplerParameteriv(m_target, m_pname, &decodeInt);
2322                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
2323                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_DECODE_EXT, m_type);
2324
2325                 gl.glSamplerParameterf(m_target, m_pname, GL_SKIP_DECODE_EXT);
2326                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
2327                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_SKIP_DECODE_EXT, m_type);
2328
2329                 gl.glSamplerParameterfv(m_target, m_pname, &decodeFloat);
2330                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "set state");
2331                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_DECODE_EXT, m_type);
2332         }
2333
2334         if (isPureIntTester(m_tester))
2335         {
2336                 const glw::GLint skipDecode     = GL_SKIP_DECODE_EXT;
2337                 const glw::GLint decode         = GL_DECODE_EXT;
2338
2339                 gl.glSamplerParameterIiv(m_target, m_pname, &skipDecode);
2340                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIiv");
2341                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_SKIP_DECODE_EXT, m_type);
2342
2343                 gl.glSamplerParameterIiv(m_target, m_pname, &decode);
2344                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIiv");
2345                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_DECODE_EXT, m_type);
2346         }
2347
2348         if (isPureUintTester(m_tester))
2349         {
2350                 const glw::GLuint skipDecode    = GL_SKIP_DECODE_EXT;
2351                 const glw::GLuint decode                = GL_DECODE_EXT;
2352
2353                 gl.glSamplerParameterIuiv(m_target, m_pname, &skipDecode);
2354                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIuiv");
2355                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_SKIP_DECODE_EXT, m_type);
2356
2357                 gl.glSamplerParameterIuiv(m_target, m_pname, &decode);
2358                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIuiv");
2359                 verifyStateSamplerParamInteger(result, gl, m_target, m_pname, GL_DECODE_EXT, m_type);
2360         }
2361 }
2362
2363 class SamplerBorderColorCase : public SamplerTest
2364 {
2365 public:
2366                         SamplerBorderColorCase  (tcu::TestContext& testCtx, const glu::RenderContext& renderContext, const char* name, const char* desc, QueryType type);
2367         void    test                                    (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const;
2368 };
2369
2370 SamplerBorderColorCase::SamplerBorderColorCase (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const char* name, const char* desc, QueryType type)
2371         : SamplerTest(testCtx, renderCtx, name, desc, TESTER_TEXTURE_BORDER_COLOR, type)
2372 {
2373         DE_ASSERT(m_type == QUERY_SAMPLER_PARAM_INTEGER_VEC4                                    ||
2374                           m_type == QUERY_SAMPLER_PARAM_FLOAT_VEC4                                              ||
2375                           m_type == QUERY_SAMPLER_PARAM_PURE_INTEGER_VEC4                               ||
2376                           m_type == QUERY_SAMPLER_PARAM_PURE_UNSIGNED_INTEGER_VEC4);
2377 }
2378
2379 void SamplerBorderColorCase::test (glu::CallLogWrapper& gl, tcu::ResultCollector& result) const
2380 {
2381         // border color is undefined if queried with pure type and was not set to pure value
2382         if (m_type == QUERY_SAMPLER_PARAM_INTEGER_VEC4 || m_type == QUERY_SAMPLER_PARAM_FLOAT_VEC4)
2383         {
2384                 const tcu::ScopedLogSection section(m_testCtx.getLog(), "Initial", "Initial");
2385                 verifyStateSamplerParamFloatVec4(result, gl, m_target, m_pname, tcu::Vec4(0.0f, 0.0f, 0.0f, 0.0f), m_type);
2386         }
2387
2388         if (m_type == QUERY_SAMPLER_PARAM_PURE_INTEGER_VEC4)
2389         {
2390                 const tcu::ScopedLogSection     section                 (m_testCtx.getLog(), "Set", "Set");
2391                 const tcu::IVec4                        color                   (0x7FFFFFFF, -2, 3, -128);
2392
2393                 gl.glSamplerParameterIiv(m_target, m_pname, color.getPtr());
2394                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIiv");
2395
2396                 verifyStateSamplerParamIntegerVec4(result, gl, m_target, m_pname, color, m_type);
2397         }
2398         else if (m_type == QUERY_SAMPLER_PARAM_PURE_UNSIGNED_INTEGER_VEC4)
2399         {
2400                 const tcu::ScopedLogSection     section                 (m_testCtx.getLog(), "Set", "Set");
2401                 const tcu::UVec4                        color                   (0x8000000ul, 2, 3, 128);
2402
2403                 gl.glSamplerParameterIuiv(m_target, m_pname, color.getPtr());
2404                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterIuiv");
2405
2406                 verifyStateSamplerParamUnsignedIntegerVec4(result, gl, m_target, m_pname, color, m_type);
2407         }
2408         else
2409         {
2410                 DE_ASSERT(m_type == QUERY_SAMPLER_PARAM_INTEGER_VEC4 || m_type == QUERY_SAMPLER_PARAM_FLOAT_VEC4);
2411
2412                 const tcu::ScopedLogSection     section                 (m_testCtx.getLog(), "Set", "Set");
2413                 const tcu::Vec4                         color                   (0.25f, 1.0f, 0.0f, 0.77f);
2414                 const tcu::IVec4                        icolor                  (0x8000000ul, 0x7FFFFFFF, 0, 0x0FFFFFFF);
2415
2416                 gl.glSamplerParameterfv(m_target, m_pname, color.getPtr());
2417                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameterfv");
2418
2419                 verifyStateSamplerParamFloatVec4(result, gl, m_target, m_pname, color, m_type);
2420
2421                 gl.glSamplerParameteriv(m_target, m_pname, icolor.getPtr());
2422                 GLS_COLLECT_GL_ERROR(result, gl.glGetError(), "glSamplerParameteriv");
2423
2424                 verifyStateSamplerParamNormalizedI32Vec4(result, gl, m_target, m_pname, icolor, m_type);
2425         }
2426 }
2427
2428 } // anonymous
2429
2430 bool isLegalTesterForTarget (glw::GLenum target, TesterType tester)
2431 {
2432         // no 3d filtering on 2d targets
2433         if ((tester == TESTER_TEXTURE_WRAP_R || tester == TESTER_TEXTURE_WRAP_R_CLAMP_TO_BORDER) &&  target != GL_TEXTURE_3D)
2434                 return false;
2435
2436         // no sampling on multisample
2437         if (isMultisampleTarget(target) && isSamplerStateTester(tester))
2438                 return false;
2439
2440         // no states in buffer
2441         if (target == GL_TEXTURE_BUFFER)
2442                 return false;
2443
2444         return true;
2445 }
2446
2447 bool isMultisampleTarget (glw::GLenum target)
2448 {
2449         return  target == GL_TEXTURE_2D_MULTISAMPLE                     ||
2450                         target == GL_TEXTURE_2D_MULTISAMPLE_ARRAY;
2451 }
2452
2453 bool isSamplerStateTester (TesterType tester)
2454 {
2455         return  tester == TESTER_TEXTURE_WRAP_S                                 ||
2456                         tester == TESTER_TEXTURE_WRAP_T                                 ||
2457                         tester == TESTER_TEXTURE_WRAP_R                                 ||
2458                         tester == TESTER_TEXTURE_MAG_FILTER                             ||
2459                         tester == TESTER_TEXTURE_MIN_FILTER                             ||
2460                         tester == TESTER_TEXTURE_MIN_LOD                                ||
2461                         tester == TESTER_TEXTURE_MAX_LOD                                ||
2462                         tester == TESTER_TEXTURE_COMPARE_MODE                   ||
2463                         tester == TESTER_TEXTURE_COMPARE_FUNC                   ||
2464                         tester == TESTER_TEXTURE_SRGB_DECODE_EXT                ||
2465                         tester == TESTER_TEXTURE_BORDER_COLOR                   ||
2466                         tester == TESTER_TEXTURE_WRAP_S_CLAMP_TO_BORDER ||
2467                         tester == TESTER_TEXTURE_WRAP_T_CLAMP_TO_BORDER ||
2468                         tester == TESTER_TEXTURE_WRAP_R_CLAMP_TO_BORDER;
2469 }
2470
2471 tcu::TestCase* createIsTextureTest (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const std::string& name, const std::string& description, glw::GLenum target)
2472 {
2473         return new IsTextureCase(testCtx, renderCtx, name.c_str(), description.c_str(), target);
2474 }
2475
2476 tcu::TestCase* createTexParamTest (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const std::string& name, const std::string& description, QueryType queryType, glw::GLenum target, TesterType tester)
2477 {
2478         if (isMultisampleTarget(target) && isSamplerStateTester(tester))
2479         {
2480                 DE_FATAL("Multisample textures have no sampler state");
2481                 return DE_NULL;
2482         }
2483         if (target == GL_TEXTURE_BUFFER)
2484         {
2485                 DE_FATAL("Buffer textures have no texture state");
2486                 return DE_NULL;
2487         }
2488         if (target != GL_TEXTURE_3D && mapTesterToPname(tester) == GL_TEXTURE_WRAP_R)
2489         {
2490                 DE_FATAL("Only 3D textures have wrap r filter");
2491                 return DE_NULL;
2492         }
2493
2494 #define CASE_ALL_SETTERS(X) case X: case X ## _SET_PURE_INT: case X ## _SET_PURE_UINT
2495
2496         switch (tester)
2497         {
2498                 CASE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_R):
2499                 CASE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_G):
2500                 CASE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_B):
2501                 CASE_ALL_SETTERS(TESTER_TEXTURE_SWIZZLE_A):
2502                         return new TextureSwizzleCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, tester, queryType);
2503
2504                 CASE_ALL_SETTERS(TESTER_TEXTURE_WRAP_S):
2505                 CASE_ALL_SETTERS(TESTER_TEXTURE_WRAP_T):
2506                 CASE_ALL_SETTERS(TESTER_TEXTURE_WRAP_R):
2507                         return new TextureWrapCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, tester, queryType);
2508
2509                 CASE_ALL_SETTERS(TESTER_TEXTURE_MAG_FILTER):
2510                 CASE_ALL_SETTERS(TESTER_TEXTURE_MIN_FILTER):
2511                         return new TextureFilterCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, tester, queryType);
2512
2513                 CASE_ALL_SETTERS(TESTER_TEXTURE_MIN_LOD):
2514                 CASE_ALL_SETTERS(TESTER_TEXTURE_MAX_LOD):
2515                         return new TextureLODCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, tester, queryType);
2516
2517                 CASE_ALL_SETTERS(TESTER_TEXTURE_BASE_LEVEL):
2518                 CASE_ALL_SETTERS(TESTER_TEXTURE_MAX_LEVEL):
2519                         return new TextureLevelCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, tester, queryType);
2520
2521                 CASE_ALL_SETTERS(TESTER_TEXTURE_COMPARE_MODE):
2522                         return new TextureCompareModeCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, tester, queryType);
2523
2524                 CASE_ALL_SETTERS(TESTER_TEXTURE_COMPARE_FUNC):
2525                         return new TextureCompareFuncCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, tester, queryType);
2526
2527                 case TESTER_TEXTURE_IMMUTABLE_LEVELS:
2528                         return new TextureImmutableLevelsCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, queryType);
2529
2530                 case TESTER_TEXTURE_IMMUTABLE_FORMAT:
2531                         return new TextureImmutableFormatCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, queryType);
2532
2533                 case TESTER_TEXTURE_WRAP_S_CLAMP_TO_BORDER:
2534                 case TESTER_TEXTURE_WRAP_T_CLAMP_TO_BORDER:
2535                 case TESTER_TEXTURE_WRAP_R_CLAMP_TO_BORDER:
2536                         return new TextureWrapClampToBorderCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, tester, queryType);
2537
2538                 CASE_ALL_SETTERS(TESTER_DEPTH_STENCIL_TEXTURE_MODE):
2539                         return new DepthStencilModeCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, tester, queryType);
2540
2541                 CASE_ALL_SETTERS(TESTER_TEXTURE_SRGB_DECODE_EXT):
2542                         return new TextureSRGBDecodeCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, tester, queryType);
2543
2544                 case TESTER_TEXTURE_BORDER_COLOR:
2545                         return new TextureBorderColorCase(testCtx, renderCtx, name.c_str(), description.c_str(), target, queryType);
2546
2547                 default:
2548                         break;
2549         }
2550
2551 #undef CASE_ALL_SETTERS
2552
2553         DE_ASSERT(false);
2554         return DE_NULL;
2555 }
2556
2557 tcu::TestCase* createSamplerParamTest (tcu::TestContext& testCtx, const glu::RenderContext& renderCtx, const std::string& name, const std::string& description, StateQueryUtil::QueryType queryType, TesterType tester)
2558 {
2559 #define CASE_ALL_SETTERS(X) case X: case X ## _SET_PURE_INT: case X ## _SET_PURE_UINT
2560
2561         switch (tester)
2562         {
2563                 CASE_ALL_SETTERS(TESTER_TEXTURE_WRAP_S):
2564                 CASE_ALL_SETTERS(TESTER_TEXTURE_WRAP_T):
2565                 CASE_ALL_SETTERS(TESTER_TEXTURE_WRAP_R):
2566                         return new SamplerWrapCase(testCtx, renderCtx, name.c_str(), description.c_str(), tester, queryType);
2567
2568                 CASE_ALL_SETTERS(TESTER_TEXTURE_MAG_FILTER):
2569                 CASE_ALL_SETTERS(TESTER_TEXTURE_MIN_FILTER):
2570                         return new SamplerFilterCase(testCtx, renderCtx, name.c_str(), description.c_str(), tester, queryType);
2571
2572                 CASE_ALL_SETTERS(TESTER_TEXTURE_MIN_LOD):
2573                 CASE_ALL_SETTERS(TESTER_TEXTURE_MAX_LOD):
2574                         return new SamplerLODCase(testCtx, renderCtx, name.c_str(), description.c_str(), tester, queryType);
2575
2576                 CASE_ALL_SETTERS(TESTER_TEXTURE_COMPARE_MODE):
2577                         return new SamplerCompareModeCase(testCtx, renderCtx, name.c_str(), description.c_str(), tester, queryType);
2578
2579                 CASE_ALL_SETTERS(TESTER_TEXTURE_COMPARE_FUNC):
2580                         return new SamplerCompareFuncCase(testCtx, renderCtx, name.c_str(), description.c_str(), tester, queryType);
2581
2582                 case TESTER_TEXTURE_WRAP_S_CLAMP_TO_BORDER:
2583                 case TESTER_TEXTURE_WRAP_T_CLAMP_TO_BORDER:
2584                 case TESTER_TEXTURE_WRAP_R_CLAMP_TO_BORDER:
2585                         return new SamplerWrapClampToBorderCase(testCtx, renderCtx, name.c_str(), description.c_str(), tester, queryType);
2586
2587                 CASE_ALL_SETTERS(TESTER_TEXTURE_SRGB_DECODE_EXT):
2588                         return new SamplerSRGBDecodeCase(testCtx, renderCtx, name.c_str(), description.c_str(), tester, queryType);
2589
2590                 case TESTER_TEXTURE_BORDER_COLOR:
2591                         return new SamplerBorderColorCase(testCtx, renderCtx, name.c_str(), description.c_str(), queryType);
2592
2593                 default:
2594                         break;
2595         }
2596
2597 #undef CASE_ALL_SETTERS
2598
2599         DE_ASSERT(false);
2600         return DE_NULL;
2601 }
2602
2603 } // TextureStateQueryTests
2604 } // gls
2605 } // deqp