spdlog
Loading...
Searching...
No Matches
test_file_helper.cpp
Go to the documentation of this file.
1/*
2 * This content is released under the MIT License as specified in https://raw.githubusercontent.com/gabime/spdlog/master/LICENSE
3 */
4#include "includes.h"
5
6#define TEST_FILENAME "test_logs/file_helper_test.txt"
7
9
10static void write_with_helper(file_helper &helper, size_t howmany)
11{
12 spdlog::memory_buf_t formatted;
13 fmt::format_to(std::back_inserter(formatted), "{}", std::string(howmany, '1'));
14 helper.write(formatted);
15 helper.flush();
16}
17
18TEST_CASE("file_helper_filename", "[file_helper::filename()]]")
19{
21
22 file_helper helper;
24 helper.open(target_filename);
25 REQUIRE(helper.filename() == target_filename);
26}
27
28TEST_CASE("file_helper_size", "[file_helper::size()]]")
29{
32 size_t expected_size = 123;
33 {
34 file_helper helper;
35 helper.open(target_filename);
36 write_with_helper(helper, expected_size);
37 REQUIRE(static_cast<size_t>(helper.size()) == expected_size);
38 }
39 REQUIRE(get_filesize(TEST_FILENAME) == expected_size);
40}
41
42TEST_CASE("file_helper_reopen", "[file_helper::reopen()]]")
43{
46 file_helper helper;
47 helper.open(target_filename);
48 write_with_helper(helper, 12);
49 REQUIRE(helper.size() == 12);
50 helper.reopen(true);
51 REQUIRE(helper.size() == 0);
52}
53
54TEST_CASE("file_helper_reopen2", "[file_helper::reopen(false)]]")
55{
58 size_t expected_size = 14;
59 file_helper helper;
60 helper.open(target_filename);
61 write_with_helper(helper, expected_size);
62 REQUIRE(helper.size() == expected_size);
63 helper.reopen(false);
64 REQUIRE(helper.size() == expected_size);
65}
66
67static void test_split_ext(const spdlog::filename_t::value_type *fname, const spdlog::filename_t::value_type *expect_base,
68 const spdlog::filename_t::value_type *expect_ext)
69{
70 spdlog::filename_t filename(fname);
71 spdlog::filename_t expected_base(expect_base);
72 spdlog::filename_t expected_ext(expect_ext);
73
74 spdlog::filename_t basename;
76 std::tie(basename, ext) = file_helper::split_by_extension(filename);
77 REQUIRE(basename == expected_base);
78 REQUIRE(ext == expected_ext);
79}
80
81TEST_CASE("file_helper_split_by_extension", "[file_helper::split_by_extension()]]")
82{
86 test_split_ext(SPDLOG_FILENAME_T("/aaa/bb.d/mylog"), SPDLOG_FILENAME_T("/aaa/bb.d/mylog"), SPDLOG_FILENAME_T(""));
87 test_split_ext(SPDLOG_FILENAME_T("/aaa/bb.d/mylog.txt"), SPDLOG_FILENAME_T("/aaa/bb.d/mylog"), SPDLOG_FILENAME_T(".txt"));
88 test_split_ext(SPDLOG_FILENAME_T("aaa/bbb/ccc/mylog.txt"), SPDLOG_FILENAME_T("aaa/bbb/ccc/mylog"), SPDLOG_FILENAME_T(".txt"));
89 test_split_ext(SPDLOG_FILENAME_T("aaa/bbb/ccc/mylog."), SPDLOG_FILENAME_T("aaa/bbb/ccc/mylog."), SPDLOG_FILENAME_T(""));
90 test_split_ext(SPDLOG_FILENAME_T("aaa/bbb/ccc/.mylog.txt"), SPDLOG_FILENAME_T("aaa/bbb/ccc/.mylog"), SPDLOG_FILENAME_T(".txt"));
91 test_split_ext(SPDLOG_FILENAME_T("/aaa/bbb/ccc/mylog.txt"), SPDLOG_FILENAME_T("/aaa/bbb/ccc/mylog"), SPDLOG_FILENAME_T(".txt"));
92 test_split_ext(SPDLOG_FILENAME_T("/aaa/bbb/ccc/.mylog"), SPDLOG_FILENAME_T("/aaa/bbb/ccc/.mylog"), SPDLOG_FILENAME_T(""));
93 test_split_ext(SPDLOG_FILENAME_T("../mylog.txt"), SPDLOG_FILENAME_T("../mylog"), SPDLOG_FILENAME_T(".txt"));
94 test_split_ext(SPDLOG_FILENAME_T(".././mylog.txt"), SPDLOG_FILENAME_T(".././mylog"), SPDLOG_FILENAME_T(".txt"));
95 test_split_ext(SPDLOG_FILENAME_T(".././mylog.txt/xxx"), SPDLOG_FILENAME_T(".././mylog.txt/xxx"), SPDLOG_FILENAME_T(""));
97 test_split_ext(SPDLOG_FILENAME_T("//mylog.txt"), SPDLOG_FILENAME_T("//mylog"), SPDLOG_FILENAME_T(".txt"));
101}
T back_inserter(T... args)
#define TEST_CASE(...)
Definition catch.hpp:15119
#define REQUIRE(...)
Definition catch.hpp:15083
const filename_t & filename() const
void write(const memory_buf_t &buf)
static std::tuple< filename_t, filename_t > split_by_extension(const filename_t &fname)
void open(const filename_t &fname, bool truncate=false)
#define SPDLOG_FILENAME_T(s)
Definition common.h:107
fmt::basic_memory_buffer< char, 250 > memory_buf_t
Definition common.h:116
#define TEST_FILENAME
static void write_with_helper(file_helper &helper, size_t howmany)
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)
T tie(T... args)
void prepare_logdir()
Definition utils.cpp:10
std::size_t get_filesize(const std::string &filename)
Definition utils.cpp:61