comparison tests/server-disconnect-command/main.cpp @ 579:84ea13c850f4

Tests: rename close to target names
author David Demelier <markand@malikania.fr>
date Mon, 04 Dec 2017 13:49:51 +0100
parents tests/cmd-server-disconnect/main.cpp@a8b892177909
children
comparison
equal deleted inserted replaced
578:a8b892177909 579:84ea13c850f4
1 /*
2 * main.cpp -- test server-disconnect remote command
3 *
4 * Copyright (c) 2013-2017 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-disconnect"
20 #include <boost/test/unit_test.hpp>
21
22 #include <irccd/server_service.hpp>
23
24 #include <journal_server.hpp>
25 #include <command_test.hpp>
26
27 namespace irccd {
28
29 namespace {
30
31 class server_disconnect_test : public command_test<server_disconnect_command> {
32 protected:
33 server_disconnect_test()
34 {
35 daemon_->servers().add(std::make_unique<journal_server>(service_, "s1"));
36 daemon_->servers().add(std::make_unique<journal_server>(service_, "s2"));
37 }
38 };
39
40 } // !namespace
41
42 BOOST_FIXTURE_TEST_SUITE(server_disconnect_test_suite, server_disconnect_test)
43
44 BOOST_AUTO_TEST_CASE(one)
45 {
46 nlohmann::json result;
47
48 ctl_->send({
49 { "command", "server-disconnect" },
50 { "server", "s1" }
51 });
52 ctl_->recv([&] (auto, auto msg) {
53 result = msg;
54 });
55
56 wait_for([&] () {
57 return result.is_object();
58 });
59
60 BOOST_TEST(result["command"].get<std::string>() == "server-disconnect");
61 BOOST_TEST(!daemon_->servers().has("s1"));
62 BOOST_TEST(daemon_->servers().has("s2"));
63 }
64
65 BOOST_AUTO_TEST_CASE(all)
66 {
67 nlohmann::json result;
68
69 ctl_->send({{"command", "server-disconnect"}});
70 ctl_->recv([&] (auto, auto msg) {
71 result = msg;
72 });
73
74 wait_for([&] () {
75 return result.is_object();
76 });
77
78 BOOST_TEST(result["command"].get<std::string>() == "server-disconnect");
79 BOOST_TEST(!daemon_->servers().has("s1"));
80 BOOST_TEST(!daemon_->servers().has("s2"));
81 }
82
83 BOOST_AUTO_TEST_SUITE(errors)
84
85 BOOST_AUTO_TEST_CASE(invalid_identifier)
86 {
87 boost::system::error_code result;
88
89 ctl_->send({
90 { "command", "server-disconnect" },
91 { "server", 123456 }
92 });
93 ctl_->recv([&] (auto code, auto) {
94 result = code;
95 });
96
97 wait_for([&] {
98 return result;
99 });
100
101 BOOST_ASSERT(result == server_error::invalid_identifier);
102 }
103
104 BOOST_AUTO_TEST_CASE(not_found)
105 {
106 boost::system::error_code result;
107
108 ctl_->send({
109 { "command", "server-disconnect" },
110 { "server", "unknown" }
111 });
112 ctl_->recv([&] (auto code, auto) {
113 result = code;
114 });
115
116 wait_for([&] {
117 return result;
118 });
119
120 BOOST_ASSERT(result == server_error::not_found);
121 }
122
123 BOOST_AUTO_TEST_SUITE_END()
124
125 BOOST_AUTO_TEST_SUITE_END()
126
127 } // !irccd