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