spdlog/tests/file_helper.cpp

78 lines
1.8 KiB
C++
Raw Normal View History

2015-12-13 02:56:39 +08:00
/*
* This content is released under the MIT License as specified in https://raw.githubusercontent.com/gabime/spdlog/master/LICENSE
*/
#include "includes.h"
using namespace spdlog::details;
2016-04-03 06:25:41 +08:00
static const std::string target_filename = "logs/file_helper_test.txt";
2015-12-13 02:56:39 +08:00
static void write_with_helper(file_helper &helper, size_t howmany)
{
log_msg msg;
msg.formatted << std::string(howmany, '1');
helper.write(msg);
}
TEST_CASE("file_helper_filename", "[file_helper::filename()]]")
{
prepare_logdir();
file_helper helper(false);
2016-04-03 06:25:41 +08:00
helper.open(target_filename);
REQUIRE(helper.filename() == target_filename);
2015-12-13 02:56:39 +08:00
}
TEST_CASE("file_helper_size", "[file_helper::size()]]")
{
prepare_logdir();
auto expected_size = 123;
{
file_helper helper(true);
2016-04-03 06:25:41 +08:00
helper.open(target_filename);
2015-12-13 02:56:39 +08:00
write_with_helper(helper, expected_size);
REQUIRE(helper.size() == expected_size);
}
2016-04-03 06:25:41 +08:00
REQUIRE(get_filesize(target_filename) == expected_size);
2015-12-13 02:56:39 +08:00
}
TEST_CASE("file_helper_exists", "[file_helper::file_exists()]]")
{
prepare_logdir();
2016-04-03 06:25:41 +08:00
REQUIRE(!file_helper::file_exists(target_filename));
2015-12-13 02:56:39 +08:00
file_helper helper(false);
2016-04-03 06:25:41 +08:00
helper.open(target_filename);
REQUIRE(file_helper::file_exists(target_filename));
2015-12-13 02:56:39 +08:00
}
TEST_CASE("file_helper_reopen", "[file_helper::reopen()]]")
{
prepare_logdir();
file_helper helper(true);
2016-04-03 06:25:41 +08:00
helper.open(target_filename);
2015-12-13 02:56:39 +08:00
write_with_helper(helper, 12);
REQUIRE(helper.size() == 12);
helper.reopen(true);
REQUIRE(helper.size() == 0);
}
TEST_CASE("file_helper_reopen2", "[file_helper::reopen(false)]]")
{
prepare_logdir();
auto expected_size = 14;
file_helper helper(true);
2016-04-03 06:25:41 +08:00
helper.open(target_filename);
2015-12-13 02:56:39 +08:00
write_with_helper(helper, expected_size);
REQUIRE(helper.size() == expected_size);
helper.reopen(false);
REQUIRE(helper.size() == expected_size);
}