This source file includes following definitions.
- SetUp
- TearDown
- TEST_F
- TEST_F
- TEST_F
#include <GLES2/gl2.h>
#include <GLES2/gl2ext.h>
#include <GLES2/gl2extchromium.h>
#include "base/threading/platform_thread.h"
#include "gpu/command_buffer/tests/gl_manager.h"
#include "gpu/command_buffer/tests/gl_test_utils.h"
#include "testing/gmock/include/gmock/gmock.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace gpu {
class QueryTest : public testing::Test {
protected:
virtual void SetUp() {
gl_.Initialize(GLManager::Options());
}
virtual void TearDown() {
gl_.Destroy();
}
GLManager gl_;
};
TEST_F(QueryTest, MultipleQueries) {
EXPECT_TRUE(GLTestHelper::HasExtension("GL_CHROMIUM_get_error_query"));
EXPECT_TRUE(GLTestHelper::HasExtension(
"GL_CHROMIUM_command_buffer_latency_query"));
GLuint error_query = 0;
GLuint commands_issue_query = 0;
glGenQueriesEXT(1, &error_query);
glGenQueriesEXT(1, &commands_issue_query);
GLuint available;
GLuint result;
base::TimeTicks before = base::TimeTicks::HighResNow();
glBeginQueryEXT(GL_COMMANDS_ISSUED_CHROMIUM, commands_issue_query);
glBeginQueryEXT(GL_GET_ERROR_QUERY_CHROMIUM, error_query);
glEnable(GL_TEXTURE_2D);
glEndQueryEXT(GL_COMMANDS_ISSUED_CHROMIUM);
glEndQueryEXT(GL_GET_ERROR_QUERY_CHROMIUM);
glFinish();
base::TimeTicks after = base::TimeTicks::HighResNow();
available = 0;
result = 0;
glGetQueryObjectuivEXT(commands_issue_query,
GL_QUERY_RESULT_AVAILABLE_EXT,
&available);
EXPECT_TRUE(available);
glGetQueryObjectuivEXT(commands_issue_query, GL_QUERY_RESULT_EXT, &result);
EXPECT_LT(result, base::TimeDelta(after - before).InMicroseconds());
result = 0;
available = 0;
glGetQueryObjectuivEXT(error_query,
GL_QUERY_RESULT_AVAILABLE_EXT,
&available);
EXPECT_TRUE(available);
glGetQueryObjectuivEXT(error_query, GL_QUERY_RESULT_EXT, &result);
EXPECT_EQ(static_cast<uint32>(GL_INVALID_ENUM), result);
}
TEST_F(QueryTest, GetErrorBasic) {
EXPECT_TRUE(GLTestHelper::HasExtension("GL_CHROMIUM_get_error_query"));
GLuint query = 0;
glGenQueriesEXT(1, &query);
GLuint query_status = 0;
GLuint result = 0;
glBeginQueryEXT(GL_GET_ERROR_QUERY_CHROMIUM, query);
glEnable(GL_TEXTURE_2D);
glEndQueryEXT(GL_GET_ERROR_QUERY_CHROMIUM);
glFinish();
query_status = 0;
result = 0;
glGetQueryObjectuivEXT(query, GL_QUERY_RESULT_AVAILABLE_EXT, &result);
EXPECT_TRUE(result);
glGetQueryObjectuivEXT(query, GL_QUERY_RESULT_EXT, &query_status);
EXPECT_EQ(static_cast<uint32>(GL_INVALID_ENUM), query_status);
}
TEST_F(QueryTest, DISABLED_LatencyQueryBasic) {
EXPECT_TRUE(GLTestHelper::HasExtension(
"GL_CHROMIUM_command_buffer_latency_query"));
GLuint query = 0;
glGenQueriesEXT(1, &query);
GLuint query_result = 0;
GLuint available = 0;
const unsigned int kExpectedLatencyMicroseconds = 2000;
const unsigned int kTimePrecisionMicroseconds = 1000;
glBeginQueryEXT(GL_LATENCY_QUERY_CHROMIUM, query);
base::PlatformThread::Sleep(
base::TimeDelta::FromMicroseconds(kExpectedLatencyMicroseconds));
glEndQueryEXT(GL_LATENCY_QUERY_CHROMIUM);
glFinish();
query_result = 0;
available = 0;
glGetQueryObjectuivEXT(query, GL_QUERY_RESULT_AVAILABLE_EXT, &available);
EXPECT_TRUE(available);
glGetQueryObjectuivEXT(query, GL_QUERY_RESULT_EXT, &query_result);
EXPECT_GE(query_result, kExpectedLatencyMicroseconds
- kTimePrecisionMicroseconds);
EXPECT_LE(query_result, kExpectedLatencyMicroseconds
+ kTimePrecisionMicroseconds);
glBeginQueryEXT(GL_LATENCY_QUERY_CHROMIUM, query);
glEndQueryEXT(GL_LATENCY_QUERY_CHROMIUM);
glFinish();
query_result = 0;
available = 0;
glGetQueryObjectuivEXT(query, GL_QUERY_RESULT_AVAILABLE_EXT, &available);
EXPECT_TRUE(available);
glGetQueryObjectuivEXT(query, GL_QUERY_RESULT_EXT, &query_result);
EXPECT_LE(query_result, kTimePrecisionMicroseconds);
}
}