Mercurial > irccd
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 |
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 |