test_file_helper.cpp 3.62 KB
Newer Older
gabime's avatar
gabime committed
1
/*
gabime's avatar
gabime committed
2 3
 * This content is released under the MIT License as specified in https://raw.githubusercontent.com/gabime/spdlog/master/LICENSE
 */
gabime's avatar
gabime committed
4 5
#include "includes.h"

6
using spdlog::details::file_helper;
gabime's avatar
gabime committed
7
using spdlog::details::log_msg;
gabime's avatar
gabime committed
8 9 10 11 12

static const std::string target_filename = "logs/file_helper_test.txt";

static void write_with_helper(file_helper &helper, size_t howmany)
{
13 14 15
    fmt::memory_buffer formatted;
    fmt::format_to(formatted, "{}", std::string(howmany, '1'));
    helper.write(formatted);
gabime's avatar
gabime committed
16
    helper.flush();
gabime's avatar
gabime committed
17 18 19 20 21 22
}

TEST_CASE("file_helper_filename", "[file_helper::filename()]]")
{
    prepare_logdir();

23
    file_helper helper;
gabime's avatar
gabime committed
24 25 26 27 28 29 30
    helper.open(target_filename);
    REQUIRE(helper.filename() == target_filename);
}

TEST_CASE("file_helper_size", "[file_helper::size()]]")
{
    prepare_logdir();
gabime's avatar
gabime committed
31
    size_t expected_size = 123;
gabime's avatar
gabime committed
32
    {
33
        file_helper helper;
gabime's avatar
gabime committed
34 35
        helper.open(target_filename);
        write_with_helper(helper, expected_size);
gabime's avatar
gabime committed
36
        REQUIRE(static_cast<size_t>(helper.size()) == expected_size);
gabime's avatar
gabime committed
37 38 39 40 41 42 43 44
    }
    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));
gabime's avatar
gabime committed
45
    file_helper helper;
gabime's avatar
gabime committed
46 47 48 49 50 51 52
    helper.open(target_filename);
    REQUIRE(file_helper::file_exists(target_filename));
}

TEST_CASE("file_helper_reopen", "[file_helper::reopen()]]")
{
    prepare_logdir();
53
    file_helper helper;
gabime's avatar
gabime committed
54 55 56 57 58 59 60 61 62 63
    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();
64
    size_t expected_size = 14;
gabime's avatar
gabime committed
65
    file_helper helper;
gabime's avatar
gabime committed
66 67 68 69 70 71 72
    helper.open(target_filename);
    write_with_helper(helper, expected_size);
    REQUIRE(helper.size() == expected_size);
    helper.reopen(false);
    REQUIRE(helper.size() == expected_size);
}

gabime's avatar
gabime committed
73
static void test_split_ext(const char *fname, const char *expect_base, const char *expect_ext)
gabime's avatar
gabime committed
74 75 76 77
{
    spdlog::filename_t filename(fname);
    spdlog::filename_t expected_base(expect_base);
    spdlog::filename_t expected_ext(expect_ext);
78

79
#ifdef _WIN32 // replace folder sep
gabime's avatar
gabime committed
80 81
    std::replace(filename.begin(), filename.end(), '/', '\\');
    std::replace(expected_base.begin(), expected_base.end(), '/', '\\');
82
#endif
gabime's avatar
gabime committed
83 84 85 86
    spdlog::filename_t basename, ext;
    std::tie(basename, ext) = file_helper::split_by_extenstion(filename);
    REQUIRE(basename == expected_base);
    REQUIRE(ext == expected_ext);
87 88
}

89
TEST_CASE("file_helper_split_by_extenstion", "[file_helper::split_by_extenstion()]]")
gabime's avatar
gabime committed
90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108
{
    test_split_ext("mylog.txt", "mylog", ".txt");
    test_split_ext(".mylog.txt", ".mylog", ".txt");
    test_split_ext(".mylog", ".mylog", "");
    test_split_ext("/aaa/bb.d/mylog", "/aaa/bb.d/mylog", "");
    test_split_ext("/aaa/bb.d/mylog.txt", "/aaa/bb.d/mylog", ".txt");
    test_split_ext("aaa/bbb/ccc/mylog.txt", "aaa/bbb/ccc/mylog", ".txt");
    test_split_ext("aaa/bbb/ccc/mylog.", "aaa/bbb/ccc/mylog.", "");
    test_split_ext("aaa/bbb/ccc/.mylog.txt", "aaa/bbb/ccc/.mylog", ".txt");
    test_split_ext("/aaa/bbb/ccc/mylog.txt", "/aaa/bbb/ccc/mylog", ".txt");
    test_split_ext("/aaa/bbb/ccc/.mylog", "/aaa/bbb/ccc/.mylog", "");
    test_split_ext("../mylog.txt", "../mylog", ".txt");
    test_split_ext(".././mylog.txt", ".././mylog", ".txt");
    test_split_ext(".././mylog.txt/xxx", ".././mylog.txt/xxx", "");
    test_split_ext("/mylog.txt", "/mylog", ".txt");
    test_split_ext("//mylog.txt", "//mylog", ".txt");
    test_split_ext("", "", "");
    test_split_ext(".", ".", "");
    test_split_ext("..txt", ".", ".txt");
109
}