mirror of
https://github.com/gabime/spdlog.git
synced 2024-11-15 16:35:45 +08:00
added file_helper tests
This commit is contained in:
parent
a9fb96e088
commit
a05ba78656
86
tests/file_helper.cpp
Normal file
86
tests/file_helper.cpp
Normal file
@ -0,0 +1,86 @@
|
|||||||
|
/*
|
||||||
|
* 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;
|
||||||
|
|
||||||
|
static const std::string filename = "logs/file_helper_test.txt";
|
||||||
|
|
||||||
|
size_t filesize2(const std::string& filename)
|
||||||
|
{
|
||||||
|
std::ifstream ifs(filename, std::ifstream::ate | std::ifstream::binary);
|
||||||
|
if (!ifs)
|
||||||
|
throw std::runtime_error("Failed open file ");
|
||||||
|
|
||||||
|
return (size_t)ifs.tellg();
|
||||||
|
}
|
||||||
|
|
||||||
|
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);
|
||||||
|
helper.open(filename);
|
||||||
|
REQUIRE(helper.filename() == filename);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
TEST_CASE("file_helper_size", "[file_helper::size()]]")
|
||||||
|
{
|
||||||
|
prepare_logdir();
|
||||||
|
auto expected_size = 123;
|
||||||
|
{
|
||||||
|
file_helper helper(true);
|
||||||
|
helper.open(filename);
|
||||||
|
write_with_helper(helper, expected_size);
|
||||||
|
REQUIRE(helper.size() == expected_size);
|
||||||
|
}
|
||||||
|
REQUIRE(filesize2(filename) == expected_size);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
TEST_CASE("file_helper_exists", "[file_helper::file_exists()]]")
|
||||||
|
{
|
||||||
|
prepare_logdir();
|
||||||
|
REQUIRE(!file_helper::file_exists(filename));
|
||||||
|
file_helper helper(false);
|
||||||
|
helper.open(filename);
|
||||||
|
REQUIRE(file_helper::file_exists(filename));
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST_CASE("file_helper_reopen", "[file_helper::reopen()]]")
|
||||||
|
{
|
||||||
|
prepare_logdir();
|
||||||
|
file_helper helper(true);
|
||||||
|
helper.open(filename);
|
||||||
|
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);
|
||||||
|
helper.open(filename);
|
||||||
|
write_with_helper(helper, expected_size);
|
||||||
|
REQUIRE(helper.size() == expected_size);
|
||||||
|
helper.reopen(false);
|
||||||
|
REQUIRE(helper.size() == expected_size);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user