/*-------------------------------------------------------------------------
* drawElements Quality Program OpenGL ES 3.1 Module
* -------------------------------------------------
*
* Copyright 2014 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 ANDROID_extension_pack_es31a tests
*//*--------------------------------------------------------------------*/
#include "es31fAndroidExtensionPackES31ATests.hpp"
#include "glsStateQueryUtil.hpp"
#include "glsShaderLibrary.hpp"
#include "tcuTestLog.hpp"
#include "gluCallLogWrapper.hpp"
#include "gluContextInfo.hpp"
#include "gluStrUtil.hpp"
#include "glwFunctions.hpp"
#include "glwEnums.hpp"
#include "deStringUtil.hpp"
namespace deqp
{
namespace gles31
{
namespace Functional
{
namespace
{
static std::string genExtensionTestName (const char* extensionName)
{
DE_ASSERT(deStringBeginsWith(extensionName, "GL_"));
return de::toLower(std::string(extensionName + 3));
}
class ExtensionPackTestCase : public TestCase
{
public:
ExtensionPackTestCase (Context& context, const char* name, const char* description);
protected:
void init (void);
};
ExtensionPackTestCase::ExtensionPackTestCase (Context& context, const char* name, const char* description)
: TestCase (context, name, description)
{
}
void ExtensionPackTestCase::init (void)
{
if (!m_context.getContextInfo().isExtensionSupported("GL_ANDROID_extension_pack_es31a"))
throw tcu::NotSupportedError("Test requires GL_ANDROID_extension_pack_es31a extension");
}
class ImplementationLimitCase : public ExtensionPackTestCase
{
public:
ImplementationLimitCase (Context& context, const char* name, const char* description, glw::GLenum target, int limit);
private:
IterateResult iterate (void);
const glw::GLenum m_target;
const int m_limit;
};
ImplementationLimitCase::ImplementationLimitCase (Context& context, const char* name, const char* description, glw::GLenum target, int limit)
: ExtensionPackTestCase (context, name, description)
, m_target (target)
, m_limit (limit)
{
}
ImplementationLimitCase::IterateResult ImplementationLimitCase::iterate (void)
{
using namespace gls::StateQueryUtil;
glu::CallLogWrapper gl (m_context.getRenderContext().getFunctions(), m_testCtx.getLog());
StateQueryMemoryWriteGuard<glw::GLint> result;
m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass");
m_testCtx.getLog()
<< tcu::TestLog::Message
<< "Querying " << glu::getGettableStateName(m_target) << ", expecting at least " << m_limit
<< tcu::TestLog::EndMessage;
gl.enableLogging(true);
gl.glGetIntegerv(m_target, &result);
GLU_EXPECT_NO_ERROR(gl.glGetError(), "implementation limit query failed");
if (result.verifyValidity(m_testCtx) && result < m_limit)
{
m_testCtx.getLog()
<< tcu::TestLog::Message
<< "// ERROR: Got " << result << ", expected at least " << m_limit
<< tcu::TestLog::EndMessage;
m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Too low implementation limit");
}
return STOP;
}
class SubExtensionCase : public ExtensionPackTestCase
{
public:
SubExtensionCase (Context& context, const char* name, const char* description, const char* extension);
private:
IterateResult iterate (void);
const std::string m_extension;
};
SubExtensionCase::SubExtensionCase (Context& context, const char* name, const char* description, const char* extension)
: ExtensionPackTestCase (context, name, description)
, m_extension (extension)
{
}
SubExtensionCase::IterateResult SubExtensionCase::iterate (void)
{
m_testCtx.getLog()
<< tcu::TestLog::Message
<< "Verifying that extension \"" << m_extension << "\" is supported."
<< tcu::TestLog::EndMessage;
if (m_context.getContextInfo().isExtensionSupported(m_extension.c_str()))
{
m_testCtx.getLog()
<< tcu::TestLog::Message
<< "Extension is supported."
<< tcu::TestLog::EndMessage;
m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass");
}
else
{
m_testCtx.getLog()
<< tcu::TestLog::Message
<< "Error, extension is not supported."
<< tcu::TestLog::EndMessage;
m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Required extension not supported");
}
return STOP;
}
} //anonymous
AndroidExtensionPackES31ATests::AndroidExtensionPackES31ATests (Context& context)
: TestCaseGroup(context, "android_extension_pack", "ANDROID_extension_pack_es31a extension tests")
{
}
AndroidExtensionPackES31ATests::~AndroidExtensionPackES31ATests (void)
{
}
void AndroidExtensionPackES31ATests::init (void)
{
// .limits
{
static const struct
{
const char* name;
glw::GLenum target;
int limit;
} limits[] =
{
{
"max_fragment_atomic_counter_buffers",
GL_MAX_FRAGMENT_ATOMIC_COUNTER_BUFFERS,
1
},
{
"max_fragment_atomic_counters",
GL_MAX_FRAGMENT_ATOMIC_COUNTERS,
8
},
{
"max_fragment_image_uniforms",
GL_MAX_FRAGMENT_IMAGE_UNIFORMS,
4
},
{
"max_fragment_shader_storage_blocks",
GL_MAX_FRAGMENT_SHADER_STORAGE_BLOCKS,
4
},
};
tcu::TestCaseGroup* const group = new tcu::TestCaseGroup(m_testCtx, "limits", "Implementation limits");
addChild(group);
for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(limits); ++ndx)
group->addChild(new ImplementationLimitCase(m_context,
limits[ndx].name,
(std::string() + "Check " + limits[ndx].name + " is at least " + de::toString(limits[ndx].limit)).c_str(),
limits[ndx].target,
limits[ndx].limit));
}
// .extensions
{
static const char* const subExtensions[] =
{
"GL_KHR_debug",
"GL_KHR_texture_compression_astc_ldr",
"GL_KHR_blend_equation_advanced",
"GL_OES_sample_shading",
"GL_OES_sample_variables",
"GL_OES_shader_image_atomic",
"GL_OES_shader_multisample_interpolation",
"GL_OES_texture_stencil8",
"GL_OES_texture_storage_multisample_2d_array",
"GL_EXT_copy_image",
"GL_EXT_draw_buffers_indexed",
"GL_EXT_geometry_shader",
"GL_EXT_gpu_shader5",
"GL_EXT_primitive_bounding_box",
"GL_EXT_shader_io_blocks",
"GL_EXT_tessellation_shader",
"GL_EXT_texture_border_clamp",
"GL_EXT_texture_buffer",
"GL_EXT_texture_cube_map_array",
"GL_EXT_texture_sRGB_decode",
};
tcu::TestCaseGroup* const group = new tcu::TestCaseGroup(m_testCtx, "extensions", "Required extensions");
addChild(group);
for (int ndx = 0; ndx < DE_LENGTH_OF_ARRAY(subExtensions); ++ndx)
{
const std::string name = genExtensionTestName(subExtensions[ndx]);
const std::string description = "Check that extension " + name + " is supported if extension pack is supported";
group->addChild(new SubExtensionCase(m_context, name.c_str(), description.c_str(), subExtensions[ndx]));
}
}
// .shaders
{
gls::ShaderLibrary shaderLibrary (m_testCtx, m_context.getRenderContext(), m_context.getContextInfo());
const std::vector<tcu::TestNode*>& children = shaderLibrary.loadShaderFile("shaders/android_extension_pack.test");
tcu::TestCaseGroup* const group = new tcu::TestCaseGroup(m_testCtx, "shaders", "Shader tests", children);
addChild(group);
}
}
} // Functional
} // gles31
} // deqp