view tests/src/irccdctl/cli-rule-edit/main.cpp @ 850:688f28dd3241

irccd: remove short options, closes #1673 While here, use a brand new home made option parsing.
author David Demelier <markand@malikania.fr>
date Tue, 16 Jul 2019 20:49:36 +0200
parents 1399755352e7
children eac2cc421f49
line wrap: on
line source

/*
 * main.cpp -- test irccdctl rule-edit
 *
 * Copyright (c) 2013-2019 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 rule-edit"
#include <boost/test/unit_test.hpp>

#include <irccd/test/cli_fixture.hpp>

using irccd::test::cli_fixture;

using irccd::daemon::rule;

namespace irccd {

namespace {

class rule_edit_fixture : public cli_fixture {
public:
	rule_edit_fixture()
		: cli_fixture(IRCCDCTL_EXECUTABLE)
	{
		bot_.get_rules().add({
			{ "s1", "s2" },
			{ "c1", "c2" },
			{ "o1", "o2" },
			{ "p1", "p2" },
			{ "onCommand", "onMessage" },
			rule::action_type::drop
		});
	}
};

BOOST_FIXTURE_TEST_SUITE(rule_edit_suite, rule_edit_fixture)

BOOST_AUTO_TEST_CASE(server)
{
	start();

	{
		const auto [code, out, err] = exec({ "rule-edit",
			"-s ts1",   "-s ts2",
			"-S s1",    "-S s2",
			"0"
		});

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

	{
		const auto [code, out, err] = exec({ "rule-list" });

		BOOST_TEST(!code);
		BOOST_TEST(out.size() == 6U);
		BOOST_TEST(err.size() == 0U);
		BOOST_TEST(out[0]  == "rule:           0");
		BOOST_TEST(out[1]  == "servers:        ts1 ts2 ");
		BOOST_TEST(out[2]  == "channels:       c1 c2 ");
		BOOST_TEST(out[3]  == "plugins:        p1 p2 ");
		BOOST_TEST(out[4]  == "events:         onCommand onMessage ");
		BOOST_TEST(out[5]  == "action:         drop");
	}
}

BOOST_AUTO_TEST_CASE(channel)
{
	start();

	{
		const auto [code, out, err] = exec({ "rule-edit",
			"-c tc1",   "-c tc2",
			"-C c1",    "-C c2",
			"0"
		});

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

	{
		const auto [code, out, err] = exec({ "rule-list" });

		BOOST_TEST(!code);
		BOOST_TEST(out.size() == 6U);
		BOOST_TEST(err.size() == 0U);
		BOOST_TEST(out[0]  == "rule:           0");
		BOOST_TEST(out[1]  == "servers:        s1 s2 ");
		BOOST_TEST(out[2]  == "channels:       tc1 tc2 ");
		BOOST_TEST(out[3]  == "plugins:        p1 p2 ");
		BOOST_TEST(out[4]  == "events:         onCommand onMessage ");
		BOOST_TEST(out[5]  == "action:         drop");
	}
}

BOOST_AUTO_TEST_CASE(plugin)
{
	start();

	{
		const auto [code, out, err] = exec({ "rule-edit",
			"-p tp1",   "-p tp2",
			"-P p1",    "-P p2",
			"0"
		});

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

	{
		const auto [code, out, err] = exec({ "rule-list" });

		BOOST_TEST(!code);
		BOOST_TEST(out.size() == 6U);
		BOOST_TEST(err.size() == 0U);
		BOOST_TEST(out[0]  == "rule:           0");
		BOOST_TEST(out[1]  == "servers:        s1 s2 ");
		BOOST_TEST(out[2]  == "channels:       c1 c2 ");
		BOOST_TEST(out[3]  == "plugins:        tp1 tp2 ");
		BOOST_TEST(out[4]  == "events:         onCommand onMessage ");
		BOOST_TEST(out[5]  == "action:         drop");
	}
}

BOOST_AUTO_TEST_CASE(event)
{
	start();

	{
		const auto [code, out, err] = exec({ "rule-edit",
			"-e onKick",    "-e onNickname",
			"-E onMessage", "-E onCommand",
			"0"
		});

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

	{
		const auto [code, out, err] = exec({ "rule-list" });

		BOOST_TEST(!code);
		BOOST_TEST(out.size() == 6U);
		BOOST_TEST(err.size() == 0U);
		BOOST_TEST(out[0]  == "rule:           0");
		BOOST_TEST(out[1]  == "servers:        s1 s2 ");
		BOOST_TEST(out[2]  == "channels:       c1 c2 ");
		BOOST_TEST(out[3]  == "plugins:        p1 p2 ");
		BOOST_TEST(out[4]  == "events:         onKick onNickname ");
		BOOST_TEST(out[5]  == "action:         drop");
	}
}

BOOST_AUTO_TEST_CASE(action_1)
{
	start();

	{
		const auto [code, out, err] = exec({ "rule-edit", "-a accept", "0" });

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

	{
		const auto [code, out, err] = exec({ "rule-list" });

		BOOST_TEST(!code);
		BOOST_TEST(out.size() == 6U);
		BOOST_TEST(err.size() == 0U);
		BOOST_TEST(out[0]  == "rule:           0");
		BOOST_TEST(out[1]  == "servers:        s1 s2 ");
		BOOST_TEST(out[2]  == "channels:       c1 c2 ");
		BOOST_TEST(out[3]  == "plugins:        p1 p2 ");
		BOOST_TEST(out[4]  == "events:         onCommand onMessage ");
		BOOST_TEST(out[5]  == "action:         accept");
	}
}

BOOST_AUTO_TEST_SUITE(errors)

BOOST_AUTO_TEST_CASE(invalid_index_1)
{
	start();

	const auto [code, out, err] = exec({ "rule-edit", "-p p1", "100" });

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

BOOST_AUTO_TEST_CASE(invalid_index_2)
{
	start();

	const auto [code, out, err] = exec({ "rule-edit", "-p p1", "notaint" });

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

BOOST_AUTO_TEST_CASE(invalid_action)
{
	start();

	const auto [code, out, err] = exec({ "rule-edit", "-a break", "0" });

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

BOOST_AUTO_TEST_SUITE_END()

BOOST_AUTO_TEST_SUITE_END()

} // !namespace

} // !irccd