Add tests for findLSB/findMSB applied to a uniform value.
authorRaymond Chiu <chiur@google.com>
Tue, 13 Feb 2018 23:13:47 +0000 (15:13 -0800)
committerRaymond Chiu <chiur@google.com>
Wed, 7 Mar 2018 01:06:35 +0000 (17:06 -0800)
Ensure that findLSB/findMSB work correctly when:

Argument is a uniform value, of various precisions
Result is written out directly
Result is compared to a fixed value

Components: AOSP
Bug: 71875560
New Tests: dEQP-GLES31.functional.shaders.builtin_functions.uniform.*

Merged-In: I0dc83b291d1ecaed5e451b76e4b41827116218c6
Change-Id: Iafd784deaf22dd86b6bfc955af967e4482d9e95c

Android.mk
android/cts/master/gles31-master.txt
modules/gles31/functional/CMakeLists.txt
modules/gles31/functional/es31fFunctionalTests.cpp
modules/gles31/functional/es31fShaderUniformIntegerFunctionTests.cpp [new file with mode: 0644]
modules/gles31/functional/es31fShaderUniformIntegerFunctionTests.hpp [new file with mode: 0644]

index ae8de10c56d255ecbb2109f1b14583a06f078cd5..3e82f4983c0d958dbe4fc5faecec9171b29473b9 100644 (file)
@@ -880,6 +880,7 @@ LOCAL_SRC_FILES := \
        modules/gles31/functional/es31fShaderSharedVarTests.cpp \
        modules/gles31/functional/es31fShaderStateQueryTests.cpp \
        modules/gles31/functional/es31fShaderTextureSizeTests.cpp \
+       modules/gles31/functional/es31fShaderUniformIntegerFunctionTests.cpp \
        modules/gles31/functional/es31fStencilTexturingTests.cpp \
        modules/gles31/functional/es31fSynchronizationTests.cpp \
        modules/gles31/functional/es31fTessellationGeometryInteractionTests.cpp \
index 34db6226efb92f479548aa7fb3cc00997e4e725b..bee36efc1ac1bb8f8d38f26ee84c812f75220b84 100644 (file)
@@ -2094,6 +2094,78 @@ dEQP-GLES31.functional.shaders.builtin_functions.integer.findmsb.uvec4_highp_geo
 dEQP-GLES31.functional.shaders.builtin_functions.integer.findmsb.uvec4_highp_tess_control
 dEQP-GLES31.functional.shaders.builtin_functions.integer.findmsb.uvec4_highp_tess_eval
 dEQP-GLES31.functional.shaders.builtin_functions.integer.findmsb.uvec4_highp_compute
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBZero.lowp_vertex
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBZero.lowp_fragment
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBZero.lowp_geometry
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBZero.lowp_tess_control
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBZero.lowp_tess_eval
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBZero.lowp_compute
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBZero.mediump_vertex
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBZero.mediump_fragment
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBZero.mediump_geometry
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBZero.mediump_tess_control
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBZero.mediump_tess_eval
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBZero.mediump_compute
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBZero.highp_vertex
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBZero.highp_fragment
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBZero.highp_geometry
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBZero.highp_tess_control
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBZero.highp_tess_eval
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBZero.highp_compute
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBMinusOne.lowp_vertex
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBMinusOne.lowp_fragment
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBMinusOne.lowp_geometry
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBMinusOne.lowp_tess_control
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBMinusOne.lowp_tess_eval
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBMinusOne.lowp_compute
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBMinusOne.mediump_vertex
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBMinusOne.mediump_fragment
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBMinusOne.mediump_geometry
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBMinusOne.mediump_tess_control
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBMinusOne.mediump_tess_eval
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBMinusOne.mediump_compute
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBMinusOne.highp_vertex
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBMinusOne.highp_fragment
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBMinusOne.highp_geometry
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBMinusOne.highp_tess_control
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBMinusOne.highp_tess_eval
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findMSBMinusOne.highp_compute
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBZero.lowp_vertex
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBZero.lowp_fragment
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBZero.lowp_geometry
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBZero.lowp_tess_control
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBZero.lowp_tess_eval
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBZero.lowp_compute
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBZero.mediump_vertex
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBZero.mediump_fragment
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBZero.mediump_geometry
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBZero.mediump_tess_control
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBZero.mediump_tess_eval
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBZero.mediump_compute
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBZero.highp_vertex
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBZero.highp_fragment
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBZero.highp_geometry
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBZero.highp_tess_control
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBZero.highp_tess_eval
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBZero.highp_compute
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBMinusOne.lowp_vertex
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBMinusOne.lowp_fragment
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBMinusOne.lowp_geometry
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBMinusOne.lowp_tess_control
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBMinusOne.lowp_tess_eval
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBMinusOne.lowp_compute
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBMinusOne.mediump_vertex
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBMinusOne.mediump_fragment
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBMinusOne.mediump_geometry
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBMinusOne.mediump_tess_control
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBMinusOne.mediump_tess_eval
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBMinusOne.mediump_compute
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBMinusOne.highp_vertex
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBMinusOne.highp_fragment
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBMinusOne.highp_geometry
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBMinusOne.highp_tess_control
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBMinusOne.highp_tess_eval
+dEQP-GLES31.functional.shaders.builtin_functions.uniform.findLSBMinusOne.highp_compute
 dEQP-GLES31.functional.shaders.builtin_functions.texture_size.samples_1_texture_2d
 dEQP-GLES31.functional.shaders.builtin_functions.texture_size.samples_4_texture_2d
 dEQP-GLES31.functional.shaders.builtin_functions.texture_size.samples_1_texture_2d_array
