2016-04-20 11:57:49 +03:00
|
|
|
/*
|
2023-09-25 16:05:07 +03:00
|
|
|
* This content is released under the MIT License as specified in
|
2023-10-01 12:20:48 +03:00
|
|
|
* https://raw.githubusercontent.com/gabime/spdlog/v2.x/LICENSE
|
2018-03-09 15:26:33 +02:00
|
|
|
*/
|
2016-04-20 11:57:49 +03:00
|
|
|
#include "includes.h"
|
2023-09-29 00:45:09 +03:00
|
|
|
#include "spdlog/sinks/rotating_file_sink.h"
|
2016-04-20 11:57:49 +03:00
|
|
|
|
2021-01-06 18:55:57 -05:00
|
|
|
#define TEST_FILENAME "test_logs/file_helper_test.txt"
|
|
|
|
|
|
2018-02-25 12:12:34 +01:00
|
|
|
using spdlog::details::file_helper;
|
2016-04-20 11:57:49 +03:00
|
|
|
|
2024-12-06 19:21:42 +02:00
|
|
|
static void write_with_helper(const file_helper &helper, size_t howmany) {
|
2019-08-28 18:46:09 +03:00
|
|
|
spdlog::memory_buf_t formatted;
|
2021-11-13 11:29:05 -05:00
|
|
|
spdlog::fmt_lib::format_to(std::back_inserter(formatted), "{}", std::string(howmany, '1'));
|
2018-06-24 01:32:39 +03:00
|
|
|
helper.write(formatted);
|
2016-10-12 23:08:44 +03:00
|
|
|
helper.flush();
|
2016-04-20 11:57:49 +03:00
|
|
|
}
|
|
|
|
|
|
2023-09-25 16:05:07 +03:00
|
|
|
TEST_CASE("file_helper_filename", "[file_helper::filename()]") {
|
2016-04-20 11:57:49 +03:00
|
|
|
prepare_logdir();
|
|
|
|
|
|
2016-09-18 00:43:42 +03:00
|
|
|
file_helper helper;
|
2021-01-06 18:55:57 -05:00
|
|
|
spdlog::filename_t target_filename = SPDLOG_FILENAME_T(TEST_FILENAME);
|
2016-04-20 11:57:49 +03:00
|
|
|
helper.open(target_filename);
|
|
|
|
|
REQUIRE(helper.filename() == target_filename);
|
|
|
|
|
}
|
|
|
|
|
|
2023-09-25 16:05:07 +03:00
|
|
|
TEST_CASE("file_helper_size", "[file_helper::size()]") {
|
2016-04-20 11:57:49 +03:00
|
|
|
prepare_logdir();
|
2021-01-06 18:55:57 -05:00
|
|
|
spdlog::filename_t target_filename = SPDLOG_FILENAME_T(TEST_FILENAME);
|
2016-07-15 18:41:59 +03:00
|
|
|
size_t expected_size = 123;
|
2016-04-20 11:57:49 +03:00
|
|
|
{
|
2016-09-18 00:43:42 +03:00
|
|
|
file_helper helper;
|
2016-04-20 11:57:49 +03:00
|
|
|
helper.open(target_filename);
|
|
|
|
|
write_with_helper(helper, expected_size);
|
2016-07-15 18:41:59 +03:00
|
|
|
REQUIRE(static_cast<size_t>(helper.size()) == expected_size);
|
2016-04-20 11:57:49 +03:00
|
|
|
}
|
2021-01-06 18:55:57 -05:00
|
|
|
REQUIRE(get_filesize(TEST_FILENAME) == expected_size);
|
2016-04-20 11:57:49 +03:00
|
|
|
}
|
|
|
|
|
|
2023-09-25 16:05:07 +03:00
|
|
|
TEST_CASE("file_helper_reopen", "[file_helper::reopen()]") {
|
2016-04-20 11:57:49 +03:00
|
|
|
prepare_logdir();
|
2021-01-06 18:55:57 -05:00
|
|
|
spdlog::filename_t target_filename = SPDLOG_FILENAME_T(TEST_FILENAME);
|
2016-09-18 00:43:42 +03:00
|
|
|
file_helper helper;
|
2016-04-20 11:57:49 +03:00
|
|
|
helper.open(target_filename);
|
|
|
|
|
write_with_helper(helper, 12);
|
2020-04-29 14:50:25 +03:00
|
|
|
REQUIRE(helper.size() == 12);
|
2016-04-20 11:57:49 +03:00
|
|
|
helper.reopen(true);
|
|
|
|
|
REQUIRE(helper.size() == 0);
|
|
|
|
|
}
|
|
|
|
|
|
2023-09-25 16:05:07 +03:00
|
|
|
TEST_CASE("file_helper_reopen2", "[file_helper::reopen(false)]") {
|
2016-04-20 11:57:49 +03:00
|
|
|
prepare_logdir();
|
2021-01-06 18:55:57 -05:00
|
|
|
spdlog::filename_t target_filename = SPDLOG_FILENAME_T(TEST_FILENAME);
|
2016-07-30 19:32:51 +03:00
|
|
|
size_t expected_size = 14;
|
2016-10-12 23:08:44 +03:00
|
|
|
file_helper helper;
|
2016-04-20 11:57:49 +03:00
|
|
|
helper.open(target_filename);
|
|
|
|
|
write_with_helper(helper, expected_size);
|
|
|
|
|
REQUIRE(helper.size() == expected_size);
|
|
|
|
|
helper.reopen(false);
|
|
|
|
|
REQUIRE(helper.size() == expected_size);
|
|
|
|
|
}
|
|
|
|
|
|
2023-09-25 16:05:07 +03:00
|
|
|
static void test_split_ext(const spdlog::filename_t::value_type *fname,
|
|
|
|
|
const spdlog::filename_t::value_type *expect_base,
|
|
|
|
|
const spdlog::filename_t::value_type *expect_ext) {
|
2017-12-22 18:55:19 +02:00
|
|
|
spdlog::filename_t filename(fname);
|
|
|
|
|
spdlog::filename_t expected_base(expect_base);
|
|
|
|
|
spdlog::filename_t expected_ext(expect_ext);
|
2017-12-01 03:40:49 +02:00
|
|
|
|
2020-04-08 18:17:21 +03:00
|
|
|
spdlog::filename_t basename;
|
|
|
|
|
spdlog::filename_t ext;
|
2024-12-05 19:14:25 +02:00
|
|
|
std::tie(basename, ext) = spdlog::details::os::split_by_extension(filename);
|
2017-12-22 18:55:19 +02:00
|
|
|
REQUIRE(basename == expected_base);
|
|
|
|
|
REQUIRE(ext == expected_ext);
|
2017-12-01 03:40:49 +02:00
|
|
|
}
|
|
|
|
|
|
2023-09-25 16:05:07 +03:00
|
|
|
TEST_CASE("file_helper_split_by_extension", "[file_helper::split_by_extension()]") {
|
2024-01-13 09:37:32 +02:00
|
|
|
test_split_ext(SPDLOG_FILENAME_T("mylog.txt"), SPDLOG_FILENAME_T("mylog"), SPDLOG_FILENAME_T(".txt"));
|
|
|
|
|
test_split_ext(SPDLOG_FILENAME_T(".mylog.txt"), SPDLOG_FILENAME_T(".mylog"), SPDLOG_FILENAME_T(".txt"));
|
2021-01-06 03:55:46 -05:00
|
|
|
test_split_ext(SPDLOG_FILENAME_T(".mylog"), SPDLOG_FILENAME_T(".mylog"), SPDLOG_FILENAME_T(""));
|
2024-01-13 09:37:32 +02:00
|
|
|
test_split_ext(SPDLOG_FILENAME_T("/aaa/bb.d/mylog"), SPDLOG_FILENAME_T("/aaa/bb.d/mylog"), SPDLOG_FILENAME_T(""));
|
2024-01-13 18:20:08 +02:00
|
|
|
test_split_ext(SPDLOG_FILENAME_T("/aaa/bb.d/mylog.txt"), SPDLOG_FILENAME_T("/aaa/bb.d/mylog"), SPDLOG_FILENAME_T(".txt"));
|
|
|
|
|
test_split_ext(SPDLOG_FILENAME_T("aaa/bbb/ccc/mylog.txt"), SPDLOG_FILENAME_T("aaa/bbb/ccc/mylog"), SPDLOG_FILENAME_T(".txt"));
|
2024-12-05 19:14:25 +02:00
|
|
|
test_split_ext(SPDLOG_FILENAME_T("aaa/bbb/ccc/mylog."), SPDLOG_FILENAME_T("aaa/bbb/ccc/mylog"), SPDLOG_FILENAME_T("."));
|
2024-01-13 09:37:32 +02:00
|
|
|
test_split_ext(SPDLOG_FILENAME_T("aaa/bbb/ccc/.mylog.txt"), SPDLOG_FILENAME_T("aaa/bbb/ccc/.mylog"),
|
2023-09-25 16:05:07 +03:00
|
|
|
SPDLOG_FILENAME_T(".txt"));
|
2024-01-13 09:37:32 +02:00
|
|
|
test_split_ext(SPDLOG_FILENAME_T("/aaa/bbb/ccc/mylog.txt"), SPDLOG_FILENAME_T("/aaa/bbb/ccc/mylog"),
|
2023-09-25 16:05:07 +03:00
|
|
|
SPDLOG_FILENAME_T(".txt"));
|
2024-01-13 18:20:08 +02:00
|
|
|
test_split_ext(SPDLOG_FILENAME_T("/aaa/bbb/ccc/.mylog"), SPDLOG_FILENAME_T("/aaa/bbb/ccc/.mylog"), SPDLOG_FILENAME_T(""));
|
2024-01-13 09:37:32 +02:00
|
|
|
test_split_ext(SPDLOG_FILENAME_T("../mylog.txt"), SPDLOG_FILENAME_T("../mylog"), SPDLOG_FILENAME_T(".txt"));
|
|
|
|
|
test_split_ext(SPDLOG_FILENAME_T(".././mylog.txt"), SPDLOG_FILENAME_T(".././mylog"), SPDLOG_FILENAME_T(".txt"));
|
2024-01-13 18:20:08 +02:00
|
|
|
test_split_ext(SPDLOG_FILENAME_T(".././mylog.txt/xxx"), SPDLOG_FILENAME_T(".././mylog.txt/xxx"), SPDLOG_FILENAME_T(""));
|
2024-01-13 09:37:32 +02:00
|
|
|
test_split_ext(SPDLOG_FILENAME_T("/mylog.txt"), SPDLOG_FILENAME_T("/mylog"), SPDLOG_FILENAME_T(".txt"));
|
2024-12-05 19:14:25 +02:00
|
|
|
test_split_ext(SPDLOG_FILENAME_T("///mylog.txt"), SPDLOG_FILENAME_T("///mylog"), SPDLOG_FILENAME_T(".txt"));
|
2021-01-06 03:55:46 -05:00
|
|
|
test_split_ext(SPDLOG_FILENAME_T(""), SPDLOG_FILENAME_T(""), SPDLOG_FILENAME_T(""));
|
|
|
|
|
test_split_ext(SPDLOG_FILENAME_T("."), SPDLOG_FILENAME_T("."), SPDLOG_FILENAME_T(""));
|
|
|
|
|
test_split_ext(SPDLOG_FILENAME_T("..txt"), SPDLOG_FILENAME_T("."), SPDLOG_FILENAME_T(".txt"));
|
2017-12-22 17:52:50 +08:00
|
|
|
}
|
2021-12-09 23:43:49 +02:00
|
|
|
|
2023-09-25 16:05:07 +03:00
|
|
|
TEST_CASE("file_event_handlers", "[file_helper]") {
|
|
|
|
|
enum class flags { before_open, after_open, before_close, after_close };
|
2021-12-09 23:43:49 +02:00
|
|
|
prepare_logdir();
|
2022-02-12 13:20:15 +02:00
|
|
|
|
2021-12-11 00:38:41 +02:00
|
|
|
spdlog::filename_t test_filename = SPDLOG_FILENAME_T(TEST_FILENAME);
|
2021-12-10 00:12:20 +02:00
|
|
|
// define event handles that update vector of flags when called
|
|
|
|
|
std::vector<flags> events;
|
2021-12-09 23:43:49 +02:00
|
|
|
spdlog::file_event_handlers handlers;
|
|
|
|
|
handlers.before_open = [&](spdlog::filename_t filename) {
|
2021-12-10 18:31:32 +02:00
|
|
|
REQUIRE(filename == test_filename);
|
2021-12-10 00:12:20 +02:00
|
|
|
events.push_back(flags::before_open);
|
2021-12-09 23:43:49 +02:00
|
|
|
};
|
2022-02-12 13:20:15 +02:00
|
|
|
handlers.after_open = [&](spdlog::filename_t filename, std::FILE *fstream) {
|
2021-12-10 18:31:32 +02:00
|
|
|
REQUIRE(filename == test_filename);
|
2021-12-09 23:43:49 +02:00
|
|
|
REQUIRE(fstream);
|
2021-12-10 00:28:25 +02:00
|
|
|
fputs("after_open\n", fstream);
|
2021-12-10 00:12:20 +02:00
|
|
|
events.push_back(flags::after_open);
|
2021-12-09 23:43:49 +02:00
|
|
|
};
|
2022-02-12 13:20:15 +02:00
|
|
|
handlers.before_close = [&](spdlog::filename_t filename, std::FILE *fstream) {
|
2021-12-10 18:31:32 +02:00
|
|
|
REQUIRE(filename == test_filename);
|
2021-12-09 23:43:49 +02:00
|
|
|
REQUIRE(fstream);
|
2021-12-10 00:28:25 +02:00
|
|
|
fputs("before_close\n", fstream);
|
2021-12-10 00:12:20 +02:00
|
|
|
events.push_back(flags::before_close);
|
2021-12-09 23:43:49 +02:00
|
|
|
};
|
|
|
|
|
handlers.after_close = [&](spdlog::filename_t filename) {
|
2021-12-10 18:31:32 +02:00
|
|
|
REQUIRE(filename == test_filename);
|
2021-12-10 00:12:20 +02:00
|
|
|
events.push_back(flags::after_close);
|
2021-12-09 23:43:49 +02:00
|
|
|
};
|
2021-12-10 00:12:20 +02:00
|
|
|
{
|
|
|
|
|
spdlog::details::file_helper helper{handlers};
|
|
|
|
|
REQUIRE(events.empty());
|
|
|
|
|
|
2021-12-10 18:31:32 +02:00
|
|
|
helper.open(test_filename);
|
2021-12-10 00:12:20 +02:00
|
|
|
REQUIRE(events == std::vector<flags>{flags::before_open, flags::after_open});
|
2022-02-12 13:20:15 +02:00
|
|
|
|
|
|
|
|
events.clear();
|
|
|
|
|
helper.close();
|
2021-12-10 00:12:20 +02:00
|
|
|
REQUIRE(events == std::vector<flags>{flags::before_close, flags::after_close});
|
2025-01-05 02:17:31 +02:00
|
|
|
REQUIRE(file_contents(SPDLOG_FILENAME_T(TEST_FILENAME)) == "after_open\nbefore_close\n");
|
2021-12-10 00:12:20 +02:00
|
|
|
|
|
|
|
|
helper.reopen(true);
|
2022-02-12 13:20:15 +02:00
|
|
|
events.clear();
|
2021-12-10 00:12:20 +02:00
|
|
|
}
|
2024-02-12 22:02:31 +01:00
|
|
|
// make sure that the file_helper destructor calls the close callbacks if needed
|
2021-12-10 00:12:20 +02:00
|
|
|
REQUIRE(events == std::vector<flags>{flags::before_close, flags::after_close});
|
2021-12-10 22:31:08 +02:00
|
|
|
REQUIRE(file_contents(TEST_FILENAME) == "after_open\nbefore_close\n");
|
2021-12-09 23:43:49 +02:00
|
|
|
}
|
2022-03-11 19:22:45 +00:00
|
|
|
|
2023-09-25 16:05:07 +03:00
|
|
|
TEST_CASE("file_helper_open", "[file_helper]") {
|
2022-03-11 19:22:45 +00:00
|
|
|
prepare_logdir();
|
|
|
|
|
spdlog::filename_t target_filename = SPDLOG_FILENAME_T(TEST_FILENAME);
|
|
|
|
|
file_helper helper;
|
|
|
|
|
helper.open(target_filename);
|
|
|
|
|
helper.close();
|
|
|
|
|
|
|
|
|
|
target_filename += SPDLOG_FILENAME_T("/invalid");
|
|
|
|
|
REQUIRE_THROWS_AS(helper.open(target_filename), spdlog::spdlog_ex);
|
|
|
|
|
}
|