X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=tests%2Flibmemcached_world.h;h=5147e1a42a4e0c44acbfc53673b5bcfa8f083d90;hb=7e9077c0ead0394bcfa84a44ebbecf6af1c7bd44;hp=dfdddbefe00796336603fa2af813c8c9ef42eef8;hpb=12a07e58df95bb8dbe167e4157b29c910177ade8;p=awesomized%2Flibmemcached diff --git a/tests/libmemcached_world.h b/tests/libmemcached_world.h index dfdddbef..5147e1a4 100644 --- a/tests/libmemcached_world.h +++ b/tests/libmemcached_world.h @@ -1,214 +1,115 @@ -/* libMemcached Functions Test - * Copyright (C) 2006-2009 Brian Aker - * All rights reserved. +/* vim:expandtab:shiftwidth=2:tabstop=2:smarttab: + * + * Libmemcached Client and Server * - * Use and distribution licensed under the BSD license. See - * the COPYING file in the parent directory for full text. + * Copyright (C) 2012 Data Differential, http://datadifferential.com/ + * Copyright (C) 2006-2009 Brian Aker + * All rights reserved. * - * Description: This is the startup bits for any libmemcached test. + * 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. * */ -#pragma once - -#include - -/* The structure we use for the test system */ -struct libmemcached_test_container_st -{ - server_startup_st construct; - memcached_st *parent; - memcached_st *memc; - - libmemcached_test_container_st() : - parent(NULL), - memc(NULL) - { } -}; - -#ifdef __cplusplus -extern "C" { -#endif - -/* Prototypes for functions we will pass to test framework */ -libmemcached_test_container_st *world_create(test_return_t *error); -test_return_t world_test_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 *); -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 *); +#pragma once -/** - @note generic shutdown/startup for libmemcached tests. -*/ -test_return_t world_container_startup(libmemcached_test_container_st *container); -test_return_t world_container_shutdown(libmemcached_test_container_st *container); +#include "tests/libmemcached_test_container.h" -libmemcached_test_container_st *world_create(test_return_t *error) +static void *world_create(libtest::server_startup_st& servers, test_return_t& error) { - libmemcached_test_container_st *global_container= new libmemcached_test_container_st(); - if (not server_startup(&global_container->construct)) + if (libtest::has_memcached() == false) { - *error= TEST_FAILURE; + error= TEST_SKIPPED; return NULL; } - *error= TEST_SUCCESS; - - return global_container; -} - -test_return_t world_container_startup(libmemcached_test_container_st *container) -{ - char buffer[BUFSIZ]; - - test_compare_got(MEMCACHED_SUCCESS, - libmemcached_check_configuration(container->construct.server_list.c_str(), container->construct.server_list.size(), - buffer, sizeof(buffer)), - buffer); - - assert(not container->parent); - container->parent= memcached(container->construct.server_list.c_str(), container->construct.server_list.size()); - test_true(container->parent); - - return TEST_SUCCESS; -} - -test_return_t world_container_shutdown(libmemcached_test_container_st *container) -{ - memcached_free(container->parent); - container->parent= NULL; - - return TEST_SUCCESS; -} - -test_return_t world_test_startup(libmemcached_test_container_st *container) -{ - assert(container); - assert(not container->memc); - assert(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) -{ - assert(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) -{ - assert(container->memc); - for (uint32_t loop= 0; loop < memcached_server_list_count(container->memc->servers); loop++) + if (servers.sasl() and (LIBMEMCACHED_WITH_SASL_SUPPORT == 0 or MEMCACHED_SASL_BINARY == 0)) { - memcached_server_instance_st instance= - memcached_server_instance_by_position(container->memc, loop); - - test_compare(-1, instance->fd); - test_compare(0, instance->cursor_active); + error= TEST_SKIPPED; + return NULL; } - return TEST_SUCCESS; -} - - -test_return_t world_post_run(libmemcached_test_container_st *container) -{ - test_true(container->memc); - - return TEST_SUCCESS; -} - -test_return_t world_on_error(test_return_t test_state, libmemcached_test_container_st *container) -{ - (void)test_state; - assert(container->memc); - memcached_free(container->memc); - container->memc= NULL; - - return TEST_SUCCESS; -} - -test_return_t world_destroy(libmemcached_test_container_st *container) -{ - server_startup_st *construct= &container->construct; - - server_shutdown(construct); - -#ifdef LIBMEMCACHED_WITH_SASL_SUPPORT - sasl_done(); -#endif - - 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) + // Assume we are running under valgrind, and bail + if (servers.sasl() and getenv("TESTS_ENVIRONMENT")) { - assert(container); - assert(container->memc); - return func(container->memc); - } - else - { - return TEST_SUCCESS; + error= TEST_SKIPPED; + return NULL; } -} -static test_return_t _pre_runner_default(libmemcached_test_callback_fn func, libmemcached_test_container_st *container) -{ - if (func) - { - return func(container->parent); - } - else + for (uint32_t x= 0; x < servers.servers_to_run(); x++) { - return TEST_SUCCESS; + in_port_t port= libtest::get_free_port(); + + if (servers.sasl()) + { + if (server_startup(servers, "memcached-sasl", port, 0, NULL) == false) + { + error= TEST_SKIPPED; +#if 0 + fatal_message("Could not start memcached-sasl"); +#endif + return NULL; + } + } + else + { + if (server_startup(servers, "memcached", port, 0, NULL) == false) + { + error= TEST_SKIPPED; +#if 0 + fatal_message("Could not start memcached"); +#endif + return NULL; + } + } } + + libmemcached_test_container_st *global_container= new libmemcached_test_container_st(servers); + + return global_container; } -static test_return_t _post_runner_default(libmemcached_test_callback_fn func, libmemcached_test_container_st *container) +static bool world_destroy(void *object) { - if (func) + 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) { - return func(container->parent); + sasl_done(); } - else - { - return TEST_SUCCESS; - } -} - -#ifdef __cplusplus -} #endif -#ifdef __cplusplus - -static Runner defualt_libmemcached_runner= { - reinterpret_cast(_pre_runner_default), - reinterpret_cast(_runner_default), - reinterpret_cast(_post_runner_default) -}; + delete container; -#else + return TEST_SUCCESS; +} -static Runner defualt_libmemcached_runner= { - (test_callback_runner_fn)_pre_runner_default, - (test_callback_runner_fn)_runner_default, - (test_callback_runner_fn)_post_runner_default -}; +typedef test_return_t (*libmemcached_test_callback_fn)(memcached_st *); -#endif +#include "tests/runner.h"