Mercurial > irccd
annotate tests/plugin-logger/main.cpp @ 486:0b156b82b8c1
Irccd: rework of paths, closes #611
author | David Demelier <markand@malikania.fr> |
---|---|
date | Thu, 20 Jul 2017 15:12:41 +0200 |
parents | 8b615d37d303 |
children | beb6c638b841 |
rev | line source |
---|---|
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
1 /* |
165 | 2 * main.cpp -- test logger plugin |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
3 * |
394 | 4 * Copyright (c) 2013-2017 David Demelier <markand@malikania.fr> |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
5 * |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
6 * Permission to use, copy, modify, and/or distribute this software for any |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
7 * purpose with or without fee is hereby granted, provided that the above |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
8 * copyright notice and this permission notice appear in all copies. |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
9 * |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
10 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
11 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
12 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
13 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
14 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
15 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
16 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
17 */ |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
18 |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
19 #include <fstream> |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
20 #include <iterator> |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
21 |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
22 #include <gtest/gtest.h> |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
23 |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
24 #include <irccd/irccd.hpp> |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
25 #include <irccd/logger.hpp> |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
26 #include <irccd/server.hpp> |
350 | 27 #include <irccd/service.hpp> |
28 | |
29 #include "plugin-tester.hpp" | |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
30 |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
31 using namespace irccd; |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
32 |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
33 class ServerTest : public Server { |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
34 public: |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
35 inline ServerTest() |
250 | 36 : Server("test") |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
37 { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
38 } |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
39 }; |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
40 |
350 | 41 class LoggerTest : public PluginTester { |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
42 protected: |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
43 std::shared_ptr<ServerTest> m_server; |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
44 std::shared_ptr<Plugin> m_plugin; |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
45 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
46 std::string last() const |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
47 { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
48 std::ifstream file(BINARYDIR "/log.txt"); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
49 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
50 return std::string(std::istreambuf_iterator<char>(file.rdbuf()), {}); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
51 } |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
52 |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
53 public: |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
54 LoggerTest() |
350 | 55 : m_server(std::make_shared<ServerTest>()) |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
56 { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
57 remove(BINARYDIR "/log.txt"); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
58 |
350 | 59 m_irccd.plugins().setFormats("logger", { |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
60 { "cmode", "cmode=#{server}:#{channel}:#{origin}:#{nickname}:#{mode}:#{arg}" }, |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
61 { "cnotice", "cnotice=#{server}:#{channel}:#{origin}:#{nickname}:#{message}" }, |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
62 { "join", "join=#{server}:#{channel}:#{origin}:#{nickname}" }, |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
63 { "kick", "kick=#{server}:#{channel}:#{origin}:#{nickname}:#{target}:#{reason}" }, |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
64 { "me", "me=#{server}:#{channel}:#{origin}:#{nickname}:#{message}" }, |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
65 { "message", "message=#{server}:#{channel}:#{origin}:#{nickname}:#{message}" }, |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
66 { "mode", "mode=#{server}:#{origin}:#{nickname}:#{mode}:#{arg}" }, |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
67 { "notice", "notice=#{server}:#{origin}:#{nickname}:#{message}" }, |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
68 { "part", "part=#{server}:#{channel}:#{origin}:#{nickname}:#{reason}" }, |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
69 { "query", "query=#{server}:#{origin}:#{nickname}:#{message}" }, |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
70 { "topic", "topic=#{server}:#{channel}:#{origin}:#{nickname}:#{topic}" }, |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
71 }); |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
72 } |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
73 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
74 void load(PluginConfig config = PluginConfig()) |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
75 { |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
76 if (config.count("path") == 0) |
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
77 config.emplace("path", BINARYDIR "/log.txt"); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
78 |
350 | 79 m_irccd.plugins().setConfig("logger", config); |
80 m_irccd.plugins().load("logger", PLUGINDIR "/logger.js"); | |
81 m_plugin = m_irccd.plugins().require("logger"); | |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
82 } |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
83 }; |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
84 |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
85 TEST_F(LoggerTest, formatChannelMode) |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
86 { |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
87 load(); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
88 |
210
2d10d7e661a0
Irccd: make object based IRC events, #522
David Demelier <markand@malikania.fr>
parents:
207
diff
changeset
|
89 m_plugin->onChannelMode(m_irccd, ChannelModeEvent{m_server, "jean!jean@localhost", "#staff", "+o", "jean"}); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
90 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
91 ASSERT_EQ("cmode=test:#staff:jean!jean@localhost:jean:+o:jean\n", last()); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
92 } |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
93 |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
94 TEST_F(LoggerTest, formatChannelNotice) |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
95 { |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
96 load(); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
97 |
210
2d10d7e661a0
Irccd: make object based IRC events, #522
David Demelier <markand@malikania.fr>
parents:
207
diff
changeset
|
98 m_plugin->onChannelNotice(m_irccd, ChannelNoticeEvent{m_server, "jean!jean@localhost", "#staff", "bonjour!"}); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
99 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
100 ASSERT_EQ("cnotice=test:#staff:jean!jean@localhost:jean:bonjour!\n", last()); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
101 } |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
102 |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
103 TEST_F(LoggerTest, formatJoin) |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
104 { |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
105 load(); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
106 |
210
2d10d7e661a0
Irccd: make object based IRC events, #522
David Demelier <markand@malikania.fr>
parents:
207
diff
changeset
|
107 m_plugin->onJoin(m_irccd, JoinEvent{m_server, "jean!jean@localhost", "#staff"}); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
108 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
109 ASSERT_EQ("join=test:#staff:jean!jean@localhost:jean\n", last()); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
110 } |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
111 |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
112 TEST_F(LoggerTest, formatKick) |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
113 { |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
114 load(); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
115 |
210
2d10d7e661a0
Irccd: make object based IRC events, #522
David Demelier <markand@malikania.fr>
parents:
207
diff
changeset
|
116 m_plugin->onKick(m_irccd, KickEvent{m_server, "jean!jean@localhost", "#staff", "badboy", "please do not flood"}); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
117 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
118 ASSERT_EQ("kick=test:#staff:jean!jean@localhost:jean:badboy:please do not flood\n", last()); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
119 } |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
120 |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
121 TEST_F(LoggerTest, formatMe) |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
122 { |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
123 load(); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
124 |
210
2d10d7e661a0
Irccd: make object based IRC events, #522
David Demelier <markand@malikania.fr>
parents:
207
diff
changeset
|
125 m_plugin->onMe(m_irccd, MeEvent{m_server, "jean!jean@localhost", "#staff", "is drinking water"}); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
126 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
127 ASSERT_EQ("me=test:#staff:jean!jean@localhost:jean:is drinking water\n", last()); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
128 } |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
129 |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
130 TEST_F(LoggerTest, formatMessage) |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
131 { |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
132 load(); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
133 |
210
2d10d7e661a0
Irccd: make object based IRC events, #522
David Demelier <markand@malikania.fr>
parents:
207
diff
changeset
|
134 m_plugin->onMessage(m_irccd, MessageEvent{m_server, "jean!jean@localhost", "#staff", "hello guys"}); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
135 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
136 ASSERT_EQ("message=test:#staff:jean!jean@localhost:jean:hello guys\n", last()); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
137 } |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
138 |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
139 TEST_F(LoggerTest, formatMode) |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
140 { |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
141 load(); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
142 |
210
2d10d7e661a0
Irccd: make object based IRC events, #522
David Demelier <markand@malikania.fr>
parents:
207
diff
changeset
|
143 m_plugin->onMode(m_irccd, ModeEvent{m_server, "jean!jean@localhost", "+i"}); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
144 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
145 ASSERT_EQ("mode=test:jean!jean@localhost:jean:+i:\n", last()); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
146 } |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
147 |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
148 TEST_F(LoggerTest, formatNotice) |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
149 { |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
150 load(); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
151 |
210
2d10d7e661a0
Irccd: make object based IRC events, #522
David Demelier <markand@malikania.fr>
parents:
207
diff
changeset
|
152 m_plugin->onNotice(m_irccd, NoticeEvent{m_server, "jean!jean@localhost", "tu veux voir mon chat ?"}); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
153 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
154 ASSERT_EQ("notice=test:jean!jean@localhost:jean:tu veux voir mon chat ?\n", last()); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
155 } |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
156 |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
157 TEST_F(LoggerTest, formatPart) |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
158 { |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
159 load(); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
160 |
210
2d10d7e661a0
Irccd: make object based IRC events, #522
David Demelier <markand@malikania.fr>
parents:
207
diff
changeset
|
161 m_plugin->onPart(m_irccd, PartEvent{m_server, "jean!jean@localhost", "#staff", "too noisy here"}); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
162 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
163 ASSERT_EQ("part=test:#staff:jean!jean@localhost:jean:too noisy here\n", last()); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
164 } |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
165 |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
166 TEST_F(LoggerTest, formatQuery) |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
167 { |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
168 load(); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
169 |
210
2d10d7e661a0
Irccd: make object based IRC events, #522
David Demelier <markand@malikania.fr>
parents:
207
diff
changeset
|
170 m_plugin->onQuery(m_irccd, QueryEvent{m_server, "jean!jean@localhost", "much irccd, wow"}); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
171 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
172 ASSERT_EQ("query=test:jean!jean@localhost:jean:much irccd, wow\n", last()); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
173 } |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
174 |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
175 TEST_F(LoggerTest, formatTopic) |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
176 { |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
177 load(); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
178 |
210
2d10d7e661a0
Irccd: make object based IRC events, #522
David Demelier <markand@malikania.fr>
parents:
207
diff
changeset
|
179 m_plugin->onTopic(m_irccd, TopicEvent{m_server, "jean!jean@localhost", "#staff", "oh yeah yeaaaaaaaah"}); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
180 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
181 ASSERT_EQ("topic=test:#staff:jean!jean@localhost:jean:oh yeah yeaaaaaaaah\n", last()); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
182 } |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
183 |
454
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
394
diff
changeset
|
184 TEST_F(LoggerTest, case_fix_642) |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
394
diff
changeset
|
185 { |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
394
diff
changeset
|
186 load(); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
394
diff
changeset
|
187 |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
394
diff
changeset
|
188 m_plugin->onMessage(m_irccd, MessageEvent{m_server, "jean!jean@localhost", "#STAFF", "hello guys"}); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
394
diff
changeset
|
189 |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
394
diff
changeset
|
190 ASSERT_EQ("message=test:#staff:jean!jean@localhost:jean:hello guys\n", last()); |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
394
diff
changeset
|
191 } |
8b615d37d303
Fix #642: plugins must be case sensitive
David Demelier <markand@malikania.fr>
parents:
394
diff
changeset
|
192 |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
193 int main(int argc, char **argv) |
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
194 { |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
195 testing::InitGoogleTest(&argc, argv); |
256
f04acabfbbe5
CMake: switch to NSIS with various fixes, closes #533
David Demelier <markand@malikania.fr>
parents:
250
diff
changeset
|
196 log::setLogger(std::make_unique<log::SilentLogger>()); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
197 |
207
6635b9187d71
Irccd: switch to 4 spaces indent, #518
David Demelier <markand@malikania.fr>
parents:
195
diff
changeset
|
198 return RUN_ALL_TESTS(); |
164
3b38931801ff
Plugin logger: add initial unit test
David Demelier <markand@malikania.fr>
parents:
diff
changeset
|
199 } |