/* * Copyright (c) 2016 MariaDB Corporation Ab * * Use of this software is governed by the Business Source License included * in the LICENSE.TXT file and at www.mariadb.com/bsl11. * * Change Date: 2024-04-23 * * On the date above, in accordance with the Business Source License, use * of this software will be governed by version 2 or later of the General * Public License. */ // To ensure that ss_info_assert asserts also when builing in non-debug mode. #if !defined (SS_DEBUG) #define SS_DEBUG #endif #if defined (NDEBUG) #undef NDEBUG #endif #include #include #include #include #include #include #include // This is pretty ugly but it's required to test internal functions #include "../config.cc" #include "../server.cc" #include "../internal/server.hh" static MXS_CONFIG_PARAMETER* params = new MXS_CONFIG_PARAMETER; /** * test1 Allocate a server and do lots of other things * */ static int test1() { std::string status; /* Server tests */ fprintf(stderr, "testserver : creating server called MyServer"); Server* server = Server::server_alloc("uniquename", *params); mxb_assert_message(server, "Allocating the server should not fail"); fprintf(stderr, "\t..done\nTest Parameter for Server."); mxb_assert_message(server->get_custom_parameter("name").empty(), "Parameter should be empty when not set"); server->set_custom_parameter("name", "value"); std::string buf = server->get_custom_parameter("name"); mxb_assert_message(buf == "value", "Parameter should be returned correctly"); fprintf(stderr, "\t..done\nTesting Unique Name for Server."); mxb_assert_message(NULL == Server::find_by_unique_name("non-existent"), "Should not find non-existent unique name."); mxb_assert_message(server == Server::find_by_unique_name("uniquename"), "Should find by unique name."); fprintf(stderr, "\t..done\nTesting Status Setting for Server."); status = server->status_string(); mxb_assert_message(status == "Running", "Status of Server should be Running by default."); server->set_status(SERVER_MASTER); status = server->status_string(); mxb_assert_message(status == "Master, Running", "Should find correct status."); server->clear_status(SERVER_MASTER); status = server->status_string(); mxb_assert_message(status == "Running", "Status of Server should be Running after master status cleared."); fprintf(stderr, "\t..done\nRun Prints for Server and all Servers."); server->printServer(); Server::printAllServers(); fprintf(stderr, "\t..done\nFreeing Server."); Server::server_free(server); fprintf(stderr, "\t..done\n"); return 0; } #define TEST(A, B) do {if (!(A)) {printf(B "\n"); return false;}} while (false) bool test_load_config(const char* input, Server* server) { DUPLICATE_CONTEXT dcontext; if (duplicate_context_init(&dcontext)) { CONFIG_CONTEXT ccontext; if (config_load_single_file(input, &dcontext, &ccontext)) { CONFIG_CONTEXT* obj = ccontext.m_next; MXS_CONFIG_PARAMETER* param = &obj->m_parameters; config_add_defaults(obj, config_server_params); TEST(strcmp(obj->name(), server->name()) == 0, "Server names differ"); TEST(param->get_string("address") == server->address, "Server addresses differ"); TEST(param->get_string("protocol") == server->protocol(), "Server protocols differ"); TEST(param->get_string("authenticator") == server->get_authenticator(), "Server authenticators differ"); TEST(param->get_integer("port") == server->port, "Server ports differ"); TEST(Server::server_alloc(obj->name(), obj->m_parameters), "Failed to create server from loaded config"); duplicate_context_finish(&dcontext); config_context_free(obj); } } return true; } bool test_serialize() { char name[] = "serialized-server"; char config_name[] = "serialized-server.cnf"; char old_config_name[] = "serialized-server.cnf.old"; char* persist_dir = MXS_STRDUP_A("./"); set_config_persistdir(persist_dir); Server* server = Server::server_alloc(name, *params); TEST(server, "Server allocation failed"); /** Make sure the files don't exist */ unlink(config_name); unlink(old_config_name); /** Serialize server to disk */ TEST(server->serialize(), "Failed to synchronize original server"); /** Load it again */ TEST(test_load_config(config_name, server), "Failed to load the serialized server"); /** We should have two identical servers */ Server* created = Server::find_by_unique_name(name); rename(config_name, old_config_name); /** Serialize the loaded server to disk */ TEST(created->serialize(), "Failed to synchronize the copied server"); /** Check that they serialize to identical files */ char cmd[1024]; sprintf(cmd, "diff ./%s ./%s", config_name, old_config_name); TEST(system(cmd) == 0, "The files are not identical"); return true; } int main(int argc, char** argv) { /** * Prepare test environment by pre-loading modules. This prevents the server * allocation from failing if multiple modules from different directories are * loaded in one core function call. */ mxs_log_init(NULL, NULL, MXS_LOG_TARGET_STDOUT); set_libdir(MXS_STRDUP_A("../../modules/authenticator/NullAuthAllow/")); load_module("NullAuthAllow", MODULE_AUTHENTICATOR); set_libdir(MXS_STRDUP_A("../../modules/protocol/HTTPD/")); load_module("HTTPD", MODULE_PROTOCOL); params->set_from_list({ {"address", "127.0.0.1"}, {"port", "9876"}, {"protocol", "HTTPD"}, {"authenticator", "NullAuthAllow"} }, config_server_params); int result = 0; result += test1(); if (!test_serialize()) { result++; } mxs_log_finish(); exit(result); }