1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89
|
// Copyright 2014 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifdef UNSAFE_BUFFERS_BUILD
// TODO(crbug.com/351564777): Remove this and convert code to safer constructs.
#pragma allow_unsafe_buffers
#endif
#include "mojo/core/test/test_support_impl.h"
#include <stddef.h>
#include <stdlib.h>
#include <string.h>
#include <string>
#include <string_view>
#include "base/check.h"
#include "base/files/file_enumerator.h"
#include "base/files/file_path.h"
#include "base/files/file_util.h"
#include "base/path_service.h"
#include "base/strings/string_split.h"
#include "base/strings/string_util.h"
#include "base/strings/stringprintf.h"
#include "base/test/perf_log.h"
namespace mojo {
namespace core {
namespace test {
namespace {
base::FilePath ResolveSourceRootRelativePath(const char* relative_path) {
base::FilePath path;
if (!base::PathService::Get(base::DIR_SRC_TEST_DATA_ROOT, &path)) {
return base::FilePath();
}
for (std::string_view component : base::SplitStringPiece(
relative_path, "/", base::TRIM_WHITESPACE, base::SPLIT_WANT_ALL)) {
if (!component.empty())
path = path.AppendASCII(component);
}
return path;
}
} // namespace
TestSupportImpl::TestSupportImpl() = default;
TestSupportImpl::~TestSupportImpl() = default;
void TestSupportImpl::LogPerfResult(const char* test_name,
const char* sub_test_name,
double value,
const char* units) {
DCHECK(test_name);
if (sub_test_name) {
std::string name = base::StringPrintf("%s/%s", test_name, sub_test_name);
base::LogPerfResult(name.c_str(), value, units);
} else {
base::LogPerfResult(test_name, value, units);
}
}
FILE* TestSupportImpl::OpenSourceRootRelativeFile(const char* relative_path) {
return base::OpenFile(ResolveSourceRootRelativePath(relative_path), "rb");
}
char** TestSupportImpl::EnumerateSourceRootRelativeDirectory(
const char* relative_path) {
std::vector<std::string> names;
base::FileEnumerator e(ResolveSourceRootRelativePath(relative_path), false,
base::FileEnumerator::FILES);
for (base::FilePath name = e.Next(); !name.empty(); name = e.Next())
names.push_back(name.BaseName().AsUTF8Unsafe());
// |names.size() + 1| for null terminator.
char** rv = static_cast<char**>(calloc(names.size() + 1, sizeof(char*)));
for (size_t i = 0; i < names.size(); ++i)
rv[i] = base::strdup(names[i].c_str());
return rv;
}
} // namespace test
} // namespace core
} // namespace mojo
|