/*-------------------------------------------------------------------------
* drawElements Quality Program OpenGL ES 2.0 Module
* -------------------------------------------------
*
* Copyright 2015 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 GL_EXT_debug_marker tests
*//*--------------------------------------------------------------------*/
#include "es2fDebugMarkerTests.hpp"
#include "gluContextInfo.hpp"
#include "gluRenderContext.hpp"
#include "glwFunctions.hpp"
#include "glwEnums.hpp"
#include "tcuTestLog.hpp"
#include "deRandom.hpp"
#include "deUniquePtr.hpp"
namespace deqp
{
namespace gles2
{
namespace Functional
{
namespace
{
using std::vector;
using tcu::TestLog;
void checkSupport (const glu::ContextInfo& ctxInfo)
{
if (!ctxInfo.isExtensionSupported("GL_EXT_debug_marker"))
{
#if (DE_OS == DE_OS_ANDROID)
TCU_THROW(TestError, "Support for GL_EXT_debug_marker is mandatory on Android");
#else
TCU_THROW(NotSupportedError, "GL_EXT_debug_marker is not supported");
#endif
}
// else no exception thrown
}
class IsSupportedCase : public TestCase
{
public:
IsSupportedCase (Context& context)
: TestCase(context, "supported", "Is GL_EXT_debug_marker supported")
{
}
IterateResult iterate (void)
{
checkSupport(m_context.getContextInfo());
m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "GL_EXT_debug_marker is supported");
return STOP;
}
};
void getSimpleRndString (vector<char>& dst, de::Random& rnd, int maxLen)
{
const char s_chars[] = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ -_";
dst.resize(rnd.getInt(0, (int)maxLen));
for (size_t ndx = 0; ndx < dst.size(); ndx++)
dst[ndx] = rnd.choose<char>(DE_ARRAY_BEGIN(s_chars), DE_ARRAY_END(s_chars));
}
void getComplexRndString (vector<char>& dst, de::Random& rnd, int maxLen)
{
dst.resize(rnd.getInt(0, (int)maxLen));
for (size_t ndx = 0; ndx < dst.size(); ndx++)
dst[ndx] = (char)rnd.getUint8();
}
enum CallType
{
CALL_TYPE_PUSH_GROUP = 0,
CALL_TYPE_POP_GROUP,
CALL_TYPE_INSERT_MARKER,
CALL_TYPE_LAST
};
class RandomCase : public TestCase
{
public:
RandomCase (Context& context)
: TestCase(context, "random", "Random GL_EXT_debug_marker usage")
{
}
void init (void)
{
checkSupport(m_context.getContextInfo());
}
IterateResult iterate (void)
{
const glw::Functions& gl = m_context.getRenderContext().getFunctions();
const int numIters = 1000;
const int maxMsgLen = 4096;
de::Random rnd (0xaf829c0);
for (int iterNdx = 0; iterNdx < numIters; iterNdx++)
{
const CallType callType = CallType(rnd.getInt(0, CALL_TYPE_LAST-1));
if (callType == CALL_TYPE_PUSH_GROUP || callType == CALL_TYPE_INSERT_MARKER)
{
const bool nullTerminate = rnd.getBool();
const bool passLength = rnd.getBool();
const bool complexMsg = rnd.getBool();
vector<char> message;
if (complexMsg)
getComplexRndString(message, rnd, maxMsgLen);
else
getSimpleRndString(message, rnd, maxMsgLen);
if (nullTerminate)
message.push_back(char(0));
{
const glw::GLsizei length = passLength ? glw::GLsizei(nullTerminate ? message.size()-1 : message.size()) : 0;
if (callType == CALL_TYPE_PUSH_GROUP)
gl.pushGroupMarkerEXT(length, &message[0]);
else
gl.insertEventMarkerEXT(length, &message[0]);
}
}
else
gl.popGroupMarkerEXT();
}
GLU_EXPECT_NO_ERROR(gl.getError(), "Debug marker calls must not set error state");
m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "All calls passed");
return STOP;
}
};
class InvalidCase : public TestCase
{
public:
InvalidCase (Context& context)
: TestCase(context, "invalid", "Invalid GL_EXT_debug_marker usage")
{
}
void init (void)
{
checkSupport(m_context.getContextInfo());
}
IterateResult iterate (void)
{
const glw::Functions& gl = m_context.getRenderContext().getFunctions();
m_testCtx.getLog() << TestLog::Message << "Note: GL_EXT_debug_marker calls must not report an error even if invalid arguments are supplied." << TestLog::EndMessage;
gl.pushGroupMarkerEXT(-1, "foo");
gl.insertEventMarkerEXT(-1, "foo");
gl.pushGroupMarkerEXT(0, DE_NULL);
gl.insertEventMarkerEXT(0, DE_NULL);
gl.pushGroupMarkerEXT(-1, DE_NULL);
gl.insertEventMarkerEXT(-1, DE_NULL);
GLU_EXPECT_NO_ERROR(gl.getError(), "Debug marker calls must not set error state");
m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "All calls passed");
return STOP;
}
};
} // anonymous
tcu::TestCaseGroup* createDebugMarkerTests (Context& context)
{
de::MovePtr<tcu::TestCaseGroup> debugMarkerGroup (new tcu::TestCaseGroup(context.getTestContext(), "debug_marker", "GL_EXT_debug_marker tests"));
debugMarkerGroup->addChild(new IsSupportedCase (context));
debugMarkerGroup->addChild(new RandomCase (context));
debugMarkerGroup->addChild(new InvalidCase (context));
return debugMarkerGroup.release();
}
} // Functional
} // gles2
} // deqp