2016-04-20 16:57:49 +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;
|
|
|
|
|
|
|
|
static const std::string target_filename = "logs/file_helper_test.txt";
|
|
|
|
|
|
|
|
static void write_with_helper(file_helper &helper, size_t howmany)
|
|
|
|
{
|
|
|
|
log_msg msg;
|
|
|
|
msg.formatted << std::string(howmany, '1');
|
|
|
|
helper.write(msg);
|
2016-10-13 04:08:44 +08:00
|
|
|
helper.flush();
|
2016-04-20 16:57:49 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TEST_CASE("file_helper_filename", "[file_helper::filename()]]")
|
|
|
|
{
|
|
|
|
prepare_logdir();
|
|
|
|
|
2016-09-18 05:43:42 +08:00
|
|
|
file_helper helper;
|
2016-04-20 16:57:49 +08:00
|
|
|
helper.open(target_filename);
|
|
|
|
REQUIRE(helper.filename() == target_filename);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
TEST_CASE("file_helper_size", "[file_helper::size()]]")
|
|
|
|
{
|
|
|
|
prepare_logdir();
|
2016-07-15 23:41:59 +08:00
|
|
|
size_t expected_size = 123;
|
2016-04-20 16:57:49 +08:00
|
|
|
{
|
2016-09-18 05:43:42 +08:00
|
|
|
file_helper helper;
|
2016-04-20 16:57:49 +08:00
|
|
|
helper.open(target_filename);
|
|
|
|
write_with_helper(helper, expected_size);
|
2016-07-15 23:41:59 +08:00
|
|
|
REQUIRE(static_cast<size_t>(helper.size()) == expected_size);
|
2016-04-20 16:57:49 +08:00
|
|
|
}
|
|
|
|
REQUIRE(get_filesize(target_filename) == expected_size);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TEST_CASE("file_helper_exists", "[file_helper::file_exists()]]")
|
|
|
|
{
|
|
|
|
prepare_logdir();
|
|
|
|
REQUIRE(!file_helper::file_exists(target_filename));
|
2016-10-13 04:08:44 +08:00
|
|
|
file_helper helper;
|
2016-04-20 16:57:49 +08:00
|
|
|
helper.open(target_filename);
|
|
|
|
REQUIRE(file_helper::file_exists(target_filename));
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST_CASE("file_helper_reopen", "[file_helper::reopen()]]")
|
|
|
|
{
|
|
|
|
prepare_logdir();
|
2016-09-18 05:43:42 +08:00
|
|
|
file_helper helper;
|
2016-04-20 16:57:49 +08:00
|
|
|
helper.open(target_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();
|
2016-07-31 00:32:51 +08:00
|
|
|
size_t expected_size = 14;
|
2016-10-13 04:08:44 +08:00
|
|
|
file_helper helper;
|
2016-04-20 16:57:49 +08:00
|
|
|
helper.open(target_filename);
|
|
|
|
write_with_helper(helper, expected_size);
|
|
|
|
REQUIRE(helper.size() == expected_size);
|
|
|
|
helper.reopen(false);
|
|
|
|
REQUIRE(helper.size() == expected_size);
|
|
|
|
}
|
|
|
|
|
2017-12-01 09:40:49 +08:00
|
|
|
TEST_CASE("file_helper_split_by_extenstion", "[file_helper::split_by_extenstion()]]")
|
|
|
|
{
|
2017-12-01 09:46:19 +08:00
|
|
|
std::string basename, ext;
|
|
|
|
std::tie(basename, ext) = file_helper::split_by_extenstion("mylog.txt");
|
|
|
|
REQUIRE(basename == "mylog");
|
|
|
|
REQUIRE(ext == ".txt");
|
2017-12-01 09:40:49 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_CASE("file_helper_split_by_extenstion2", "[file_helper::split_by_extenstion()]]")
|
|
|
|
{
|
2017-12-01 09:46:19 +08:00
|
|
|
std::string basename, ext;
|
|
|
|
std::tie(basename, ext) = file_helper::split_by_extenstion("mylog");
|
|
|
|
REQUIRE(basename == "mylog");
|
|
|
|
REQUIRE(ext == "");
|
2017-12-01 09:40:49 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_CASE("file_helper_split_by_extenstion3", "[file_helper::split_by_extenstion()]]")
|
|
|
|
{
|
2017-12-01 09:46:19 +08:00
|
|
|
std::string basename, ext;
|
|
|
|
std::tie(basename, ext) = file_helper::split_by_extenstion("mylog.xyz.txt");
|
|
|
|
REQUIRE(basename == "mylog.xyz");
|
|
|
|
REQUIRE(ext == ".txt");
|
2017-12-01 09:40:49 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TEST_CASE("file_helper_split_by_extenstion4", "[file_helper::split_by_extenstion()]]")
|
|
|
|
{
|
2017-12-01 09:46:19 +08:00
|
|
|
std::string basename, ext;
|
|
|
|
std::tie(basename, ext) = file_helper::split_by_extenstion("mylog.xyz....txt");
|
|
|
|
REQUIRE(basename == "mylog.xyz...");
|
|
|
|
REQUIRE(ext == ".txt");
|
2017-12-01 09:40:49 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_CASE("file_helper_split_by_extenstion5", "[file_helper::split_by_extenstion(hidden_file)]]")
|
|
|
|
{
|
2017-12-01 09:46:19 +08:00
|
|
|
std::string basename, ext;
|
|
|
|
std::tie(basename, ext) = file_helper::split_by_extenstion(".mylog");
|
|
|
|
REQUIRE(basename == ".mylog");
|
|
|
|
REQUIRE(ext == "");
|
2017-12-01 09:40:49 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_CASE("file_helper_split_by_extenstion6", "[file_helper::split_by_extenstion(hidden_file)]]")
|
2017-12-01 09:46:19 +08:00
|
|
|
{
|
2017-12-01 09:40:49 +08:00
|
|
|
#ifdef _WIN32
|
2017-12-01 09:46:19 +08:00
|
|
|
auto filename = "folder\\.mylog";
|
|
|
|
auto expected_basename = "folder\\.mylog";
|
2017-12-01 09:40:49 +08:00
|
|
|
#else
|
2017-12-01 09:46:19 +08:00
|
|
|
auto filename = "folder/.mylog";
|
|
|
|
auto expected_basename = "folder/.mylog";
|
2017-12-01 09:40:49 +08:00
|
|
|
#endif
|
2017-12-01 09:46:19 +08:00
|
|
|
std::string basename, ext;
|
|
|
|
std::tie(basename, ext) = file_helper::split_by_extenstion(filename);
|
|
|
|
REQUIRE(basename == expected_basename);
|
|
|
|
REQUIRE(ext == "");
|
2017-12-01 09:40:49 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
TEST_CASE("file_helper_split_by_extenstion7", "[file_helper::split_by_extenstion(hidden_file)]]")
|
|
|
|
{
|
|
|
|
#ifdef _WIN32
|
2017-12-01 09:46:19 +08:00
|
|
|
auto filename = "folder\\.mylog.txt";
|
|
|
|
auto expected_basename = "folder\\.mylog";
|
2017-12-01 09:40:49 +08:00
|
|
|
#else
|
2017-12-01 09:46:19 +08:00
|
|
|
auto filename = "folder/.mylog.txt";
|
|
|
|
auto expected_basename = "folder/.mylog";
|
2017-12-01 09:40:49 +08:00
|
|
|
#endif
|
2017-12-01 09:46:19 +08:00
|
|
|
std::string basename, ext;
|
|
|
|
std::tie(basename, ext) = file_helper::split_by_extenstion(filename);
|
|
|
|
REQUIRE(basename == expected_basename);
|
|
|
|
REQUIRE(ext == ".txt");
|
2017-12-01 09:40:49 +08:00
|
|
|
}
|
|
|
|
|
2016-04-20 16:57:49 +08:00
|
|
|
|
2017-12-22 17:52:50 +08:00
|
|
|
TEST_CASE("file_helper_split_by_extenstion8", "[file_helper::split_by_extenstion(hidden_file)]]")
|
|
|
|
{
|
|
|
|
#ifdef _WIN32
|
|
|
|
auto filename = "folder.ext\\mylog";
|
|
|
|
auto expected_basename = "folder.ext\\mylog";
|
|
|
|
#else
|
|
|
|
auto filename = "folder.ext/mylog";
|
|
|
|
auto expected_basename = "folder.ext/mylog";
|
|
|
|
#endif
|
|
|
|
std::string basename, ext;
|
|
|
|
std::tie(basename, ext) = file_helper::split_by_extenstion(filename);
|
|
|
|
REQUIRE(basename == expected_basename);
|
|
|
|
REQUIRE(ext == "");
|
|
|
|
}
|
2016-04-20 16:57:49 +08:00
|
|
|
|
|
|
|
|