Mercurial > irccd
view tests/src/irccdctl/cli-rule-edit/main.cpp @ 670:95ac3ace1610
Common: introduce new io code
To avoid code duplication in accept, connect, reading and writing we add a new
set of classes in `io` namespaces located in the following files:
- stream.hpp, acceptor.hpp, connector.hpp
These classes consist of pure abstract interfaces for I/O. Then we reimplement
them in the following files:
- socket_stream.hpp, socket_acceptor.hpp, socket_connector.hpp,
- tls_stream.hpp, tls_acceptor.hpp, tls_conncetor.hpp (for SSL).
This allows future independant connections such as DBus, fifo or any other fancy
optional stuff.
We also no longer need large class hierarchy such as `connection` for irccdctl
controller or transport_server, transport_client classes.
author | David Demelier <markand@malikania.fr> |
---|---|
date | Tue, 10 Apr 2018 21:20:30 +0200 |
parents | 7ed23c858694 |
children | a4082de4e94e |
line wrap: on
line source
/* * main.cpp -- test irccdctl rule-edit * * 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 rule-edit" #include <boost/test/unit_test.hpp> #include <irccd/test/cli_test.hpp> namespace irccd { BOOST_FIXTURE_TEST_SUITE(rule_edit_suite, cli_test) BOOST_AUTO_TEST_CASE(server) { run_irccd("irccd-rules.conf"); { const auto result = run_irccdctl({ "rule-edit", "-s ts1", "--add-server ts2", "-S s1", "--remove-server s2", "0" }); BOOST_TEST(result.first.size() == 0U); BOOST_TEST(result.second.size() == 0U); } { const auto result = run_irccdctl({ "rule-list" }); BOOST_TEST(result.first.size() == 8U); BOOST_TEST(result.second.size() == 0U); BOOST_TEST(result.first[0] == "rule: 0"); BOOST_TEST(result.first[1] == "servers: ts1 ts2 "); BOOST_TEST(result.first[2] == "channels: c1 c2 "); BOOST_TEST(result.first[3] == "plugins: p1 p2 "); BOOST_TEST(result.first[4] == "events: onCommand onMessage "); BOOST_TEST(result.first[5] == "action: drop"); } } BOOST_AUTO_TEST_CASE(channel) { run_irccd("irccd-rules.conf"); { const auto result = run_irccdctl({ "rule-edit", "-c tc1", "--add-channel tc2", "-C c1", "--remove-channel c2", "0" }); BOOST_TEST(result.first.size() == 0U); BOOST_TEST(result.second.size() == 0U); } { const auto result = run_irccdctl({ "rule-list" }); BOOST_TEST(result.first.size() == 8U); BOOST_TEST(result.second.size() == 0U); BOOST_TEST(result.first[0] == "rule: 0"); BOOST_TEST(result.first[1] == "servers: s1 s2 "); BOOST_TEST(result.first[2] == "channels: tc1 tc2 "); BOOST_TEST(result.first[3] == "plugins: p1 p2 "); BOOST_TEST(result.first[4] == "events: onCommand onMessage "); BOOST_TEST(result.first[5] == "action: drop"); } } BOOST_AUTO_TEST_CASE(plugin) { run_irccd("irccd-rules.conf"); { const auto result = run_irccdctl({ "rule-edit", "-p tp1", "--add-plugin tp2", "-P p1", "--remove-plugin p2", "0" }); BOOST_TEST(result.first.size() == 0U); BOOST_TEST(result.second.size() == 0U); } { const auto result = run_irccdctl({ "rule-list" }); BOOST_TEST(result.first.size() == 8U); BOOST_TEST(result.second.size() == 0U); BOOST_TEST(result.first[0] == "rule: 0"); BOOST_TEST(result.first[1] == "servers: s1 s2 "); BOOST_TEST(result.first[2] == "channels: c1 c2 "); BOOST_TEST(result.first[3] == "plugins: tp1 tp2 "); BOOST_TEST(result.first[4] == "events: onCommand onMessage "); BOOST_TEST(result.first[5] == "action: drop"); } } BOOST_AUTO_TEST_CASE(event) { run_irccd("irccd-rules.conf"); { const auto result = run_irccdctl({ "rule-edit", "-e onKick", "--add-event onNickname", "-E onMessage", "--remove-event onCommand", "0" }); BOOST_TEST(result.first.size() == 0U); BOOST_TEST(result.second.size() == 0U); } { const auto result = run_irccdctl({ "rule-list" }); BOOST_TEST(result.first.size() == 8U); BOOST_TEST(result.second.size() == 0U); BOOST_TEST(result.first[0] == "rule: 0"); BOOST_TEST(result.first[1] == "servers: s1 s2 "); BOOST_TEST(result.first[2] == "channels: c1 c2 "); BOOST_TEST(result.first[3] == "plugins: p1 p2 "); BOOST_TEST(result.first[4] == "events: onKick onNickname "); BOOST_TEST(result.first[5] == "action: drop"); } } BOOST_AUTO_TEST_CASE(action_1) { run_irccd("irccd-rules.conf"); { const auto result = run_irccdctl({ "rule-edit", "-a accept", "0" }); BOOST_TEST(result.first.size() == 0U); BOOST_TEST(result.second.size() == 0U); } { const auto result = run_irccdctl({ "rule-list" }); BOOST_TEST(result.first.size() == 8U); BOOST_TEST(result.second.size() == 0U); BOOST_TEST(result.first[0] == "rule: 0"); BOOST_TEST(result.first[1] == "servers: s1 s2 "); BOOST_TEST(result.first[2] == "channels: c1 c2 "); BOOST_TEST(result.first[3] == "plugins: p1 p2 "); BOOST_TEST(result.first[4] == "events: onCommand onMessage "); BOOST_TEST(result.first[5] == "action: accept"); } } BOOST_AUTO_TEST_CASE(action_2) { run_irccd("irccd-rules.conf"); { const auto result = run_irccdctl({ "rule-edit", "--action accept", "0" }); BOOST_TEST(result.first.size() == 0U); BOOST_TEST(result.second.size() == 0U); } { const auto result = run_irccdctl({ "rule-list" }); BOOST_TEST(result.first.size() == 8U); BOOST_TEST(result.second.size() == 0U); BOOST_TEST(result.first[0] == "rule: 0"); BOOST_TEST(result.first[1] == "servers: s1 s2 "); BOOST_TEST(result.first[2] == "channels: c1 c2 "); BOOST_TEST(result.first[3] == "plugins: p1 p2 "); BOOST_TEST(result.first[4] == "events: onCommand onMessage "); BOOST_TEST(result.first[5] == "action: accept"); } } BOOST_AUTO_TEST_SUITE_END() } // !irccd