index a4ac348f9770e1bce1a1f14d55a818b2ba80272a..cfaa31224e804d759e6bc8a3ce09680c6f66ea56 100644 (file)
@@ -193,6 +193,8 @@ set(DEQP_GLES31_FUNCTIONAL_SRCS
        es31fShaderFramebufferFetchTests.hpp
        es31fNegativeShaderFramebufferFetchTests.cpp
        es31fNegativeShaderFramebufferFetchTests.hpp
+       es31fShaderUniformIntegerFunctionTests.cpp
+       es31fShaderUniformIntegerFunctionTests.hpp
        )
 
 add_library(deqp-gles31-functional STATIC ${DEQP_GLES31_FUNCTIONAL_SRCS})
index 3fb407e37c4ff0211a7272f5894b9eaa8ec24e6e..325ddac3d28a553e3ad9314a011fdfad36e82841 100644 (file)
@@ -92,6 +92,7 @@
 #include "es31fSRGBDecodeTests.hpp"
 #include "es31fDrawElementsBaseVertexTests.hpp"
 #include "es31fShaderFramebufferFetchTests.hpp"
+#include "es31fShaderUniformIntegerFunctionTests.hpp"
 
 namespace deqp
 {
@@ -153,11 +154,12 @@ public:
 
        void init (void)
        {
-               addChild(new ShaderCommonFunctionTests  (m_context));
-               addChild(new ShaderPackingFunctionTests (m_context));
-               addChild(new ShaderIntegerFunctionTests (m_context));
-               addChild(new ShaderTextureSizeTests             (m_context));
-               addChild(createBuiltinPrecisionTests    (m_context));
+               addChild(new ShaderCommonFunctionTests                  (m_context));
+               addChild(new ShaderPackingFunctionTests                 (m_context));
+               addChild(new ShaderIntegerFunctionTests                 (m_context));
+               addChild(new ShaderUniformIntegerFunctionTests  (m_context));
+               addChild(new ShaderTextureSizeTests                             (m_context));
+               addChild(createBuiltinPrecisionTests                    (m_context));
        }
 };
 
