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