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