diff --git a/modules/gles31/functional/es31fShaderUniformIntegerFunctionTests.cpp b/modules/gles31/functional/es31fShaderUniformIntegerFunctionTests.cpp
new file mode 100644 (file)
index 0000000..30f3391
--- /dev/null
@@ -0,0 +1,266 @@
+/*-------------------------------------------------------------------------
+ * drawElements Quality Program OpenGL ES 3.1 Module
+ * -------------------------------------------------
+ *
+ * Copyright 2018 The Android Open Source Project
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ *//*!
+ * \file
+ * \brief Built-in function tests for uniform constants.
+ *//*--------------------------------------------------------------------*/
+
+#include "es31fShaderUniformIntegerFunctionTests.hpp"
+#include "glsShaderExecUtil.hpp"
+#include "glwFunctions.hpp"
+#include "tcuTestLog.hpp"
+#include <iostream>
+
+namespace deqp
+{
+namespace gles31
+{
+namespace Functional
+{
+
+using std::vector;
+using std::string;
+using tcu::TestLog;
+using namespace gls::ShaderExecUtil;
+
+class UniformIntegerFunctionCase : public TestCase
+{
+public:
+                                                               UniformIntegerFunctionCase                              (Context& context, const char* description, int inputValue, glu::Precision precision, glu::ShaderType shaderType);
+                                                               ~UniformIntegerFunctionCase                             (void);
+
+       void                                            init                                                                    (void);
+       void                                            deinit                                                                  (void);
+       IterateResult                           iterate                                                                 (void);
+       virtual const char*                     getFunctionName()                                               = 0;
+       virtual int                                     computeExpectedResult(deInt32 value)    = 0;
+
+protected:
+                                                               UniformIntegerFunctionCase                              (const UniformIntegerFunctionCase& other);
+       UniformIntegerFunctionCase&     operator=                                                               (const UniformIntegerFunctionCase& other);
+
+private:
+       ShaderSpec                                      m_spec;
+       glu::ShaderType                         m_shaderType;
+       int                                                     m_input;
+       int                                                     m_value;
+       ShaderExecutor*                         m_executor;
+};
+
+static std::string getCaseName (glu::Precision precision, glu::ShaderType shaderType);
+
+UniformIntegerFunctionCase::UniformIntegerFunctionCase(Context& context, const char* description, int inputValue, glu::Precision precision, glu::ShaderType shaderType)
+       : TestCase(context, getCaseName(precision, shaderType).c_str(), description)
+       , m_shaderType(shaderType)
+       , m_input(inputValue)
+       , m_value(0)
+       , m_executor(DE_NULL)
+{
+       m_spec.version = glu::GLSL_VERSION_310_ES;
+
+       std::ostringstream oss;
+       glu::VarType varType(glu::TYPE_INT, precision);
+       oss << "uniform " << glu::declare(varType, "value", 0) << ";\n";
+       m_spec.globalDeclarations = oss.str();
+       m_spec.outputs.push_back(Symbol("result", glu::VarType(glu::TYPE_INT, glu::PRECISION_LOWP)));
+       m_spec.outputs.push_back(Symbol("comparison", glu::VarType(glu::TYPE_BOOL, glu::PRECISION_LOWP)));
+}
+
+UniformIntegerFunctionCase::~UniformIntegerFunctionCase(void)
+{
+       UniformIntegerFunctionCase::deinit();
+}
+
+void UniformIntegerFunctionCase::deinit(void)
+{
+       delete m_executor;
+       m_executor = DE_NULL;
+}
+
+void UniformIntegerFunctionCase::init(void)
+{
+       std::ostringstream oss;
+       oss <<
+               "result = " << getFunctionName() << "(value);\n"
+               "comparison = (" << getFunctionName() << "(value) == " << computeExpectedResult(m_input) << ");\n";
+       m_spec.source = oss.str();
+
+       DE_ASSERT(!m_executor);
+       m_executor = createExecutor(m_context.getRenderContext(), m_shaderType, m_spec);
+       m_testCtx.getLog() << m_executor;
+
+       if (!m_executor->isOk())
+               throw tcu::TestError("Compile failed");
+
+       m_value = m_context.getRenderContext().getFunctions().getUniformLocation(m_executor->getProgram(), "value");
+}
+
+tcu::TestNode::IterateResult UniformIntegerFunctionCase::iterate(void)
+{
+       deInt32                                 result;
+       deBool                                  comparison;
+       vector<void*>                   outputPointers  (2);
+
+       outputPointers[0]= &result;
+       outputPointers[1] = &comparison;
+
+       m_executor->useProgram();
+       m_context.getRenderContext().getFunctions().uniform1i(m_value, m_input);
+       m_executor->execute(1, DE_NULL, &outputPointers[0]);
+
+       int expectedResult = computeExpectedResult(m_input);
+       if (result != expectedResult) {
+               m_testCtx.getLog() << TestLog::Message << "ERROR: comparison failed for " << getFunctionName() << "(" << m_input << ") == " << expectedResult << TestLog::EndMessage;
+               m_testCtx.getLog() << TestLog::Message << "input: " << m_input << TestLog::EndMessage;
+               m_testCtx.getLog() << TestLog::Message << "result: " << result << TestLog::EndMessage;
+               m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Result comparison failed");
+               return STOP;
+       } else if (!comparison) {
+               m_testCtx.getLog() << TestLog::Message << "ERROR: result is as expected, but not when use in condition statement (" << getFunctionName() << "(" << m_input << ") == " << expectedResult << ") == true" << TestLog::EndMessage;
+               m_testCtx.getLog() << TestLog::Message << "input:" << m_input << TestLog::EndMessage;
+               m_testCtx.getLog() << TestLog::Message << "result: " << result << TestLog::EndMessage;
+               m_testCtx.getLog() << TestLog::Message << "comparison: " << comparison << TestLog::EndMessage;
+               m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Result comparison failed");
+               return STOP;
+       }
+       m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass");
+       return STOP;
+}
+
+static const char* getPrecisionPostfix (glu::Precision precision)
+{
+       static const char* s_postfix[] =
+               {
+                       "lowp",
+                       "mediump",
+                       "highp"
+               };
+       DE_STATIC_ASSERT(DE_LENGTH_OF_ARRAY(s_postfix) == glu::PRECISION_LAST);
+       DE_ASSERT(de::inBounds<int>(precision, 0, DE_LENGTH_OF_ARRAY(s_postfix)));
+       return s_postfix[precision];
+}
+
+static const char* getShaderTypePostfix (glu::ShaderType shaderType)
+{
+       static const char* s_postfix[] =
+               {
+                       "_vertex",
+                       "_fragment",
+                       "_geometry",
+                       "_tess_control",
+                       "_tess_eval",
+                       "_compute"
+               };
+       DE_ASSERT(de::inBounds<int>(shaderType, 0, DE_LENGTH_OF_ARRAY(s_postfix)));
+       return s_postfix[shaderType];
+}
+
+static std::string getCaseName (glu::Precision precision, glu::ShaderType shaderType)
+{
+       return string(getPrecisionPostfix(precision)) + getShaderTypePostfix(shaderType);
+}
+
+static int findMSB (deInt32 value)
+{
+       if (value > 0)
+               return 31 - deClz32((deUint32)value);
+       else if (value < 0)
+               return 31 - deClz32(~(deUint32)value);
+       else
+               return -1;
+}
+
+class FindMSBEdgeCase : public UniformIntegerFunctionCase {
+public:
+       FindMSBEdgeCase(Context& context, int inputValue, glu::Precision precision, glu::ShaderType shaderType)
+               : UniformIntegerFunctionCase(context, "findMSB", inputValue, precision, shaderType)
+       {
+       }
+
+protected:
+       const char* getFunctionName() {
+               return "findMSB";
+       }
+
+       int computeExpectedResult(deInt32 input) {
+               return findMSB(input);
+       }
+};
+
+static int findLSB (deUint32 value)
+{
+       for (int i = 0; i < 32; i++)
+       {
+               if (value & (1u<<i))
+                       return i;
+       }
+       return -1;
+}
+
+class FindLSBEdgeCase : public UniformIntegerFunctionCase {
+public:
+       FindLSBEdgeCase(Context& context, int inputValue, glu::Precision precision, glu::ShaderType shaderType)
+               : UniformIntegerFunctionCase(context, "findLSB", inputValue, precision, shaderType)
+       {
+       }
+
+protected:
+       const char* getFunctionName() {
+               return "findLSB";
+       }
+
+       int computeExpectedResult(deInt32 input) {
+               return findLSB(input);
+       }
+};
+
+
+template<class TestClass>
+static void addFunctionCases (TestCaseGroup* parent, const char* functionName, int input)
+{
+       tcu::TestCaseGroup* group = new tcu::TestCaseGroup(parent->getTestContext(), functionName, functionName);
+       parent->addChild(group);
+       for (int prec = glu::PRECISION_LOWP; prec <= glu::PRECISION_HIGHP; prec++)
+       {
+               for (int shaderTypeNdx = 0; shaderTypeNdx < glu::SHADERTYPE_LAST; shaderTypeNdx++)
+               {
+                       group->addChild(new TestClass(parent->getContext(), input, glu::Precision(prec), glu::ShaderType(shaderTypeNdx)));
+               }
+       }
+}
+
+ShaderUniformIntegerFunctionTests::ShaderUniformIntegerFunctionTests(Context& context)
+       : TestCaseGroup(context, "uniform", "Function on uniform")
+{
+}
+
+ShaderUniformIntegerFunctionTests::~ShaderUniformIntegerFunctionTests()
+{
+}
+void ShaderUniformIntegerFunctionTests::init()
+{
+       addFunctionCases<FindMSBEdgeCase>(this, "findMSBZero", 0);
+       addFunctionCases<FindMSBEdgeCase>(this, "findMSBMinusOne", -1);
+       addFunctionCases<FindLSBEdgeCase>(this, "findLSBZero", 0);
+       addFunctionCases<FindLSBEdgeCase>(this, "findLSBMinusOne", -1);
+}
+
+}
+}
+}
diff --git a/modules/gles31/functional/es31fShaderUniformIntegerFunctionTests.hpp b/modules/gles31/functional/es31fShaderUniformIntegerFunctionTests.hpp
new file mode 100644 (file)
index 0000000..8d32fe3
--- /dev/null
@@ -0,0 +1,53 @@
+#ifndef _ES31FSHADERUNIFORMINTEGERFUNCTIONTESTS_HPP
+#define _ES31FSHADERUNIFORMINTEGERFUNCTIONTESTS_HPP
+/*-------------------------------------------------------------------------
+ * drawElements Quality Program OpenGL ES 3.1 Module
+ * -------------------------------------------------
+ *
+ * Copyright 2018 The Android Open Source Project
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ *
+ *//*!
+ * \file
+ * \brief Built-in function tests for uniform constants.
+ *//*--------------------------------------------------------------------*/
+
+#include <gluShaderProgram.hpp>
+#include "tes31TestCase.hpp"
+
+namespace deqp
+{
+namespace gles31
+{
+namespace Functional
+{
+
+class ShaderUniformIntegerFunctionTests : public TestCaseGroup
+{
+public:
+                                                                                       ShaderUniformIntegerFunctionTests                               (Context& context);
+       virtual                                                                 ~ShaderUniformIntegerFunctionTests                              (void);
+
+       virtual void                                                    init                                                                                    (void);
+
+private:
+       ShaderUniformIntegerFunctionTests               (const ShaderUniformIntegerFunctionTests&);             // not allowed!
+       ShaderUniformIntegerFunctionTests&              operator=                                                                               (const ShaderUniformIntegerFunctionTests&);             // not allowed!
+};
+
+} // Functional
+} // gles31
+} // deqp
+
+#endif // _ES31FSHADERUNIFORMINTEGERFUNCTIONTESTS_HPP