blob: e1715ae44df3eb31d547d2ef46c874d53bf3803a [file] [log] [blame]
// Copyright 2015 The Cobalt Authors. All Rights Reserved.
//
// 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.
#include "starboard/nplb/file_helpers.h"
#include <sys/stat.h>
#include <sstream>
#include <string>
#include <vector>
#include "starboard/common/log.h"
#include "starboard/configuration_constants.h"
#include "starboard/directory.h"
#include "starboard/file.h"
#include "starboard/system.h"
#include "testing/gtest/include/gtest/gtest.h"
namespace starboard {
namespace nplb {
namespace {
// Size of appropriate path buffer.
const size_t kPathSize = kSbFileMaxPath + 1;
} // namespace
std::string GetTempDir() {
// It seems there's absolutely no way to get to std::string without a copy.
std::vector<char> path(kPathSize, 0);
if (!SbSystemGetPath(kSbSystemPathTempDirectory, path.data(), path.size())) {
return "";
}
return path.data();
}
std::string GetFileTestsDataDir() {
std::vector<char> content_path(kPathSize);
EXPECT_TRUE(SbSystemGetPath(kSbSystemPathContentDirectory,
content_path.data(), kPathSize));
std::string directory_path = std::string(content_path.data()) +
kSbFileSepChar + "test" + kSbFileSepChar +
"starboard" + kSbFileSepChar + "nplb" +
kSbFileSepChar + "file_tests";
struct stat info;
SB_CHECK(stat(directory_path.c_str(), &info) == 0 && S_ISDIR(info.st_mode));
return directory_path;
}
// Make a vector of absolute paths in our test data from a null-terminated array
// of C-strings with the relative paths. Slashes are converted to the platform's
// delimiter.
std::vector<std::string> MakePathsVector(const char* files[]) {
std::string directory_path = GetFileTestsDataDir();
std::vector<std::string> paths;
for (int i = 0; files[i] != nullptr; i++) {
std::string file_path = directory_path + kSbFileSepChar + files[i];
std::replace(file_path.begin(), file_path.end(), '/', kSbFileSepChar);
paths.push_back(file_path);
}
return paths;
}
std::vector<std::string> GetFileTestsFilePaths() {
const char* kFiles[] = {
// This long file MUST be first -- SbFileSeekTest depends on it!
"file_with_long_name_and_contents_for_seek_testing_1234567890",
"file01",
"dir_with_files/file11",
"dir_with_files/file12",
"dir_with_only_subdir/dir_with_files/file21",
"dir_with_only_subdir/dir_with_files/file22",
nullptr};
return MakePathsVector(kFiles);
}
std::vector<std::string> GetFileTestsDirectoryPaths() {
const char* kDirs[] = {"dir_with_files", "dir_with_only_subdir",
"dir_with_only_subdir/dir_with_files", nullptr};
return MakePathsVector(kDirs);
}
std::string GetTestFileExpectedContent(const std::string& path) {
// The test file content matches the basename of the file + a newline.
std::string content(path, path.find_last_of(kSbFileSepChar) + 1);
content += '\n';
return content;
}
// static
std::string ScopedRandomFile::MakeRandomFilename() {
std::ostringstream filename_stream;
filename_stream << "ScopedRandomFile.File_" << SbSystemGetRandomUInt64();
return filename_stream.str();
}
// static
void ScopedRandomFile::ExpectPattern(int pattern_offset,
void* buffer,
int size,
int line) {
char* char_buffer = static_cast<char*>(buffer);
for (int i = 0; i < size; ++i) {
EXPECT_EQ(static_cast<char>((i + pattern_offset) & 0xFF), char_buffer[i])
<< "original line=" << line;
}
}
// static
std::string ScopedRandomFile::MakeRandomFilePath() {
std::ostringstream filename_stream;
filename_stream << GetTempDir();
if (!filename_stream.tellp()) {
return "";
}
filename_stream << kSbFileSepChar << MakeRandomFilename();
return filename_stream.str();
}
std::string ScopedRandomFile::MakeRandomFile(int length) {
std::string filename = MakeRandomFilePath();
if (filename.empty()) {
return filename;
}
SbFile file = SbFileOpen(filename.c_str(), kSbFileCreateOnly | kSbFileWrite,
NULL, NULL);
EXPECT_TRUE(SbFileIsValid(file));
if (!SbFileIsValid(file)) {
return "";
}
char* data = new char[length];
for (int i = 0; i < length; ++i) {
data[i] = static_cast<char>(i & 0xFF);
}
int bytes = SbFileWriteAll(file, data, length);
EXPECT_EQ(bytes, length) << "Failed to write " << length << " bytes to "
<< filename;
bool result = SbFileClose(file);
EXPECT_TRUE(result) << "Failed to close " << filename;
delete[] data;
return filename;
}
} // namespace nplb
} // namespace starboard