comparison tests/src/libirccd-daemon/command-server-nick/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-nick/main.cpp@8c44bbcbbab9
children 06cc2f95f479
comparison
equal deleted inserted replaced
808:80bccab4a093 809:8460b4a34191
1 /*
2 * main.cpp -- test server-nick 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-nick"
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_nick_fixture_suite, command_fixture)
34
35 BOOST_AUTO_TEST_CASE(basic)
36 {
37 const auto [json, code] = request({
38 { "command", "server-nick" },
39 { "server", "test" },
40 { "nickname", "chris" }
41 });
42
43 BOOST_TEST(!code);
44 BOOST_TEST(json.is_object());
45 BOOST_TEST(server_->get_nickname() == "chris");
46 }
47
48 BOOST_AUTO_TEST_SUITE(errors)
49
50 BOOST_AUTO_TEST_CASE(invalid_identifier_1)
51 {
52 const auto [json, code] = request({
53 { "command", "server-nick" },
54 { "server", 123456 },
55 { "nickname", "chris" }
56 });
57
58 BOOST_TEST(code == server_error::invalid_identifier);
59 BOOST_TEST(json["error"].get<int>() == server_error::invalid_identifier);
60 BOOST_TEST(json["errorCategory"].get<std::string>() == "server");
61 }
62
63 BOOST_AUTO_TEST_CASE(invalid_identifier_2)
64 {
65 const auto [json, code] = request({
66 { "command", "server-nick" },
67 { "server", "" },
68 { "nickname", "chris" }
69 });
70
71 BOOST_TEST(code == server_error::invalid_identifier);
72 BOOST_TEST(json["error"].get<int>() == server_error::invalid_identifier);
73 BOOST_TEST(json["errorCategory"].get<std::string>() == "server");
74 }
75
76 BOOST_AUTO_TEST_CASE(invalid_nickname_1)
77 {
78 const auto [json, code] = request({
79 { "command", "server-nick" },
80 { "server", "test" },
81 { "nickname", "" }
82 });
83
84 BOOST_TEST(code == server_error::invalid_nickname);
85 BOOST_TEST(json["error"].get<int>() == server_error::invalid_nickname);
86 BOOST_TEST(json["errorCategory"].get<std::string>() == "server");
87 }
88
89 BOOST_AUTO_TEST_CASE(invalid_nickname_2)
90 {
91 const auto [json, code] = request({
92 { "command", "server-nick" },
93 { "server", "test" },
94 { "nickname", 123456 }
95 });
96
97 BOOST_TEST(code == server_error::invalid_nickname);
98 BOOST_TEST(json["error"].get<int>() == server_error::invalid_nickname);
99 BOOST_TEST(json["errorCategory"].get<std::string>() == "server");
100 }
101 BOOST_AUTO_TEST_CASE(not_found)
102 {
103 const auto [json, code] = request({
104 { "command", "server-nick" },
105 { "server", "unknown" },
106 { "nickname", "chris" }
107 });
108
109 BOOST_TEST(code == server_error::not_found);
110 BOOST_TEST(json["error"].get<int>() == server_error::not_found);
111 BOOST_TEST(json["errorCategory"].get<std::string>() == "server");
112 }
113
114 BOOST_AUTO_TEST_SUITE_END()
115
116 BOOST_AUTO_TEST_SUITE_END()
117
118 } // !namespace
119
120 } // !irccd