Mercurial > irccd
view tests/src/libirccd/command-server-invite/main.cpp @ 733:bd12709b1975
Irccd: rework server to be simpler
Server no longer has signals, now user is responsible of calling connect(),
recv() and pass a completion handler. The recv function will complete with a
std::variant of all possible events.
The server does not manage itself anymore, the reconnection system has been
moved to server_service instead.
To simplify reconnection, the limit has been removed now you can only enable
indefinite reconnection or disable it at all.
closes #893
closes #892
author | David Demelier <markand@malikania.fr> |
---|---|
date | Tue, 24 Jul 2018 21:30:00 +0200 |
parents | e8c4ba5ed1c6 |
children | 64839725f346 |
line wrap: on
line source
/* * main.cpp -- test server-invite remote command * * Copyright (c) 2013-2018 David Demelier <markand@malikania.fr> * * Permission to use, copy, modify, and/or distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice appear in all copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ #define BOOST_TEST_MODULE "server-invite" #include <boost/test/unit_test.hpp> #include <irccd/daemon/command/server_invite_command.hpp> #include <irccd/daemon/service/server_service.hpp> #include <irccd/test/command_test.hpp> #include <irccd/test/journal_server.hpp> namespace irccd { namespace { class server_invite_test : public command_test<server_invite_command> { protected: std::shared_ptr<journal_server> server_{new journal_server(service_, "test")}; server_invite_test() { daemon_->servers().add(server_); server_->cqueue().clear(); } }; BOOST_FIXTURE_TEST_SUITE(server_invite_test_suite, server_invite_test) BOOST_AUTO_TEST_CASE(basic) { ctl_->write({ { "command", "server-invite" }, { "server", "test" }, { "target", "francis" }, { "channel", "#music" } }); wait_for([this] () { return !server_->cqueue().empty(); }); auto cmd = server_->cqueue().back(); BOOST_TEST(cmd["command"].get<std::string>() == "invite"); BOOST_TEST(cmd["channel"].get<std::string>() == "#music"); BOOST_TEST(cmd["target"].get<std::string>() == "francis"); } BOOST_AUTO_TEST_SUITE(errors) BOOST_AUTO_TEST_CASE(invalid_identifier_1) { const auto result = request({ { "command", "server-invite" }, { "server", 123456 }, { "target", "francis" }, { "channel", "#music" } }); BOOST_TEST(result.second == server_error::invalid_identifier); BOOST_TEST(result.first["error"].template get<int>() == server_error::invalid_identifier); BOOST_TEST(result.first["errorCategory"].template get<std::string>() == "server"); } BOOST_AUTO_TEST_CASE(invalid_identifier_2) { const auto result = request({ { "command", "server-invite" }, { "server", "" }, { "target", "francis" }, { "channel", "#music" } }); BOOST_TEST(result.second == server_error::invalid_identifier); BOOST_TEST(result.first["error"].template get<int>() == server_error::invalid_identifier); BOOST_TEST(result.first["errorCategory"].template get<std::string>() == "server"); } BOOST_AUTO_TEST_CASE(invalid_nickname_1) { const auto result = request({ { "command", "server-invite" }, { "server", "test" }, { "target", "" }, { "channel", "#music" } }); BOOST_TEST(result.second == server_error::invalid_nickname); BOOST_TEST(result.first["error"].template get<int>() == server_error::invalid_nickname); BOOST_TEST(result.first["errorCategory"].template get<std::string>() == "server"); } BOOST_AUTO_TEST_CASE(invalid_nickname_2) { const auto result = request({ { "command", "server-invite" }, { "server", "test" }, { "target", 123456 }, { "channel", "#music" } }); BOOST_TEST(result.second == server_error::invalid_nickname); BOOST_TEST(result.first["error"].template get<int>() == server_error::invalid_nickname); BOOST_TEST(result.first["errorCategory"].template get<std::string>() == "server"); } BOOST_AUTO_TEST_CASE(invalid_channel_1) { const auto result = request({ { "command", "server-invite" }, { "server", "test" }, { "target", "jean" }, { "channel", "" } }); BOOST_TEST(result.second == server_error::invalid_channel); BOOST_TEST(result.first["error"].template get<int>() == server_error::invalid_channel); BOOST_TEST(result.first["errorCategory"].template get<std::string>() == "server"); } BOOST_AUTO_TEST_CASE(invalid_channel_2) { const auto result = request({ { "command", "server-invite" }, { "server", "test" }, { "target", "jean" }, { "channel", 123456 } }); BOOST_TEST(result.second == server_error::invalid_channel); BOOST_TEST(result.first["error"].template get<int>() == server_error::invalid_channel); BOOST_TEST(result.first["errorCategory"].template get<std::string>() == "server"); } BOOST_AUTO_TEST_CASE(not_found) { const auto result = request({ { "command", "server-invite" }, { "server", "unknown" }, { "target", "francis" }, { "channel", "#music" } }); BOOST_TEST(result.second == server_error::not_found); BOOST_TEST(result.first["error"].template get<int>() == server_error::not_found); BOOST_TEST(result.first["errorCategory"].template get<std::string>() == "server"); } BOOST_AUTO_TEST_SUITE_END() BOOST_AUTO_TEST_SUITE_END() } // !namespace } // !irccd