comparison tests/src/libirccd-daemon/command-server-kick/main.cpp @ 809:8460b4a34191

misc: reorganize namespaces, closes #952 @4h
author David Demelier <markand@malikania.fr>
date Fri, 16 Nov 2018 12:25:00 +0100
parents tests/src/libirccd/command-server-kick/main.cpp@8c44bbcbbab9
children 06cc2f95f479
comparison
equal deleted inserted replaced
808:80bccab4a093 809:8460b4a34191
1 /*
2 * main.cpp -- test server-kick remote command
3 *
4 * Copyright (c) 2013-2018 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 #define BOOST_TEST_MODULE "server-kick"
20 #include <boost/test/unit_test.hpp>
21
22 #include <irccd/test/command_fixture.hpp>
23
24 using irccd::test::command_fixture;
25
26 using irccd::daemon::server;
27 using irccd::daemon::server_error;
28
29 namespace irccd {
30
31 namespace {
32
33 BOOST_FIXTURE_TEST_SUITE(server_kick_fixture_suite, command_fixture)
34
35 BOOST_AUTO_TEST_CASE(basic)
36 {
37 const auto [json, code] = request({
38 { "command", "server-kick" },
39 { "server", "test" },
40 { "target", "francis" },
41 { "channel", "#staff" },
42 { "reason", "too noisy" }
43 });
44
45 const auto cmd = server_->find("kick").back();
46
47 BOOST_TEST(!code);
48 BOOST_TEST(std::any_cast<std::string>(cmd[1]) == "#staff");
49 BOOST_TEST(std::any_cast<std::string>(cmd[0]) == "francis");
50 BOOST_TEST(std::any_cast<std::string>(cmd[2]) == "too noisy");
51 }
52
53 BOOST_AUTO_TEST_CASE(noreason)
54 {
55 const auto [json, code] = request({
56 { "command", "server-kick" },
57 { "server", "test" },
58 { "target", "francis" },
59 { "channel", "#staff" }
60 });
61
62 const auto cmd = server_->find("kick").back();
63
64 BOOST_TEST(!code);
65 BOOST_TEST(std::any_cast<std::string>(cmd[1]) == "#staff");
66 BOOST_TEST(std::any_cast<std::string>(cmd[0]) == "francis");
67 BOOST_TEST(std::any_cast<std::string>(cmd[2]) == "");
68 }
69
70 BOOST_AUTO_TEST_SUITE(errors)
71
72 BOOST_AUTO_TEST_CASE(invalid_identifier_1)
73 {
74 const auto [json, code] = request({
75 { "command", "server-kick" },
76 { "server", 123456 },
77 { "target", "francis" },
78 { "channel", "#music" }
79 });
80
81 BOOST_TEST(code == server_error::invalid_identifier);
82 BOOST_TEST(json["error"].get<int>() == server_error::invalid_identifier);
83 BOOST_TEST(json["errorCategory"].get<std::string>() == "server");
84 }
85
86 BOOST_AUTO_TEST_CASE(invalid_identifier_2)
87 {
88 const auto [json, code] = request({
89 { "command", "server-kick" },
90 { "server", "" },
91 { "target", "francis" },
92 { "channel", "#music" }
93 });
94
95 BOOST_TEST(code == server_error::invalid_identifier);
96 BOOST_TEST(json["error"].get<int>() == server_error::invalid_identifier);
97 BOOST_TEST(json["errorCategory"].get<std::string>() == "server");
98 }
99
100 BOOST_AUTO_TEST_CASE(invalid_nickname_1)
101 {
102 const auto [json, code] = request({
103 { "command", "server-kick" },
104 { "server", "test" },
105 { "target", "" },
106 { "channel", "#music" }
107 });
108
109 BOOST_TEST(code == server_error::invalid_nickname);
110 BOOST_TEST(json["error"].get<int>() == server_error::invalid_nickname);
111 BOOST_TEST(json["errorCategory"].get<std::string>() == "server");
112 }
113
114 BOOST_AUTO_TEST_CASE(invalid_nickname_2)
115 {
116 const auto [json, code] = request({
117 { "command", "server-kick" },
118 { "server", "test" },
119 { "target", 123456 },
120 { "channel", "#music" }
121 });
122
123 BOOST_TEST(code == server_error::invalid_nickname);
124 BOOST_TEST(json["error"].get<int>() == server_error::invalid_nickname);
125 BOOST_TEST(json["errorCategory"].get<std::string>() == "server");
126 }
127
128 BOOST_AUTO_TEST_CASE(invalid_channel_1)
129 {
130 const auto [json, code] = request({
131 { "command", "server-kick" },
132 { "server", "test" },
133 { "target", "jean" },
134 { "channel", "" }
135 });
136
137 BOOST_TEST(code == server_error::invalid_channel);
138 BOOST_TEST(json["error"].get<int>() == server_error::invalid_channel);
139 BOOST_TEST(json["errorCategory"].get<std::string>() == "server");
140 }
141
142 BOOST_AUTO_TEST_CASE(invalid_channel_2)
143 {
144 const auto [json, code] = request({
145 { "command", "server-kick" },
146 { "server", "test" },
147 { "target", "jean" },
148 { "channel", 123456 }
149 });
150
151 BOOST_TEST(code == server_error::invalid_channel);
152 BOOST_TEST(json["error"].get<int>() == server_error::invalid_channel);
153 BOOST_TEST(json["errorCategory"].get<std::string>() == "server");
154 }
155
156 BOOST_AUTO_TEST_CASE(invalid_message)
157 {
158 const auto [json, code] = request({
159 { "command", "server-kick" },
160 { "server", "test" },
161 { "target", "jean" },
162 { "channel", "#staff" },
163 { "reason", 123456 }
164 });
165
166 BOOST_TEST(code == server_error::invalid_message);
167 BOOST_TEST(json["error"].get<int>() == server_error::invalid_message);
168 BOOST_TEST(json["errorCategory"].get<std::string>() == "server");
169 }
170
171 BOOST_AUTO_TEST_CASE(not_found)
172 {
173 const auto [json, code] = request({
174 { "command", "server-kick" },
175 { "server", "unknown" },
176 { "target", "francis" },
177 { "channel", "#music" }
178 });
179
180 BOOST_TEST(code == server_error::not_found);
181 BOOST_TEST(json["error"].get<int>() == server_error::not_found);
182 BOOST_TEST(json["errorCategory"].get<std::string>() == "server");
183 }
184
185 BOOST_AUTO_TEST_SUITE_END()
186
187 BOOST_AUTO_TEST_SUITE_END()
188
189 } // !namespace
190
191 } // !irccd