X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=tests%2Flibmemcached_world.h;h=cedb8c2fa6e6b8da44428b12a6ae029ea1d4d881;hb=64e9fa38f42f0d30463da5ddc3a573619941d93a;hp=c26323119b35696044d2e13f94ffc0d0dc23a521;hpb=a246ac50a88e4af750fd2dd209eff94dcadf72d2;p=m6w6%2Flibmemcached diff --git a/tests/libmemcached_world.h b/tests/libmemcached_world.h index c2632311..cedb8c2f 100644 --- a/tests/libmemcached_world.h +++ b/tests/libmemcached_world.h @@ -1,141 +1,274 @@ -/* libMemcached Functions Test - * Copyright (C) 2006-2009 Brian Aker - * All rights reserved. - * - * Use and distribution licensed under the BSD license. See - * the COPYING file in the parent directory for full text. +/* vim:expandtab:shiftwidth=2:tabstop=2:smarttab: * - * Description: This is the startup bits for any libmemcached test. + * Libmemcached Client and Server + * + * Copyright (C) 2012 Data Differential, http://datadifferential.com/ + * Copyright (C) 2006-2009 Brian Aker + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are + * met: + * + * * Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * + * * Redistributions in binary form must reproduce the above + * copyright notice, this list of conditions and the following disclaimer + * in the documentation and/or other materials provided with the + * distribution. + * + * * The names of its contributors may not be used to endorse or + * promote products derived from this software without specific prior + * written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS + * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT + * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR + * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT + * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, + * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT + * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * */ -#ifdef __cplusplus -extern "C" { -#endif + +#pragma once + +#include /* The structure we use for the test system */ -typedef struct +struct libmemcached_test_container_st { - server_startup_st construct; + libtest::server_startup_st& construct; + memcached_st *parent; memcached_st *memc; -} libmemcached_test_container_st; -/* Prototypes for functions we will pass to test framework */ -libmemcached_test_container_st *world_create(void); -test_return_t world_collection_startup(libmemcached_test_container_st *); -test_return_t world_flush(libmemcached_test_container_st *container); -test_return_t world_pre_run(libmemcached_test_container_st *); + libmemcached_test_container_st(libtest::server_startup_st &construct_arg) : + construct(construct_arg), + parent(NULL), + memc(NULL) + { } +}; -test_return_t world_post_run(libmemcached_test_container_st *); -test_return_t world_on_error(test_return_t, libmemcached_test_container_st *); -test_return_t world_destroy(libmemcached_test_container_st *); +static void *world_create(libtest::server_startup_st& servers, test_return_t& error) +{ + if (HAVE_MEMCACHED_BINARY == 0) + { + error= TEST_SKIPPED; + return NULL; + } -static libmemcached_test_container_st global_container; + if (servers.sasl() and (LIBMEMCACHED_WITH_SASL_SUPPORT == 0 or MEMCACHED_SASL_BINARY == 0)) + { + error= TEST_SKIPPED; + return NULL; + } -libmemcached_test_container_st *world_create(void) -{ - memset(&global_container, 0, sizeof(global_container)); - global_container.construct.count= SERVERS_TO_CREATE; - global_container.construct.udp= 0; - server_startup(&global_container.construct); + // Assume we are running under valgrind, and bail + if (servers.sasl() and getenv("TESTS_ENVIRONMENT")) + { + error= TEST_SKIPPED; + return NULL; + } - assert(global_container.construct.servers); + for (uint32_t x= 0; x < servers.count(); x++) + { + in_port_t port= libtest::get_free_port(); + + const char *argv[1]= { "memcached" }; + if (servers.sasl()) + { + if (server_startup(servers, "memcached-sasl", port, 1, argv) == false) + { + fatal_message("Could not start memcached-sasl"); + } + } + else + { + if (server_startup(servers, "memcached", port, 1, argv) == false) + { + fatal_message("Could not start memcached"); + } + } + } - return &global_container; + libmemcached_test_container_st *global_container= new libmemcached_test_container_st(servers); + + return global_container; } +static test_return_t world_container_startup(libmemcached_test_container_st *container) +{ + char buffer[BUFSIZ]; + + test_compare_got(MEMCACHED_SUCCESS, + libmemcached_check_configuration(container->construct.option_string().c_str(), container->construct.option_string().size(), + buffer, sizeof(buffer)), + container->construct.option_string().c_str()); + + test_null(container->parent); + container->parent= memcached(container->construct.option_string().c_str(), container->construct.option_string().size()); + test_true(container->parent); + test_compare(MEMCACHED_SUCCESS, memcached_version(container->parent)); -test_return_t world_collection_startup(libmemcached_test_container_st *container) + if (container->construct.sasl()) + { + if (memcached_failed(memcached_behavior_set(container->parent, MEMCACHED_BEHAVIOR_BINARY_PROTOCOL, 1))) + { + memcached_free(container->parent); + return TEST_FAILURE; + } + + if (memcached_failed(memcached_set_sasl_auth_data(container->parent, container->construct.username().c_str(), container->construct.password().c_str()))) + { + memcached_free(container->parent); + return TEST_FAILURE; + } + } + + return TEST_SUCCESS; +} + +static test_return_t world_container_shutdown(libmemcached_test_container_st *container) { - memcached_return_t rc; - container->memc= memcached_create(NULL); - test_truth((container->memc != NULL)); + memcached_free(container->parent); + container->parent= NULL; - rc= memcached_server_push(container->memc, container->construct.servers); - test_truth(rc == MEMCACHED_SUCCESS); + return TEST_SUCCESS; +} + +static test_return_t world_test_startup(libmemcached_test_container_st *container) +{ + test_true(container); + test_null(container->memc); + test_true(container->parent); + container->memc= memcached_clone(NULL, container->parent); + test_true(container->memc); return TEST_SUCCESS; } +test_return_t world_flush(libmemcached_test_container_st *container); test_return_t world_flush(libmemcached_test_container_st *container) { + test_true(container->memc); memcached_flush(container->memc, 0); memcached_quit(container->memc); return TEST_SUCCESS; } -test_return_t world_pre_run(libmemcached_test_container_st *container) +static test_return_t world_pre_run(libmemcached_test_container_st *container) { - uint32_t loop; - - for (loop= 0; loop < memcached_server_list_count(container->construct.servers); loop++) + test_true(container->memc); + for (uint32_t loop= 0; loop < memcached_server_list_count(container->memc->servers); loop++) { - test_truth(container->memc->hosts[loop].fd == -1); - test_truth(container->memc->hosts[loop].cursor_active == 0); + memcached_server_instance_st instance= memcached_server_instance_by_position(container->memc, loop); + + test_compare(-1, instance->fd); + test_compare(0U, instance->cursor_active); } return TEST_SUCCESS; } -test_return_t world_post_run(libmemcached_test_container_st *container) +static test_return_t world_post_run(libmemcached_test_container_st *container) { - assert(container->memc); + test_true(container->memc); return TEST_SUCCESS; } -test_return_t world_on_error(test_return_t test_state, libmemcached_test_container_st *container) +static test_return_t world_on_error(test_return_t , libmemcached_test_container_st *container) { - (void)test_state; + test_true(container->memc); memcached_free(container->memc); - + container->memc= NULL; + return TEST_SUCCESS; } -test_return_t world_destroy(libmemcached_test_container_st *container) +static bool world_destroy(void *object) { - server_startup_st *construct= &container->construct; - memcached_server_st *servers= container->construct.servers; - memcached_server_list_free(servers); + libmemcached_test_container_st *container= (libmemcached_test_container_st *)object; +#if defined(LIBMEMCACHED_WITH_SASL_SUPPORT) && LIBMEMCACHED_WITH_SASL_SUPPORT + if (LIBMEMCACHED_WITH_SASL_SUPPORT) + { + sasl_done(); + } +#endif - server_shutdown(construct); + delete container; return TEST_SUCCESS; } typedef test_return_t (*libmemcached_test_callback_fn)(memcached_st *); + static test_return_t _runner_default(libmemcached_test_callback_fn func, libmemcached_test_container_st *container) { if (func) { - return func(container->memc); + test_true(container); + test_true(container->memc); + test_return_t ret; + try { + ret= func(container->memc); + } + catch (std::exception& e) + { + libtest::Error << e.what(); + return TEST_FAILURE; + } + + return ret; } - else + + return TEST_SUCCESS; +} + +static test_return_t _pre_runner_default(libmemcached_test_callback_fn func, libmemcached_test_container_st *container) +{ + if (func) { - return TEST_SUCCESS; + return func(container->parent); } -} -#ifdef __cplusplus + return TEST_SUCCESS; } -#endif -#ifdef __cplusplus +static test_return_t _post_runner_default(libmemcached_test_callback_fn func, libmemcached_test_container_st *container) +{ + if (func) + { + return func(container->parent); + } -static world_runner_st defualt_libmemcached_runner= { - reinterpret_cast(_runner_default), - reinterpret_cast(_runner_default), - reinterpret_cast(_runner_default) -}; + return TEST_SUCCESS; +} -#else +class LibmemcachedRunner : public libtest::Runner { +public: + test_return_t run(test_callback_fn* func, void *object) + { + return _runner_default(libmemcached_test_callback_fn(func), (libmemcached_test_container_st*)object); + } + + test_return_t pre(test_callback_fn* func, void *object) + { + return _pre_runner_default(libmemcached_test_callback_fn(func), (libmemcached_test_container_st*)object); + } -static world_runner_st defualt_libmemcached_runner= { - (test_callback_runner_fn)_runner_default, - (test_callback_runner_fn)_runner_default, - (test_callback_runner_fn)_runner_default + test_return_t post(test_callback_fn* func, void *object) + { + return _post_runner_default(libmemcached_test_callback_fn(func), (libmemcached_test_container_st*)object); + } }; -#endif +static LibmemcachedRunner defualt_libmemcached_runner;