annotate tests/src/libirccd/logger/main.cpp @ 773:8c44bbcbbab9

Misc: style, cleanup and update
author David Demelier <markand@malikania.fr>
date Fri, 26 Oct 2018 13:01:00 +0200
parents 0dbe1842a7d8
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 *
628
27587ff92a64 Misc: update copyrights
David Demelier <markand@malikania.fr>
parents: 611
diff changeset
4 * Copyright (c) 2013-2018 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>
725
0dbe1842a7d8 Irccd: rework loggers, closes #793 @3h
David Demelier <markand@malikania.fr>
parents: 723
diff changeset
23 #include <boost/format.hpp>
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
24
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
25 #include <irccd/daemon/logger.hpp>
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
26
725
0dbe1842a7d8 Irccd: rework loggers, closes #793 @3h
David Demelier <markand@malikania.fr>
parents: 723
diff changeset
27 using boost::format;
0dbe1842a7d8 Irccd: rework loggers, closes #793 @3h
David Demelier <markand@malikania.fr>
parents: 723
diff changeset
28 using boost::str;
0dbe1842a7d8 Irccd: rework loggers, closes #793 @3h
David Demelier <markand@malikania.fr>
parents: 723
diff changeset
29
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
30 namespace irccd {
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
31
723
e8c4ba5ed1c6 Tests: put code in anonymous namespaces, closes #889 @10m
David Demelier <markand@malikania.fr>
parents: 628
diff changeset
32 namespace {
e8c4ba5ed1c6 Tests: put code in anonymous namespaces, closes #889 @10m
David Demelier <markand@malikania.fr>
parents: 628
diff changeset
33
725
0dbe1842a7d8 Irccd: rework loggers, closes #793 @3h
David Demelier <markand@malikania.fr>
parents: 723
diff changeset
34 class sample_sink : public logger::sink {
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
35 public:
773
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
36 std::string line_debug;
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
37 std::string line_info;
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
38 std::string line_warning;
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
39
773
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
40 void write_debug(const std::string& line) override
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
41 {
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
42 line_debug = line;
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
43 }
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
44
773
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
45 void write_info(const std::string& line) override
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
46 {
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
47 line_info = line;
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
48 }
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
49
773
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
50 void write_warning(const std::string& line) override
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
51 {
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
52 line_warning = line;
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
53 }
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
54 };
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
55
725
0dbe1842a7d8 Irccd: rework loggers, closes #793 @3h
David Demelier <markand@malikania.fr>
parents: 723
diff changeset
56 class sample_filter : public logger::filter {
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
57 public:
773
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
58 auto pre_debug(std::string_view category,
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
59 std::string_view component,
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
60 std::string_view message) const -> std::string override
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
61 {
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
62 return str(format("DEBUG %s:%s:%s") % category % component % message);
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
63 }
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
64
773
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
65 auto pre_info(std::string_view category,
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
66 std::string_view component,
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
67 std::string_view message) const -> std::string override
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
68 {
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
69 return str(format("INFO %s:%s:%s") % category % component % message);
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
70 }
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
71
773
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
72 auto pre_warning(std::string_view category,
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
73 std::string_view component,
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
74 std::string_view message) const -> std::string override
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
75 {
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
76 return str(format("WARN %s:%s:%s") % category % component % message);
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
77 }
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
78 };
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
79
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
80 class logger_test {
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
81 public:
773
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
82 sample_sink log_;
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
83
773
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
84 logger_test()
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
85 {
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
86 log_.set_filter(std::make_unique<sample_filter>());
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
87 log_.set_verbose(true);
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
88 }
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
89 };
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
90
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
91 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
92
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
93 #if !defined(NDEBUG)
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
94
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
95 BOOST_AUTO_TEST_CASE(debug)
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
96 {
773
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
97 log_.debug("test", "debug") << "success" << std::endl;
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
98
773
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
99 BOOST_TEST(log_.line_debug == "DEBUG test:debug:success");
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
100 }
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
101
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
102 #endif
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
103
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
104 BOOST_AUTO_TEST_CASE(info)
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
105 {
773
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
106 log_.info("test", "info") << "success" << std::endl;
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
107
773
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
108 BOOST_TEST(log_.line_info == "INFO test:info:success");
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
109 }
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
110
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
111 BOOST_AUTO_TEST_CASE(info_quiet)
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
112 {
773
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
113 log_.set_verbose(false);
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
114 log_.info("test", "info") << "success" << std::endl;
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
115
773
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
116 BOOST_REQUIRE(log_.line_info.empty());
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
117 }
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
118
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
119 BOOST_AUTO_TEST_CASE(warning)
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
120 {
773
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
121 log_.warning("test", "warning") << "success" << std::endl;
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
122
773
8c44bbcbbab9 Misc: style, cleanup and update
David Demelier <markand@malikania.fr>
parents: 725
diff changeset
123 BOOST_TEST(log_.line_warning == "WARN test:warning:success");
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
124 }
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
125
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
126 BOOST_AUTO_TEST_SUITE_END()
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
127
723
e8c4ba5ed1c6 Tests: put code in anonymous namespaces, closes #889 @10m
David Demelier <markand@malikania.fr>
parents: 628
diff changeset
128 } // !namespace
e8c4ba5ed1c6 Tests: put code in anonymous namespaces, closes #889 @10m
David Demelier <markand@malikania.fr>
parents: 628
diff changeset
129
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
130 } // !irccd