Mercurial > irccd
view tests/src/rule-remove-command/main.cpp @ 581:a51b5dd5b761
Tests: put everything in src/
author | David Demelier <markand@malikania.fr> |
---|---|
date | Mon, 04 Dec 2017 14:12:13 +0100 |
parents | tests/rule-remove-command/main.cpp@84ea13c850f4 |
children | 029667d16d12 |
line wrap: on
line source
/* * main.cpp -- test rule-remove remote command * * Copyright (c) 2013-2017 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 "rule-remove" #include <boost/test/unit_test.hpp> #include <irccd/json_util.hpp> #include <irccd/command.hpp> #include <irccd/rule_service.hpp> #include <command_test.hpp> namespace irccd { namespace { class rule_remove_test : public command_test<rule_remove_command> { public: rule_remove_test() { daemon_->commands().add(std::make_unique<rule_list_command>()); daemon_->rules().add(rule( { "s1", "s2" }, { "c1", "c2" }, { "o1", "o2" }, { "p1", "p2" }, { "onMessage", "onCommand" }, rule::action_type::drop )); daemon_->rules().add(rule( { "s1", }, { "c1", }, { "o1", }, { "p1", }, { "onMessage", }, rule::action_type::accept )); } }; } // !namespace BOOST_FIXTURE_TEST_SUITE(rule_remove_test_suite, rule_remove_test) BOOST_AUTO_TEST_CASE(basic) { nlohmann::json result; ctl_->send({ { "command", "rule-remove" }, { "index", 1 } }); ctl_->recv([&] (auto, auto msg) { result = msg; }); wait_for([&] () { return result.is_object(); }); BOOST_TEST(result.is_object()); result = nullptr; ctl_->send({{ "command", "rule-list" }}); ctl_->recv([&] (auto, auto msg) { result = msg; }); wait_for([&] () { return result.is_object(); }); BOOST_TEST(result["list"].is_array()); BOOST_TEST(result["list"].size() == 1U); auto servers = result["list"][0]["servers"]; auto channels = result["list"][0]["channels"]; auto plugins = result["list"][0]["plugins"]; auto events = result["list"][0]["events"]; BOOST_TEST(json_util::contains(servers, "s1")); BOOST_TEST(json_util::contains(servers, "s2")); BOOST_TEST(json_util::contains(channels, "c1")); BOOST_TEST(json_util::contains(channels, "c2")); BOOST_TEST(json_util::contains(plugins, "p1")); BOOST_TEST(json_util::contains(plugins, "p2")); BOOST_TEST(json_util::contains(events, "onMessage")); BOOST_TEST(json_util::contains(events, "onCommand")); BOOST_TEST(result["list"][0]["action"].get<std::string>() == "drop"); } BOOST_AUTO_TEST_CASE(empty) { nlohmann::json result; daemon_->rules().remove(0); daemon_->rules().remove(0); ctl_->send({ { "command", "rule-remove" }, { "index", 1 } }); ctl_->recv([&] (auto, auto msg) { result = msg; }); wait_for([&] () { return result.is_object(); }); BOOST_TEST(result.is_object()); } BOOST_AUTO_TEST_SUITE(errors) BOOST_AUTO_TEST_CASE(invalid_index_1) { boost::system::error_code result; ctl_->send({ { "command", "rule-remove" }, { "index", -100 } }); ctl_->recv([&] (auto code, auto) { result = code; }); wait_for([&] { return result; }); BOOST_ASSERT(result == rule_error::invalid_index); } BOOST_AUTO_TEST_CASE(invalid_index_2) { boost::system::error_code result; ctl_->send({ { "command", "rule-remove" }, { "index", 100 } }); ctl_->recv([&] (auto code, auto) { result = code; }); wait_for([&] { return result; }); BOOST_ASSERT(result == rule_error::invalid_index); } BOOST_AUTO_TEST_CASE(invalid_index_3) { boost::system::error_code result; ctl_->send({ { "command", "rule-remove" }, { "index", "notaint" } }); ctl_->recv([&] (auto code, auto) { result = code; }); wait_for([&] { return result; }); BOOST_ASSERT(result == rule_error::invalid_index); } BOOST_AUTO_TEST_SUITE_END() BOOST_AUTO_TEST_SUITE_END() } // !irccd