blob: 287b5d02587831d55677315f497e30203e4c9b4d [file] [log] [blame]
// 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/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/files/file_path.h"
#include "base/files/file_util.h"
#include "base/logging.h"
#include "base/path_service.h"
#include "base/process/launch.h"
#include "base/strings/string_util.h"
#include "gpu/config/gpu_test_config.h"
#include "gpu/config/gpu_test_expectations_parser.h"
#include "testing/gtest/include/gtest/gtest.h"
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("khronos_glcts_support")).
Append(FILE_PATH_LITERAL("khronos_glcts_test_expectations.txt"));
if (!base::PathExists(test_expectations_path)) {
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 khronos_glcts_test_expectations.txt";
return false;
}
gpu::GPUTestBotConfig bot_config;
if (!bot_config.LoadCurrentConfig(NULL)) {
LOG(ERROR) << "Fail to load bot configuration";
return false;
}
if (!bot_config.IsValid()) {
LOG(ERROR) << "Invalid bot configuration";
return false;
}
const ::testing::TestInfo* const test_info =
::testing::UnitTest::GetInstance()->current_test_info();
int32 expectation =
test_expectations.GetTestExpectation(test_info->name(), bot_config);
if (expectation != gpu::GPUTestExpectationsParser::kGpuTestPass) {
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(
"khronos_glcts_test_windowless")));
base::FilePath log =
g_deqp_log_dir.AppendASCII(test_info->name()).
AddExtension(FILE_PATH_LITERAL(".log"));
base::CommandLine cmdline(program);
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("Pass (Pass)");
size_t failed_index = output.find("Fail (Fail)");
success = (success_index != std::string::npos) &&
(failed_index == std::string::npos);
}
if (!success) {
LOG(ERROR) << output;
}
return success;
}
int main(int argc, char *argv[]) {
base::AtExitManager at_exit;
::testing::InitGoogleTest(&argc, argv);
if (argc == 2) {
g_deqp_log_dir = base::FilePath::FromUTF8Unsafe(argv[1]);
}
else {
base::GetTempDir(&g_deqp_log_dir);
}
return RUN_ALL_TESTS();
}