Mercurial > irccd
view tests/src/libirccd-daemon/command-hook-add/main.cpp @ 895:f0d6bc79aa32
irccd: implement hooks, closes #2342 @2h
The hook mechanism is an alternative approach to plugins which allow the user to
write lightweight scripts in any language.
author | David Demelier <markand@malikania.fr> |
---|---|
date | Thu, 05 Sep 2019 13:39:32 +0200 |
parents | |
children | 5e25439fe98d |
line wrap: on
line source
/* * main.cpp -- test hook-add remote command * * 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 "hook-add" #include <boost/test/unit_test.hpp> #include <irccd/test/command_fixture.hpp> using std::string; using irccd::daemon::hook; using irccd::daemon::hook_error; namespace irccd { namespace { BOOST_FIXTURE_TEST_SUITE(hook_add_fixture_suite, test::command_fixture) BOOST_AUTO_TEST_CASE(basic) { request({ { "command", "hook-add" }, { "id", "true" }, { "path", "/bin/true" } }); request({ { "command", "hook-add" }, { "id", "false" }, { "path", "/bin/false" } }); BOOST_TEST(bot_.get_hooks().list().size() == 2U); BOOST_TEST(bot_.get_hooks().list()[0].get_id() == "true"); BOOST_TEST(bot_.get_hooks().list()[0].get_path() == "/bin/true"); BOOST_TEST(bot_.get_hooks().list()[1].get_id() == "false"); BOOST_TEST(bot_.get_hooks().list()[1].get_path() == "/bin/false"); } BOOST_AUTO_TEST_SUITE(errors) BOOST_AUTO_TEST_CASE(invalid_identifier) { const auto json = request({ { "command", "hook-add" }, { "id" , "#@#@" } }); BOOST_TEST(json.size() == 4U); BOOST_TEST(json["command"].get<string>() == "hook-add"); BOOST_TEST(json["error"].get<int>() == hook_error::invalid_identifier); BOOST_TEST(json["errorCategory"].get<string>() == "hook"); } BOOST_AUTO_TEST_CASE(invalid_path) { const auto json = request({ { "command", "hook-add" }, { "id", "true" }, { "path", 1234 } }); BOOST_TEST(json.size() == 4U); BOOST_TEST(json["command"].get<string>() == "hook-add"); BOOST_TEST(json["error"].get<int>() == hook_error::invalid_path); BOOST_TEST(json["errorCategory"].get<string>() == "hook"); } BOOST_AUTO_TEST_CASE(already_exists) { bot_.get_hooks().add(hook("true", "/bin/true")); const auto json = request({ { "command", "hook-add" }, { "id", "true" }, { "path", "/bin/true" } }); BOOST_TEST(json.size() == 4U); BOOST_TEST(json["command"].get<string>() == "hook-add"); BOOST_TEST(json["error"].get<int>() == hook_error::already_exists); BOOST_TEST(json["errorCategory"].get<string>() == "hook"); } BOOST_AUTO_TEST_SUITE_END() BOOST_AUTO_TEST_SUITE_END() } // !namespace } // !irccd