annotate tests/src/libirccd/logger/main.cpp @ 630:711e0bd01eaf

Irccd: move services to service folder
author David Demelier <markand@malikania.fr>
date Wed, 07 Mar 2018 17:49:56 +0100
parents 27587ff92a64
children e8c4ba5ed1c6
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>
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
23
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
24 #include <irccd/daemon/logger.hpp>
115
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
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
28 class my_logger : public logger {
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
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
34 void write_debug(const std::string& line) override
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
35 {
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
36 line_debug = line;
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
37 }
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
38
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
39 void write_info(const std::string& line) override
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
40 {
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
41 line_info = line;
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
42 }
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
43
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
44 void write_warning(const std::string& line) override
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
45 {
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
46 line_warning = line;
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
47 }
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
48 };
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
49
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
50 class my_filter : public logger_filter {
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
51 public:
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
52 std::string pre_debug(std::string input) const override
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
53 {
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
54 return std::reverse(input.begin(), input.end()), input;
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
55 }
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
56
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
57 std::string pre_info(std::string input) const override
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
58 {
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
59 return std::reverse(input.begin(), input.end()), input;
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
60 }
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
61
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
62 std::string pre_warning(std::string input) const override
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
63 {
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
64 return std::reverse(input.begin(), input.end()), input;
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
65 }
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
66 };
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
67
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
68 class logger_test {
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
69 public:
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
70 my_logger log_;
489
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 logger_test()
207
6635b9187d71 Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents: 115
diff changeset
73 {
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
74 log_.set_filter(std::make_unique<my_filter>());
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
75 log_.set_verbose(true);
207
6635b9187d71 Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents: 115
diff changeset
76 }
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
77 };
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
78
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
79 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
80
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
81 #if !defined(NDEBUG)
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
82
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
83 BOOST_AUTO_TEST_CASE(debug)
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
84 {
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
85 log_.debug("debug");
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
86
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
87 BOOST_REQUIRE_EQUAL("gubed", log_.line_debug);
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
88 }
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 #endif
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
91
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
92 BOOST_AUTO_TEST_CASE(info)
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
93 {
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
94 log_.info("info");
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
95
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
96 BOOST_REQUIRE_EQUAL("ofni", log_.line_info);
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
97 }
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_quiet)
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
100 {
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
101 log_.set_verbose(false);
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
102 log_.info("info");
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
103
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
104 BOOST_REQUIRE(log_.line_info.empty());
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
105 }
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
106
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
107 BOOST_AUTO_TEST_CASE(warning)
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
108 {
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
109 log_.warning("warning");
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
110
599
e531f04507aa Irccd: move logger into libirccd, closes #740
David Demelier <markand@malikania.fr>
parents: 581
diff changeset
111 BOOST_REQUIRE_EQUAL("gninraw", log_.line_warning);
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
112 }
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
113
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
114 BOOST_AUTO_TEST_SUITE_END()
115
9a8f321371f7 Irccd: add filter system in logging, #491
David Demelier <markand@malikania.fr>
parents:
diff changeset
115
489
349fe29d86d5 Tests: switch to Boost, closes #680
David Demelier <markand@malikania.fr>
parents: 488
diff changeset
116 } // !irccd