diff tests/src/libirccd-daemon/command-server-info/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-server-info/main.cpp@7145a3df4cb7
children 06cc2f95f479
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/src/libirccd-daemon/command-server-info/main.cpp	Fri Nov 16 12:25:00 2018 +0100
@@ -0,0 +1,111 @@
+/*
+ * main.cpp -- test server-info 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 "server-info"
+#include <boost/test/unit_test.hpp>
+
+#include <irccd/test/command_fixture.hpp>
+
+using irccd::test::command_fixture;
+using irccd::test::mock_server;
+
+using irccd::daemon::server;
+using irccd::daemon::server_error;
+
+namespace irccd {
+
+namespace {
+
+BOOST_FIXTURE_TEST_SUITE(server_info_fixture_suite, command_fixture)
+
+BOOST_AUTO_TEST_CASE(basic)
+{
+	auto server = std::make_unique<mock_server>(ctx_, "test", "example.org");
+
+	server->set_port(8765);
+	server->set_password("none");
+	server->set_nickname("pascal");
+	server->set_username("psc");
+	server->set_realname("Pascal le grand frere");
+	server->set_ctcp_version("yeah");
+	server->set_command_char("@");
+	server->set_ping_timeout(20000);
+
+	bot_.servers().clear();
+	bot_.servers().add(std::move(server));
+
+	const auto [json, code] = request({
+		{ "command",    "server-info"   },
+		{ "server",     "test"          },
+	});
+
+	BOOST_TEST(!code);
+	BOOST_TEST(json.is_object());
+	BOOST_TEST(json["hostname"].get<std::string>() == "example.org");
+	BOOST_TEST(json["name"].get<std::string>() == "test");
+	BOOST_TEST(json["nickname"].get<std::string>() == "pascal");
+	BOOST_TEST(json["port"].get<int>() == 8765);
+	BOOST_TEST(json["realname"].get<std::string>() == "Pascal le grand frere");
+	BOOST_TEST(json["username"].get<std::string>() == "psc");
+}
+
+BOOST_AUTO_TEST_SUITE(errors)
+
+BOOST_AUTO_TEST_CASE(invalid_identifier_1)
+{
+	const auto [json, code] = request({
+		{ "command",    "server-info"   },
+		{ "server",     123456          }
+	});
+
+	BOOST_TEST(code == server_error::invalid_identifier);
+	BOOST_TEST(json["error"].get<int>() == server_error::invalid_identifier);
+	BOOST_TEST(json["errorCategory"].get<std::string>() == "server");
+}
+
+BOOST_AUTO_TEST_CASE(invalid_identifier_2)
+{
+	const auto [json, code] = request({
+		{ "command",    "server-info"   },
+		{ "server",     ""              }
+	});
+
+	BOOST_TEST(code == server_error::invalid_identifier);
+	BOOST_TEST(json["error"].get<int>() == server_error::invalid_identifier);
+	BOOST_TEST(json["errorCategory"].get<std::string>() == "server");
+}
+
+BOOST_AUTO_TEST_CASE(not_found)
+{
+	const auto [json, code] = request({
+		{ "command",    "server-info"   },
+		{ "server",     "unknown"       }
+	});
+
+	BOOST_TEST(code == server_error::not_found);
+	BOOST_TEST(json["error"].get<int>() == server_error::not_found);
+	BOOST_TEST(json["errorCategory"].get<std::string>() == "server");
+}
+
+BOOST_AUTO_TEST_SUITE_END()
+
+BOOST_AUTO_TEST_SUITE_END()
+
+} // !namespace
+
+} // !irccd