Mercurial > irccd
annotate tests/js-logger/main.cpp @ 305:e1e596a75355
Tests: add test for server-info, #559
author | David Demelier <markand@malikania.fr> |
---|---|
date | Tue, 18 Oct 2016 18:30:45 +0200 |
parents | f04acabfbbe5 |
children | 287e9ede5eef |
rev | line source |
---|---|
0 | 1 /* |
2 * main.cpp -- test Irccd.Logger API | |
3 * | |
4 * Copyright (c) 2013-2016 David Demelier <markand@malikania.fr> | |
5 * | |
6 * Permission to use, copy, modify, and/or distribute this software for any | |
7 * purpose with or without fee is hereby granted, provided that the above | |
8 * copyright notice and this permission notice appear in all copies. | |
9 * | |
10 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | |
11 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | |
12 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | |
13 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | |
14 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | |
15 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | |
16 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | |
17 */ | |
18 | |
19 #include <gtest/gtest.h> | |
20 | |
170
28080933bac6
Irccd: unbreak test-js-logger
David Demelier <markand@malikania.fr>
parents:
111
diff
changeset
|
21 #include <irccd/irccd.hpp> |
28080933bac6
Irccd: unbreak test-js-logger
David Demelier <markand@malikania.fr>
parents:
111
diff
changeset
|
22 #include <irccd/logger.hpp> |
28080933bac6
Irccd: unbreak test-js-logger
David Demelier <markand@malikania.fr>
parents:
111
diff
changeset
|
23 #include <irccd/mod-irccd.hpp> |
28080933bac6
Irccd: unbreak test-js-logger
David Demelier <markand@malikania.fr>
parents:
111
diff
changeset
|
24 #include <irccd/mod-logger.hpp> |
28080933bac6
Irccd: unbreak test-js-logger
David Demelier <markand@malikania.fr>
parents:
111
diff
changeset
|
25 #include <irccd/plugin-js.hpp> |
28080933bac6
Irccd: unbreak test-js-logger
David Demelier <markand@malikania.fr>
parents:
111
diff
changeset
|
26 #include <irccd/service-module.hpp> |
95
1125d90b3b44
Misc: switch to .hpp, #477
David Demelier <markand@malikania.fr>
parents:
84
diff
changeset
|
27 #include <irccd/sysconfig.hpp> |
0 | 28 |
29 using namespace irccd; | |
30 | |
31 namespace { | |
32 | |
33 std::string lineInfo; | |
34 std::string lineWarning; | |
35 std::string lineDebug; | |
36 | |
37 } // !namespace | |
38 | |
256
f04acabfbbe5
CMake: switch to NSIS with various fixes, closes #533
David Demelier <markand@malikania.fr>
parents:
250
diff
changeset
|
39 class LoggerIfaceTest : public log::Logger { |
0 | 40 public: |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
41 void info(const std::string &line) override |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
42 { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
43 lineInfo = line; |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
44 } |
105
378fdc2c7b56
Irccd: cleanup logging system, #485
David Demelier <markand@malikania.fr>
parents:
95
diff
changeset
|
45 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
46 void warning(const std::string &line) override |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
47 { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
48 lineWarning = line; |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
49 } |
105
378fdc2c7b56
Irccd: cleanup logging system, #485
David Demelier <markand@malikania.fr>
parents:
95
diff
changeset
|
50 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
51 void debug(const std::string &line) override |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
52 { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
53 lineDebug = line; |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
54 } |
0 | 55 }; |
56 | |
170
28080933bac6
Irccd: unbreak test-js-logger
David Demelier <markand@malikania.fr>
parents:
111
diff
changeset
|
57 class TestJsLogger : public testing::Test { |
28080933bac6
Irccd: unbreak test-js-logger
David Demelier <markand@malikania.fr>
parents:
111
diff
changeset
|
58 protected: |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
59 Irccd m_irccd; |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
60 std::shared_ptr<JsPlugin> m_plugin; |
0 | 61 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
62 TestJsLogger() |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
63 : m_plugin(std::make_shared<JsPlugin>("test", SOURCEDIR "/empty.js")) |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
64 { |
250 | 65 m_irccd.modules().get("Irccd")->load(m_irccd, m_plugin); |
66 m_irccd.modules().get("Irccd.Plugin")->load(m_irccd, m_plugin); | |
67 m_irccd.modules().get("Irccd.Logger")->load(m_irccd, m_plugin); | |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
68 } |
170
28080933bac6
Irccd: unbreak test-js-logger
David Demelier <markand@malikania.fr>
parents:
111
diff
changeset
|
69 }; |
75
f8160d515a76
Irccd: rework a lot the JavaScript library
David Demelier <markand@malikania.fr>
parents:
0
diff
changeset
|
70 |
170
28080933bac6
Irccd: unbreak test-js-logger
David Demelier <markand@malikania.fr>
parents:
111
diff
changeset
|
71 TEST_F(TestJsLogger, info) |
28080933bac6
Irccd: unbreak test-js-logger
David Demelier <markand@malikania.fr>
parents:
111
diff
changeset
|
72 { |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
73 try { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
74 if (duk_peval_string(m_plugin->context(), "Irccd.Logger.info(\"hello!\");") != 0) |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
75 throw dukx_exception(m_plugin->context(), -1); |
0 | 76 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
77 ASSERT_EQ("plugin test: hello!", lineInfo); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
78 } catch (const std::exception &ex) { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
79 FAIL() << ex.what(); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
80 } |
0 | 81 } |
82 | |
170
28080933bac6
Irccd: unbreak test-js-logger
David Demelier <markand@malikania.fr>
parents:
111
diff
changeset
|
83 TEST_F(TestJsLogger, warning) |
0 | 84 { |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
85 try { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
86 if (duk_peval_string(m_plugin->context(), "Irccd.Logger.warning(\"FAIL!\");") != 0) |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
87 throw dukx_exception(m_plugin->context(), -1); |
0 | 88 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
89 ASSERT_EQ("plugin test: FAIL!", lineWarning); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
90 } catch (const std::exception &ex) { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
91 FAIL() << ex.what(); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
92 } |
0 | 93 } |
94 | |
95 #if !defined(NDEBUG) | |
96 | |
170
28080933bac6
Irccd: unbreak test-js-logger
David Demelier <markand@malikania.fr>
parents:
111
diff
changeset
|
97 TEST_F(TestJsLogger, debug) |
0 | 98 { |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
99 try { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
100 if (duk_peval_string(m_plugin->context(), "Irccd.Logger.debug(\"starting\");") != 0) |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
101 throw dukx_exception(m_plugin->context(), -1); |
0 | 102 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
103 ASSERT_EQ("plugin test: starting", lineDebug); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
104 } catch (const std::exception &ex) { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
105 FAIL() << ex.what(); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
106 } |
0 | 107 } |
108 | |
109 #endif | |
110 | |
111 int main(int argc, char **argv) | |
112 { | |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
113 testing::InitGoogleTest(&argc, argv); |
0 | 114 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
115 log::setVerbose(true); |
256
f04acabfbbe5
CMake: switch to NSIS with various fixes, closes #533
David Demelier <markand@malikania.fr>
parents:
250
diff
changeset
|
116 log::setLogger(std::make_unique<LoggerIfaceTest>()); |
0 | 117 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
196
diff
changeset
|
118 return RUN_ALL_TESTS(); |
0 | 119 } |