Mercurial > irccd
view tests/src/libirccd/command-server-connect/main.cpp @ 670:95ac3ace1610
Common: introduce new io code
To avoid code duplication in accept, connect, reading and writing we add a new
set of classes in `io` namespaces located in the following files:
- stream.hpp, acceptor.hpp, connector.hpp
These classes consist of pure abstract interfaces for I/O. Then we reimplement
them in the following files:
- socket_stream.hpp, socket_acceptor.hpp, socket_connector.hpp,
- tls_stream.hpp, tls_acceptor.hpp, tls_conncetor.hpp (for SSL).
This allows future independant connections such as DBus, fifo or any other fancy
optional stuff.
We also no longer need large class hierarchy such as `connection` for irccdctl
controller or transport_server, transport_client classes.
author | David Demelier <markand@malikania.fr> |
---|---|
date | Tue, 10 Apr 2018 21:20:30 +0200 |
parents | 1081e45b8628 |
children | 2007a37d7e1a |
line wrap: on
line source
/* * main.cpp -- test server-connect 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-connect" #include <boost/test/unit_test.hpp> #include <irccd/daemon/command/server_connect_command.hpp> #include <irccd/daemon/service/server_service.hpp> #include <irccd/test/command_test.hpp> #include <irccd/test/journal_server.hpp> namespace irccd { BOOST_FIXTURE_TEST_SUITE(server_connect_test_suite, command_test<server_connect_command>) BOOST_AUTO_TEST_CASE(minimal) { const auto result = request({ { "command", "server-connect" }, { "name", "local" }, { "host", "irc.example.org" } }); const auto s = daemon_->servers().get("local"); BOOST_TEST(s); BOOST_TEST(s->get_name() == "local"); BOOST_TEST(s->get_host() == "irc.example.org"); BOOST_TEST(s->get_port() == 6667U); } #if defined(HAVE_SSL) BOOST_AUTO_TEST_CASE(full) { const auto result = request({ { "command", "server-connect" }, { "name", "local2" }, { "host", "irc.example2.org" }, { "password", "nonono" }, { "nickname", "francis" }, { "realname", "the_francis" }, { "username", "frc" }, { "ctcpVersion", "ultra bot" }, { "commandChar", "::" }, { "port", 18000 }, { "ssl", true }, { "sslVerify", true }, { "autoRejoin", true }, { "joinInvite", true } }); const auto s = daemon_->servers().get("local2"); BOOST_TEST(s); BOOST_TEST(s->get_name() == "local2"); BOOST_TEST(s->get_host() == "irc.example2.org"); BOOST_TEST(s->get_port() == 18000U); BOOST_TEST(s->get_password() == "nonono"); BOOST_TEST(s->get_nickname() == "francis"); BOOST_TEST(s->get_realname() == "the_francis"); BOOST_TEST(s->get_username() == "frc"); BOOST_TEST(s->get_command_char() == "::"); BOOST_TEST(s->get_ctcp_version() == "ultra bot"); BOOST_TEST(s->get_flags() & server::ssl); BOOST_TEST(s->get_flags() & server::ssl_verify); BOOST_TEST(s->get_flags() & server::auto_rejoin); BOOST_TEST(s->get_flags() & server::join_invite); } #endif // !HAVE_SSL BOOST_AUTO_TEST_SUITE(errors) BOOST_AUTO_TEST_CASE(already_exists) { daemon_->servers().add(std::make_unique<journal_server>(service_, "local")); const auto result = request({ { "command", "server-connect" }, { "name", "local" }, { "host", "127.0.0.1" } }); BOOST_TEST(result.second == server_error::already_exists); BOOST_TEST(result.first["error"].template get<int>() == server_error::already_exists); BOOST_TEST(result.first["errorCategory"].template get<std::string>() == "server"); } BOOST_AUTO_TEST_CASE(invalid_hostname_1) { const auto result = request({ { "command", "server-connect" }, { "name", "new" }, }); BOOST_TEST(result.second == server_error::invalid_hostname); BOOST_TEST(result.first["error"].template get<int>() == server_error::invalid_hostname); BOOST_TEST(result.first["errorCategory"].template get<std::string>() == "server"); } BOOST_AUTO_TEST_CASE(invalid_hostname_2) { const auto result = request({ { "command", "server-connect" }, { "name", "new" }, { "host", 123456 } }); BOOST_TEST(result.second == server_error::invalid_hostname); BOOST_TEST(result.first["error"].template get<int>() == server_error::invalid_hostname); BOOST_TEST(result.first["errorCategory"].template get<std::string>() == "server"); } BOOST_AUTO_TEST_CASE(invalid_identifier_1) { const auto result = request({ { "command", "server-connect" }, { "name", "" }, { "host", "127.0.0.1" } }); 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-connect" }, { "name", 123456 }, { "host", "127.0.0.1" } }); 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_port_1) { const auto result = request({ { "command", "server-connect" }, { "name", "new" }, { "host", "127.0.0.1" }, { "port", "notaint" } }); BOOST_TEST(result.second == server_error::invalid_port); BOOST_TEST(result.first["error"].template get<int>() == server_error::invalid_port); BOOST_TEST(result.first["errorCategory"].template get<std::string>() == "server"); } BOOST_AUTO_TEST_CASE(invalid_port_2) { const auto result = request({ { "command", "server-connect" }, { "name", "new" }, { "host", "127.0.0.1" }, { "port", -123 } }); BOOST_TEST(result.second == server_error::invalid_port); BOOST_TEST(result.first["error"].template get<int>() == server_error::invalid_port); BOOST_TEST(result.first["errorCategory"].template get<std::string>() == "server"); } BOOST_AUTO_TEST_CASE(invalid_port_3) { const auto result = request({ { "command", "server-connect" }, { "name", "new" }, { "host", "127.0.0.1" }, { "port", 1000000 } }); BOOST_TEST(result.second == server_error::invalid_port); BOOST_TEST(result.first["error"].template get<int>() == server_error::invalid_port); BOOST_TEST(result.first["errorCategory"].template get<std::string>() == "server"); } #if !defined(HAVE_SSL) BOOST_AUTO_TEST_CASE(ssl_disabled) { const auto result = request({ { "command", "server-connect" }, { "name", "new" }, { "host", "127.0.0.1" }, { "ssl", true } }); BOOST_TEST(result.second == server_error::ssl_disabled); BOOST_TEST(result.first["error"].template get<int>() == server_error::ssl_disabled); BOOST_TEST(result.first["errorCategory"].template get<std::string>() == "server"); } #endif BOOST_AUTO_TEST_SUITE_END() BOOST_AUTO_TEST_SUITE_END() } // !irccd