diff tests/src/libirccd-daemon/command-plugin-config/main.cpp @ 809:8460b4a34191

misc: reorganize namespaces, closes #952 @4h
author David Demelier <markand@malikania.fr>
date Fri, 16 Nov 2018 12:25:00 +0100
parents tests/src/libirccd/command-plugin-config/main.cpp@8c44bbcbbab9
children 06cc2f95f479
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/src/libirccd-daemon/command-plugin-config/main.cpp	Fri Nov 16 12:25:00 2018 +0100
@@ -0,0 +1,125 @@
+/*
+ * main.cpp -- test plugin-config remote command
+ *
+ * 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 "plugin-config"
+#include <boost/test/unit_test.hpp>
+
+#include <irccd/test/command_fixture.hpp>
+
+using irccd::test::command_fixture;
+using irccd::test::mock_plugin;
+
+using irccd::daemon::plugin_error;
+
+namespace irccd {
+
+namespace {
+
+BOOST_FIXTURE_TEST_SUITE(plugin_config_test_suite, command_fixture)
+
+BOOST_AUTO_TEST_CASE(set)
+{
+	const auto [json, code] = request({
+		{ "command",    "plugin-config" },
+		{ "plugin",     "test"          },
+		{ "variable",   "verbosy"       },
+		{ "value",      "falsy"         }
+	});
+
+	const auto config = bot_.plugins().require("test")->get_options();
+
+	BOOST_TEST(!code);
+	BOOST_TEST(!config.empty());
+	BOOST_TEST(config.at("verbosy") == "falsy");
+}
+
+BOOST_AUTO_TEST_CASE(get)
+{
+	auto plugin = std::make_unique<mock_plugin>("test");
+
+	plugin->set_options({
+		{ "x1", "10" },
+		{ "x2", "20" }
+	});
+	bot_.plugins().clear();
+	bot_.plugins().add(std::move(plugin));
+
+	const auto [json, code] = request({
+		{ "command",    "plugin-config" },
+		{ "plugin",     "test"          },
+		{ "variable",   "x1"            }
+	});
+
+	BOOST_TEST(!code);
+	BOOST_TEST(json["variables"]["x1"].get<std::string>() == "10");
+	BOOST_TEST(json["variables"].count("x2") == 0U);
+}
+
+BOOST_AUTO_TEST_CASE(getall)
+{
+	auto plugin = std::make_unique<mock_plugin>("test");
+
+	plugin->set_options({
+		{ "x1", "10" },
+		{ "x2", "20" }
+	});
+	bot_.plugins().clear();
+	bot_.plugins().add(std::move(plugin));
+
+	const auto [json, code] = request({
+		{ "command",    "plugin-config" },
+		{ "plugin",     "test"          }
+	});
+
+	BOOST_TEST(!code);
+	BOOST_TEST(json["variables"]["x1"].get<std::string>() == "10");
+	BOOST_TEST(json["variables"]["x2"].get<std::string>() == "20");
+}
+
+BOOST_AUTO_TEST_SUITE(errors)
+
+BOOST_AUTO_TEST_CASE(invalid_identifier)
+{
+	const auto [json, code] = request({
+		{ "command", "plugin-config" }
+	});
+
+	BOOST_TEST(code == plugin_error::invalid_identifier);
+	BOOST_TEST(json["error"].get<int>() == plugin_error::invalid_identifier);
+	BOOST_TEST(json["errorCategory"].get<std::string>() == "plugin");
+}
+
+BOOST_AUTO_TEST_CASE(not_found)
+{
+	const auto [json, code] = request({
+		{ "command",    "plugin-config" },
+		{ "plugin",     "unknown"       }
+	});
+
+	BOOST_TEST(code == plugin_error::not_found);
+	BOOST_TEST(json["error"].get<int>() == plugin_error::not_found);
+	BOOST_TEST(json["errorCategory"].get<std::string>() == "plugin");
+}
+
+BOOST_AUTO_TEST_SUITE_END()
+
+BOOST_AUTO_TEST_SUITE_END()
+
+} // !namespace
+
+} // !irccd