annotate tests/logger/main.cpp @ 516:bb65cec664c5

Irccd: use unique_ptr for services
author David Demelier <markand@malikania.fr>
date Thu, 26 Oct 2017 20:45:19 +0200
parents 349fe29d86d5
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
1 /*
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
2 * main.cpp -- test logger functions
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
3 *
394
c6fbb6e0e06d Happy new year!
David Demelier <markand@malikania.fr>
parents: 256
diff changeset
4 * Copyright (c) 2013-2017 David Demelier <markand@malikania.fr>
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
5 *
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
6 * Permission to use, copy, modify, and/or distribute this software for any
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
7 * purpose with or without fee is hereby granted, provided that the above
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
8 * copyright notice and this permission notice appear in all copies.
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
9 *
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
10 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
11 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
12 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
13 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
14 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
15 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
16 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
17 */
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
18
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
19 #include <algorithm>
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
20
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
21 #define BOOST_TEST_MODULE "Logger"
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
22 #include <boost/test/unit_test.hpp>
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
23
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
24 #include <irccd/logger.hpp>
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
25
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
26 namespace irccd {
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
27
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
28 class logger_test {
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
29 public:
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
30 std::string line_debug;
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
31 std::string line_info;
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
32 std::string line_warning;
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
33
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
34 class my_logger : public log::logger {
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
35 private:
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
36 logger_test& test_;
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
37
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
38 public:
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
39 inline my_logger(logger_test& test) noexcept
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
40 : test_(test)
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
41 {
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
42 }
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
43
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
44 void debug(const std::string& line) override
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
45 {
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
46 test_.line_debug = line;
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
47 }
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
48
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
49 void info(const std::string& line) override
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
50 {
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
51 test_.line_info = line;
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
52 }
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
53
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
54 void warning(const std::string& line) override
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
55 {
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
56 test_.line_warning = line;
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
57 }
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
58 };
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
59
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
60 class my_filter : public log::filter {
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
61 public:
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
62 std::string pre_debug(std::string input) const override
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
63 {
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
64 return std::reverse(input.begin(), input.end()), input;
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
65 }
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
66
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
67 std::string pre_info(std::string input) const override
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
68 {
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
69 return std::reverse(input.begin(), input.end()), input;
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
70 }
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
71
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
72 std::string pre_warning(std::string input) const override
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
73 {
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
74 return std::reverse(input.begin(), input.end()), input;
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
75 }
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
76 };
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
77
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
78 logger_test()
207
6635b9187d71 Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents: 115
diff changeset
79 {
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
80 log::set_logger(std::make_unique<my_logger>(*this));
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
81 log::set_filter(std::make_unique<my_filter>());
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
82 log::set_verbose(true);
207
6635b9187d71 Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents: 115
diff changeset
83 }
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
84 };
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
85
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
86 BOOST_FIXTURE_TEST_SUITE(logger_test_suite, logger_test)
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
87
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
88 #if !defined(NDEBUG)
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
89
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
90 BOOST_AUTO_TEST_CASE(debug)
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
91 {
207
6635b9187d71 Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents: 115
diff changeset
92 log::debug("debug");
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
93
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
94 BOOST_REQUIRE_EQUAL("gubed", line_debug);
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
95 }
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
96
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
97 #endif
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
98
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
99 BOOST_AUTO_TEST_CASE(info)
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
100 {
207
6635b9187d71 Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents: 115
diff changeset
101 log::info("info");
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
102
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
103 BOOST_REQUIRE_EQUAL("ofni", line_info);
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
104 }
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
105
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
106 BOOST_AUTO_TEST_CASE(info_quiet)
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
107 {
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
108 log::set_verbose(false);
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
109 log::info("info");
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
110
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
111 BOOST_REQUIRE(line_info.empty());
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
112 }
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
113
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
114 BOOST_AUTO_TEST_CASE(warning)
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
115 {
207
6635b9187d71 Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents: 115
diff changeset
116 log::warning("warning");
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
117
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
118 BOOST_REQUIRE_EQUAL("gninraw", line_warning);
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
119 }
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
120
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
121 BOOST_AUTO_TEST_SUITE_END()
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
122
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
123 } // !irccd