Index: gpu/khronos_glcts_support/khronos_glcts_test.cc |
diff --git a/gpu/gles2_conform_support/gles2_conform_test.cc b/gpu/khronos_glcts_support/khronos_glcts_test.cc |
similarity index 55% |
copy from gpu/gles2_conform_support/gles2_conform_test.cc |
copy to gpu/khronos_glcts_support/khronos_glcts_test.cc |
index 46a511569cb078aa43aaf37496b6db894ad4f5cb..b77bb8dcc1d9b90033523575f8c1eea90e3cd50f 100644 |
--- a/gpu/gles2_conform_support/gles2_conform_test.cc |
+++ b/gpu/khronos_glcts_support/khronos_glcts_test.cc |
@@ -1,20 +1,17 @@ |
-// Copyright (c) 2013 The Chromium Authors. All rights reserved. |
+// Copyright 2014 The Chromium Authors. All rights reserved. |
// Use of this source code is governed by a BSD-style license that can be |
// found in the LICENSE file. |
-#include "gpu/gles2_conform_support/gles2_conform_test.h" |
+#include "gpu/khronos_glcts_support/khronos_glcts_test.h" |
#include <string> |
#include "base/at_exit.h" |
#include "base/base_paths.h" |
#include "base/command_line.h" |
+#include "base/file_util.h" |
#include "base/files/file_path.h" |
-#include "base/files/file_util.h" |
#include "base/logging.h" |
-#if defined(OS_MACOSX) |
-#include "base/mac/scoped_nsautorelease_pool.h" |
-#endif |
#include "base/path_service.h" |
#include "base/process/launch.h" |
#include "base/strings/string_util.h" |
@@ -22,21 +19,23 @@ |
#include "gpu/config/gpu_test_expectations_parser.h" |
#include "testing/gtest/include/gtest/gtest.h" |
-bool RunGLES2ConformTest(const char* path) { |
+base::FilePath g_deqp_log_dir; |
+ |
+bool RunKhronosGLCTSTest(const char* test_name) { |
// Load test expectations, and return early if a test is marked as FAIL. |
base::FilePath src_path; |
PathService::Get(base::DIR_SOURCE_ROOT, &src_path); |
base::FilePath test_expectations_path = |
src_path.Append(FILE_PATH_LITERAL("gpu")). |
- Append(FILE_PATH_LITERAL("gles2_conform_support")). |
- Append(FILE_PATH_LITERAL("gles2_conform_test_expectations.txt")); |
+ Append(FILE_PATH_LITERAL("khronos_glcts_support")). |
+ Append(FILE_PATH_LITERAL("khronos_glcts_test_expectations.txt")); |
if (!base::PathExists(test_expectations_path)) { |
- LOG(ERROR) << "Fail to locate gles2_conform_test_expectations.txt"; |
+ LOG(ERROR) << "Fail to locate khronos_glcts_test_expectations.txt"; |
return false; |
} |
gpu::GPUTestExpectationsParser test_expectations; |
if (!test_expectations.LoadTestExpectations(test_expectations_path)) { |
- LOG(ERROR) << "Fail to load gles2_conform_test_expectations.txt"; |
+ LOG(ERROR) << "Fail to load khronos_glcts_test_expectations.txt"; |
return false; |
} |
gpu::GPUTestBotConfig bot_config; |
@@ -48,32 +47,37 @@ bool RunGLES2ConformTest(const char* path) { |
LOG(ERROR) << "Invalid bot configuration"; |
return false; |
} |
- std::string path_string(path); |
- std::string test_name; |
- base::ReplaceChars(path_string, "\\/.", "_", &test_name); |
+ |
+ const ::testing::TestInfo* const test_info = |
+ ::testing::UnitTest::GetInstance()->current_test_info(); |
int32 expectation = |
- test_expectations.GetTestExpectation(test_name, bot_config); |
+ test_expectations.GetTestExpectation(test_info->name(), bot_config); |
if (expectation != gpu::GPUTestExpectationsParser::kGpuTestPass) { |
- LOG(WARNING) << "Test " << test_name << " is bypassed"; |
+ LOG(WARNING) << "Test " << test_info->name() << " is bypassed"; |
return true; |
} |
base::FilePath test_path; |
PathService::Get(base::DIR_EXE, &test_path); |
+ base::FilePath archive(test_path.Append(FILE_PATH_LITERAL( |
+ "khronos_glcts_data"))); |
base::FilePath program(test_path.Append(FILE_PATH_LITERAL( |
- "gles2_conform_test_windowless"))); |
+ "khronos_glcts_test_windowless"))); |
+ base::FilePath log = |
+ g_deqp_log_dir.AppendASCII(test_info->name()). |
+ AddExtension(FILE_PATH_LITERAL(".log")); |
- CommandLine* currentCmdLine = CommandLine::ForCurrentProcess(); |
CommandLine cmdline(program); |
- cmdline.AppendArguments(*currentCmdLine, false); |
- cmdline.AppendSwitch(std::string("--")); |
- cmdline.AppendArg(std::string("-run=") + path); |
+ cmdline.AppendSwitchPath("--deqp-log-filename", log); |
+ cmdline.AppendSwitchPath("--deqp-archive-dir", archive); |
+ cmdline.AppendArg("--deqp-gl-config-id=-1"); |
+ cmdline.AppendArg(std::string("--deqp-case=") + test_name); |
std::string output; |
bool success = base::GetAppOutput(cmdline, &output); |
if (success) { |
- size_t success_index = output.find("Conformance PASSED all"); |
- size_t failed_index = output.find("FAILED"); |
+ size_t success_index = output.find("Pass (Pass)"); |
+ size_t failed_index = output.find("Fail (Fail)"); |
success = (success_index != std::string::npos) && |
(failed_index == std::string::npos); |
} |
@@ -83,15 +87,18 @@ bool RunGLES2ConformTest(const char* path) { |
return success; |
} |
-int main(int argc, char** argv) { |
- base::AtExitManager exit_manager; |
- CommandLine::Init(argc, argv); |
-#if defined(OS_MACOSX) |
- base::mac::ScopedNSAutoreleasePool pool; |
-#endif |
+int main(int argc, char *argv[]) { |
+ base::AtExitManager at_exit; |
+ |
::testing::InitGoogleTest(&argc, argv); |
- return RUN_ALL_TESTS(); |
-} |
+ if (argc == 2) { |
+ g_deqp_log_dir = base::FilePath::FromUTF8Unsafe(argv[1]); |
+ } |
+ else { |
+ base::GetTempDir(&g_deqp_log_dir); |
+ } |
+ return RUN_ALL_TESTS(); |
+} |