comparison tests/src/libirccd/command-server-join/main.cpp @ 735:64839725f346

Tests: replace journal_server with mock_server
author David Demelier <markand@malikania.fr>
date Tue, 24 Jul 2018 22:00:00 +0200
parents bd12709b1975
children 190b16cfa848
comparison
equal deleted inserted replaced
734:649bb151f40d 735:64839725f346
21 21
22 #include <irccd/daemon/command/server_join_command.hpp> 22 #include <irccd/daemon/command/server_join_command.hpp>
23 #include <irccd/daemon/service/server_service.hpp> 23 #include <irccd/daemon/service/server_service.hpp>
24 24
25 #include <irccd/test/command_test.hpp> 25 #include <irccd/test/command_test.hpp>
26 #include <irccd/test/journal_server.hpp> 26 #include <irccd/test/mock_server.hpp>
27 27
28 namespace irccd { 28 namespace irccd {
29 29
30 namespace { 30 namespace {
31 31
32 class server_join_test : public command_test<server_join_command> { 32 class server_join_test : public command_test<server_join_command> {
33 protected: 33 protected:
34 std::shared_ptr<journal_server> server_{new journal_server(service_, "test")}; 34 std::shared_ptr<mock_server> server_;
35 35
36 server_join_test() 36 server_join_test()
37 : server_(new mock_server(service_, "test", "localhost"))
37 { 38 {
38 daemon_->servers().add(server_); 39 daemon_->servers().add(server_);
39 server_->cqueue().clear(); 40 server_->clear();
40 } 41 }
41 }; 42 };
42 43
43 BOOST_FIXTURE_TEST_SUITE(server_join_test_suite, server_join_test) 44 BOOST_FIXTURE_TEST_SUITE(server_join_test_suite, server_join_test)
44 45
45 BOOST_AUTO_TEST_CASE(basic) 46 BOOST_AUTO_TEST_CASE(basic)
46 { 47 {
47 ctl_->write({ 48 const auto result = request({
48 { "command", "server-join" }, 49 { "command", "server-join" },
49 { "server", "test" }, 50 { "server", "test" },
50 { "channel", "#music" }, 51 { "channel", "#music" },
51 { "password", "plop" } 52 { "password", "plop" }
52 }); 53 });
53 54
54 wait_for([this] () { 55 const auto cmd = server_->find("join").back();
55 return !server_->cqueue().empty();
56 });
57 56
58 auto cmd = server_->cqueue().back(); 57 BOOST_TEST(std::any_cast<std::string>(cmd[0]) == "#music");
59 58 BOOST_TEST(std::any_cast<std::string>(cmd[1]) == "plop");
60 BOOST_TEST(cmd["command"].get<std::string>() == "join");
61 BOOST_TEST(cmd["channel"].get<std::string>() == "#music");
62 BOOST_TEST(cmd["password"].get<std::string>() == "plop");
63 } 59 }
64 60
65 BOOST_AUTO_TEST_CASE(nopassword) 61 BOOST_AUTO_TEST_CASE(nopassword)
66 { 62 {
67 const auto result = request({ 63 const auto result = request({
68 { "command", "server-join" }, 64 { "command", "server-join" },
69 { "server", "test" }, 65 { "server", "test" },
70 { "channel", "#music" } 66 { "channel", "#music" }
71 }); 67 });
72 68
73 auto cmd = server_->cqueue().back(); 69 const auto cmd = server_->find("join").back();
74 70
75 BOOST_TEST(cmd["command"].get<std::string>() == "join"); 71 BOOST_TEST(std::any_cast<std::string>(cmd[0]) == "#music");
76 BOOST_TEST(cmd["channel"].get<std::string>() == "#music"); 72 BOOST_TEST(std::any_cast<std::string>(cmd[1]) == "");
77 BOOST_TEST(cmd["password"].get<std::string>() == "");
78 } 73 }
79 74
80 BOOST_AUTO_TEST_SUITE(errors) 75 BOOST_AUTO_TEST_SUITE(errors)
81 76
82 BOOST_AUTO_TEST_CASE(invalid_identifier_1) 77 BOOST_AUTO_TEST_CASE(invalid_identifier_1)