diff tests/src/libirccd/command-rule-edit/main.cpp @ 611:9fbd1700435b

Tests: reoganize hierarchy
author David Demelier <markand@malikania.fr>
date Fri, 15 Dec 2017 15:37:58 +0100
parents tests/src/rule-edit-command/main.cpp@22b3cd6f991f
children f69b1faf812f
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/src/libirccd/command-rule-edit/main.cpp	Fri Dec 15 15:37:58 2017 +0100
@@ -0,0 +1,646 @@
+/*
+ * main.cpp -- test rule-edit 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-edit"
+#include <boost/test/unit_test.hpp>
+
+#include <irccd/json_util.hpp>
+
+#include <irccd/daemon/command.hpp>
+#include <irccd/daemon/rule_service.hpp>
+
+#include <irccd/test/command_test.hpp>
+
+namespace irccd {
+
+namespace {
+
+class rule_edit_test : public command_test<rule_edit_command, rule_info_command> {
+public:
+    rule_edit_test()
+    {
+        daemon_->rules().add(rule(
+            { "s1", "s2" },
+            { "c1", "c2" },
+            { "o1", "o2" },
+            { "p1", "p2" },
+            { "onMessage", "onCommand" },
+            rule::action_type::drop
+        ));
+    }
+};
+
+} // !namespace
+
+BOOST_FIXTURE_TEST_SUITE(rule_edit_test_suite, rule_edit_test)
+
+BOOST_AUTO_TEST_CASE(add_server)
+{
+    nlohmann::json result;
+
+    ctl_->send({
+        { "command",        "rule-edit"     },
+        { "add-servers",    { "new-s3" }    },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+
+    result = nullptr;
+    ctl_->send({
+        { "command",        "rule-info"     },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+    BOOST_TEST(json_util::contains(result["servers"], "s1"));
+    BOOST_TEST(json_util::contains(result["servers"], "s2"));
+    BOOST_TEST(json_util::contains(result["servers"], "new-s3"));
+    BOOST_TEST(json_util::contains(result["channels"], "c1"));
+    BOOST_TEST(json_util::contains(result["channels"], "c2"));
+    BOOST_TEST(json_util::contains(result["plugins"], "p1"));
+    BOOST_TEST(json_util::contains(result["plugins"], "p2"));
+    BOOST_TEST(json_util::contains(result["events"], "onMessage"));
+    BOOST_TEST(json_util::contains(result["events"], "onCommand"));
+    BOOST_TEST(result["action"].get<std::string>() == "drop");
+}
+
+BOOST_AUTO_TEST_CASE(add_channel)
+{
+    nlohmann::json result;
+
+    ctl_->send({
+        { "command",        "rule-edit"     },
+        { "add-channels",   { "new-c3" }    },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+
+    result = nullptr;
+    ctl_->send({
+        { "command",        "rule-info"     },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+    BOOST_TEST(json_util::contains(result["servers"], "s1"));
+    BOOST_TEST(json_util::contains(result["servers"], "s2"));
+    BOOST_TEST(json_util::contains(result["channels"], "c1"));
+    BOOST_TEST(json_util::contains(result["channels"], "c2"));
+    BOOST_TEST(json_util::contains(result["channels"], "new-c3"));
+    BOOST_TEST(json_util::contains(result["plugins"], "p1"));
+    BOOST_TEST(json_util::contains(result["plugins"], "p2"));
+    BOOST_TEST(json_util::contains(result["events"], "onMessage"));
+    BOOST_TEST(json_util::contains(result["events"], "onCommand"));
+    BOOST_TEST(result["action"].get<std::string>() == "drop");
+}
+
+BOOST_AUTO_TEST_CASE(add_plugin)
+{
+    nlohmann::json result;
+
+    ctl_->send({
+        { "command",        "rule-edit"     },
+        { "add-plugins",    { "new-p3" }    },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+
+    result = nullptr;
+    ctl_->send({
+        { "command",        "rule-info"     },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+    BOOST_TEST(json_util::contains(result["servers"], "s1"));
+    BOOST_TEST(json_util::contains(result["servers"], "s2"));
+    BOOST_TEST(json_util::contains(result["channels"], "c1"));
+    BOOST_TEST(json_util::contains(result["channels"], "c2"));
+    BOOST_TEST(json_util::contains(result["plugins"], "p1"));
+    BOOST_TEST(json_util::contains(result["plugins"], "p2"));
+    BOOST_TEST(json_util::contains(result["plugins"], "new-p3"));
+    BOOST_TEST(json_util::contains(result["events"], "onMessage"));
+    BOOST_TEST(json_util::contains(result["events"], "onCommand"));
+    BOOST_TEST(result["action"].get<std::string>() == "drop");
+}
+
+BOOST_AUTO_TEST_CASE(add_event)
+{
+    nlohmann::json result;
+
+    ctl_->send({
+        { "command",        "rule-edit"     },
+        { "add-events",     { "onQuery" }   },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+
+    result = nullptr;
+    ctl_->send({
+        { "command",        "rule-info"     },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+    BOOST_TEST(json_util::contains(result["servers"], "s1"));
+    BOOST_TEST(json_util::contains(result["servers"], "s2"));
+    BOOST_TEST(json_util::contains(result["channels"], "c1"));
+    BOOST_TEST(json_util::contains(result["channels"], "c2"));
+    BOOST_TEST(json_util::contains(result["plugins"], "p1"));
+    BOOST_TEST(json_util::contains(result["plugins"], "p2"));
+    BOOST_TEST(json_util::contains(result["events"], "onMessage"));
+    BOOST_TEST(json_util::contains(result["events"], "onCommand"));
+    BOOST_TEST(json_util::contains(result["events"], "onQuery"));
+    BOOST_TEST(result["action"].get<std::string>() == "drop");
+}
+
+BOOST_AUTO_TEST_CASE(add_event_and_server)
+{
+    nlohmann::json result;
+
+    ctl_->send({
+        { "command",        "rule-edit"     },
+        { "add-servers",    { "new-s3" }    },
+        { "add-events",     { "onQuery" }   },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+
+    result = nullptr;
+    ctl_->send({
+        { "command",        "rule-info"     },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+    BOOST_TEST(json_util::contains(result["servers"], "s1"));
+    BOOST_TEST(json_util::contains(result["servers"], "s2"));
+    BOOST_TEST(json_util::contains(result["servers"], "new-s3"));
+    BOOST_TEST(json_util::contains(result["channels"], "c1"));
+    BOOST_TEST(json_util::contains(result["channels"], "c2"));
+    BOOST_TEST(json_util::contains(result["plugins"], "p1"));
+    BOOST_TEST(json_util::contains(result["plugins"], "p2"));
+    BOOST_TEST(json_util::contains(result["events"], "onMessage"));
+    BOOST_TEST(json_util::contains(result["events"], "onCommand"));
+    BOOST_TEST(json_util::contains(result["events"], "onQuery"));
+    BOOST_TEST(result["action"].get<std::string>() == "drop");
+}
+
+BOOST_AUTO_TEST_CASE(change_action)
+{
+    nlohmann::json result;
+
+    ctl_->send({
+        { "command",        "rule-edit"     },
+        { "action",         "accept"        },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+
+    result = nullptr;
+    ctl_->send({
+        { "command",        "rule-info"     },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+    BOOST_TEST(json_util::contains(result["servers"], "s1"));
+    BOOST_TEST(json_util::contains(result["servers"], "s2"));
+    BOOST_TEST(json_util::contains(result["channels"], "c1"));
+    BOOST_TEST(json_util::contains(result["channels"], "c2"));
+    BOOST_TEST(json_util::contains(result["plugins"], "p1"));
+    BOOST_TEST(json_util::contains(result["plugins"], "p2"));
+    BOOST_TEST(json_util::contains(result["events"], "onMessage"));
+    BOOST_TEST(json_util::contains(result["events"], "onCommand"));
+    BOOST_TEST(result["action"].get<std::string>() == "accept");
+}
+
+BOOST_AUTO_TEST_CASE(remove_server)
+{
+    nlohmann::json result;
+
+    ctl_->send({
+        { "command",        "rule-edit"     },
+        { "remove-servers", { "s2" }        },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+
+    result = nullptr;
+    ctl_->send({
+        { "command",        "rule-info"     },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+    BOOST_TEST(json_util::contains(result["servers"], "s1"));
+    BOOST_TEST(!json_util::contains(result["servers"], "s2"));
+    BOOST_TEST(json_util::contains(result["channels"], "c1"));
+    BOOST_TEST(json_util::contains(result["channels"], "c2"));
+    BOOST_TEST(json_util::contains(result["plugins"], "p1"));
+    BOOST_TEST(json_util::contains(result["plugins"], "p2"));
+    BOOST_TEST(json_util::contains(result["events"], "onMessage"));
+    BOOST_TEST(json_util::contains(result["events"], "onCommand"));
+    BOOST_TEST(result["action"].get<std::string>() == "drop");
+}
+
+BOOST_AUTO_TEST_CASE(remove_channel)
+{
+    nlohmann::json result;
+
+    ctl_->send({
+        { "command",        "rule-edit"     },
+        { "remove-channels", { "c2" }       },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+
+    result = nullptr;
+    ctl_->send({
+        { "command",        "rule-info"     },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+    BOOST_TEST(json_util::contains(result["servers"], "s1"));
+    BOOST_TEST(json_util::contains(result["servers"], "s2"));
+    BOOST_TEST(json_util::contains(result["channels"], "c1"));
+    BOOST_TEST(!json_util::contains(result["channels"], "c2"));
+    BOOST_TEST(json_util::contains(result["plugins"], "p1"));
+    BOOST_TEST(json_util::contains(result["plugins"], "p2"));
+    BOOST_TEST(json_util::contains(result["events"], "onMessage"));
+    BOOST_TEST(json_util::contains(result["events"], "onCommand"));
+    BOOST_TEST(result["action"].get<std::string>() == "drop");
+}
+
+BOOST_AUTO_TEST_CASE(remove_plugin)
+{
+    nlohmann::json result;
+
+    ctl_->send({
+        { "command",        "rule-edit"     },
+        { "remove-plugins", { "p2" }        },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+
+    result = nullptr;
+    ctl_->send({
+        { "command",        "rule-info"     },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+    BOOST_TEST(json_util::contains(result["servers"], "s1"));
+    BOOST_TEST(json_util::contains(result["servers"], "s2"));
+    BOOST_TEST(json_util::contains(result["channels"], "c1"));
+    BOOST_TEST(json_util::contains(result["channels"], "c2"));
+    BOOST_TEST(json_util::contains(result["plugins"], "p1"));
+    BOOST_TEST(!json_util::contains(result["plugins"], "p2"));
+    BOOST_TEST(json_util::contains(result["events"], "onMessage"));
+    BOOST_TEST(json_util::contains(result["events"], "onCommand"));
+    BOOST_TEST(result["action"].get<std::string>() == "drop");
+}
+
+BOOST_AUTO_TEST_CASE(remove_event)
+{
+    nlohmann::json result;
+
+    ctl_->send({
+        { "command",        "rule-edit"     },
+        { "remove-events",  { "onCommand" } },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+
+    result = nullptr;
+    ctl_->send({
+        { "command",        "rule-info"     },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+    BOOST_TEST(json_util::contains(result["servers"], "s1"));
+    BOOST_TEST(json_util::contains(result["servers"], "s2"));
+    BOOST_TEST(json_util::contains(result["channels"], "c1"));
+    BOOST_TEST(json_util::contains(result["channels"], "c2"));
+    BOOST_TEST(json_util::contains(result["plugins"], "p1"));
+    BOOST_TEST(json_util::contains(result["plugins"], "p2"));
+    BOOST_TEST(json_util::contains(result["events"], "onMessage"));
+    BOOST_TEST(!json_util::contains(result["events"], "onCommand"));
+    BOOST_TEST(result["action"].get<std::string>() == "drop");
+}
+
+BOOST_AUTO_TEST_CASE(remove_event_and_server)
+{
+    nlohmann::json result;
+
+    ctl_->send({
+        { "command",        "rule-edit"     },
+        { "remove-servers", { "s2" }        },
+        { "remove-events",  { "onCommand" } },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+
+    result = nullptr;
+    ctl_->send({
+        { "command",        "rule-info"     },
+        { "index",          0               }
+    });
+    ctl_->recv([&] (auto, auto msg) {
+        result = msg;
+    });
+
+    wait_for([&] () {
+        return result.is_object();
+    });
+
+    BOOST_TEST(result.is_object());
+    BOOST_TEST(json_util::contains(result["servers"], "s1"));
+    BOOST_TEST(!json_util::contains(result["servers"], "s2"));
+    BOOST_TEST(json_util::contains(result["channels"], "c1"));
+    BOOST_TEST(json_util::contains(result["channels"], "c2"));
+    BOOST_TEST(json_util::contains(result["plugins"], "p1"));
+    BOOST_TEST(json_util::contains(result["plugins"], "p2"));
+    BOOST_TEST(json_util::contains(result["events"], "onMessage"));
+    BOOST_TEST(!json_util::contains(result["events"], "onCommand"));
+    BOOST_TEST(result["action"].get<std::string>() == "drop");
+}
+
+BOOST_AUTO_TEST_SUITE(errors)
+
+BOOST_AUTO_TEST_CASE(invalid_index_1)
+{
+    boost::system::error_code result;
+    nlohmann::json message;
+
+    ctl_->send({
+        { "command",    "rule-edit" },
+        { "index",      -100        },
+        { "action",     "drop"      }
+    });
+    ctl_->recv([&] (auto rresult, auto rmessage) {
+        result = rresult;
+        message = rmessage;
+    });
+
+    wait_for([&] {
+        return result;
+    });
+
+    BOOST_TEST(result == rule_error::invalid_index);
+    BOOST_TEST(message["error"].template get<int>() == rule_error::invalid_index);
+    BOOST_TEST(message["errorCategory"].template get<std::string>() == "rule");
+}
+
+BOOST_AUTO_TEST_CASE(invalid_index_2)
+{
+    boost::system::error_code result;
+    nlohmann::json message;
+
+    ctl_->send({
+        { "command",    "rule-edit" },
+        { "index",      100         },
+        { "action",     "drop"      }
+    });
+    ctl_->recv([&] (auto rresult, auto rmessage) {
+        result = rresult;
+        message = rmessage;
+    });
+
+    wait_for([&] {
+        return result;
+    });
+
+    BOOST_TEST(result == rule_error::invalid_index);
+    BOOST_TEST(message["error"].template get<int>() == rule_error::invalid_index);
+    BOOST_TEST(message["errorCategory"].template get<std::string>() == "rule");
+}
+
+BOOST_AUTO_TEST_CASE(invalid_index_3)
+{
+    boost::system::error_code result;
+    nlohmann::json message;
+
+    ctl_->send({
+        { "command",    "rule-edit" },
+        { "index",      "notaint"   },
+        { "action",     "drop"      }
+    });
+    ctl_->recv([&] (auto rresult, auto rmessage) {
+        result = rresult;
+        message = rmessage;
+    });
+
+    wait_for([&] {
+        return result;
+    });
+
+    BOOST_TEST(result == rule_error::invalid_index);
+    BOOST_TEST(message["error"].template get<int>() == rule_error::invalid_index);
+    BOOST_TEST(message["errorCategory"].template get<std::string>() == "rule");
+}
+
+BOOST_AUTO_TEST_CASE(invalid_action)
+{
+    boost::system::error_code result;
+    nlohmann::json message;
+
+    ctl_->send({
+        { "command",    "rule-edit" },
+        { "index",      0           },
+        { "action",     "unknown"   }
+    });
+    ctl_->recv([&] (auto rresult, auto rmessage) {
+        result = rresult;
+        message = rmessage;
+    });
+
+    wait_for([&] {
+        return result;
+    });
+
+    BOOST_TEST(result == rule_error::invalid_action);
+    BOOST_TEST(message["error"].template get<int>() == rule_error::invalid_action);
+    BOOST_TEST(message["errorCategory"].template get<std::string>() == "rule");
+}
+
+BOOST_AUTO_TEST_SUITE_END()
+
+BOOST_AUTO_TEST_SUITE_END()
+
+} // !irccd