/* vim:set ts=2 sw=2 sts=2 et: */
/**
* \author Marcus Holland-Moritz (github@mhxnet.de)
* \copyright Copyright (c) Marcus Holland-Moritz
*
* This file is part of dwarfs.
*
* dwarfs is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* dwarfs is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with dwarfs. If not, see .
*/
#include
#include
#include
#include
#include
#include
#include "test_helpers.h"
using namespace dwarfs;
namespace fs = std::filesystem;
TEST(file_access_generic_test, basic) {
temporary_directory tempdir("dwarfs");
auto td = fs::path(tempdir.path().string());
auto text_file = td / "test.txt";
auto binary_file = td / "test.bin";
auto fa = create_file_access_generic();
{
auto text_os = fa->open_output(text_file);
text_os->os() << "line1" << std::endl;
text_os->os() << "line2" << std::endl;
text_os->close();
}
auto binary_data = test::create_random_string(4096);
{
auto binary_os = fa->open_output_binary(binary_file);
binary_os->os().write(binary_data.data(), binary_data.size());
binary_os->close();
}
EXPECT_TRUE(fa->exists(text_file));
EXPECT_TRUE(fa->exists(binary_file));
EXPECT_TRUE(std::filesystem::exists(text_file));
EXPECT_TRUE(std::filesystem::exists(binary_file));
EXPECT_FALSE(fa->exists(td / "nonexistent"));
auto binary_size = std::filesystem::file_size(binary_file);
{
auto text_is = fa->open_input(text_file);
std::string line;
std::getline(text_is->is(), line);
EXPECT_EQ(line, "line1");
std::getline(text_is->is(), line);
EXPECT_EQ(line, "line2");
text_is->close();
}
{
auto binary_is = fa->open_input_binary(binary_file);
std::string data;
data.resize(binary_size);
binary_is->is().read(data.data(), data.size());
EXPECT_EQ(data, binary_data);
binary_is->close();
}
}
TEST(file_access_generic_test, error_handling) {
temporary_directory tempdir("dwarfs");
auto td = fs::path(tempdir.path().string());
auto nonexistent_file = td / "nonexistent";
auto file_in_subdir = td / "subdir" / "test.txt";
auto fa = create_file_access_generic();
{
auto matcher = testing::Throws(testing::Property(
&std::system_error::code,
testing::Property(&std::error_code::value,
testing::Eq(static_cast(
std::errc::no_such_file_or_directory)))));
EXPECT_THAT([&] { fa->open_input(nonexistent_file); }, matcher);
EXPECT_THAT([&] { fa->open_input_binary(nonexistent_file); }, matcher);
EXPECT_THAT([&] { fa->open_output(file_in_subdir); }, matcher);
EXPECT_THAT([&] { fa->open_output_binary(file_in_subdir); }, matcher);
}
{
auto matcher = testing::Property(
&std::system_error::code,
testing::Property(&std::error_code::value,
testing::Eq(static_cast(
std::errc::no_such_file_or_directory))));
{
std::error_code ec;
auto x [[maybe_unused]] = fa->open_input(nonexistent_file, ec);
EXPECT_THAT(ec, matcher);
}
{
std::error_code ec;
auto x [[maybe_unused]] = fa->open_input_binary(nonexistent_file, ec);
EXPECT_THAT(ec, matcher);
}
{
std::error_code ec;
auto x [[maybe_unused]] = fa->open_output(file_in_subdir, ec);
EXPECT_THAT(ec, matcher);
}
{
std::error_code ec;
auto x [[maybe_unused]] = fa->open_output_binary(file_in_subdir, ec);
EXPECT_THAT(ec, matcher);
}
}
}