view tests/src/irccdctl/cli-server-nick/main.cpp @ 771:aa231a1bf3b7

Irccd: server::set_nickname is no longer virtual Instead, it calls send() or just update nickname depending on the connection state. Also make state_ variable protected to allow derived objects modifying it.
author David Demelier <markand@malikania.fr>
date Mon, 13 Aug 2018 21:32:00 +0200
parents 445c071e8efb
children 8c44bbcbbab9
line wrap: on
line source

/*
 * main.cpp -- test irccdctl server-nick
 *
 * 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 "irccdctl server-nick"
#include <boost/test/unit_test.hpp>

#include <irccd/test/cli_fixture.hpp>

using namespace irccd::test;

namespace irccd {

namespace {

BOOST_FIXTURE_TEST_SUITE(server_nick_suite, cli_fixture)

BOOST_AUTO_TEST_CASE(not_connected)
{
    start();
    server_->disconnect();

    const auto [code, out, err] = exec({ "server-nick", "test", "new" });

    BOOST_TEST(!code);
    BOOST_TEST(out.size() == 0U);
    BOOST_TEST(err.size() == 0U);

    const auto cmd = server_->find("raw");

    BOOST_TEST(cmd.size() == 0U);
    BOOST_TEST(server_->get_nickname() == "new");
}

BOOST_AUTO_TEST_CASE(connected)
{
    start();
    server_->connect([] (auto) {});

    const auto [code, out, err] = exec({ "server-nick", "test", "new" });

    BOOST_TEST(!code);
    BOOST_TEST(out.size() == 0U);
    BOOST_TEST(err.size() == 0U);

    const auto cmd = server_->find("send");

    BOOST_TEST(cmd.size() == 1U);
    BOOST_TEST(std::any_cast<std::string>(cmd[0][0]) == "NICK new");
}


BOOST_AUTO_TEST_SUITE(errors)

BOOST_AUTO_TEST_CASE(invalid_identifier_1)
{
    start();

    const auto [code, out, err] = exec({ "server-nick", "+++", "francis" });

    BOOST_TEST(code);
    BOOST_TEST(out.size() == 0U);
    BOOST_TEST(err.size() == 1U);
    BOOST_TEST(err[0] == "abort: invalid server identifier");
}

BOOST_AUTO_TEST_CASE(not_found)
{
    start();

    const auto [code, out, err] = exec({ "server-nick", "unknown", "francis" });

    BOOST_TEST(code);
    BOOST_TEST(out.size() == 0U);
    BOOST_TEST(err.size() == 1U);
    BOOST_TEST(err[0] == "abort: server not found");
}

BOOST_AUTO_TEST_CASE(invalid_nickname)
{
    start();

    const auto [code, out, err] = exec({ "server-nick", "test", "\"\"" });

    BOOST_TEST(code);
    BOOST_TEST(out.size() == 0U);
    BOOST_TEST(err.size() == 1U);
    BOOST_TEST(err[0] == "abort: invalid nickname");
}

BOOST_AUTO_TEST_SUITE_END()

BOOST_AUTO_TEST_SUITE_END()

} // !namespace

} // !irccd