X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=tests%2Flibmemcached_world.h;h=4793569c1e14b56165ad110b7e44df961a322f30;hb=9cde1fdc1bbd49775c75a83e44c942354129f1d5;hp=a88b24cd1ece92ec92b9c6ba8a5273d24dcbc126;hpb=287c4d7cd3873c6ae9f7908bd4f34d6fbc9efcd4;p=awesomized%2Flibmemcached diff --git a/tests/libmemcached_world.h b/tests/libmemcached_world.h index a88b24cd..4793569c 100644 --- a/tests/libmemcached_world.h +++ b/tests/libmemcached_world.h @@ -17,12 +17,13 @@ extern "C" { typedef struct { 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(test_return_t *error); -test_return_t world_collection_startup(libmemcached_test_container_st *); +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 *); @@ -32,6 +33,12 @@ test_return_t world_destroy(libmemcached_test_container_st *); static libmemcached_test_container_st global_container; +/** + @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); + libmemcached_test_container_st *world_create(test_return_t *error) { memset(&global_container, 0, sizeof(global_container)); @@ -51,15 +58,30 @@ libmemcached_test_container_st *world_create(test_return_t *error) return &global_container; } - -test_return_t world_collection_startup(libmemcached_test_container_st *container) +test_return_t world_container_startup(libmemcached_test_container_st *container) { memcached_return_t rc; - container->memc= memcached_create(NULL); - test_truth((container->memc != NULL)); + container->parent= memcached_create(NULL); + test_true((container->parent != NULL)); + + rc= memcached_server_push(container->parent, container->construct.servers); + test_true(rc == MEMCACHED_SUCCESS); + + return TEST_SUCCESS; +} - rc= memcached_server_push(container->memc, container->construct.servers); - test_truth(rc == MEMCACHED_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) +{ + container->memc= memcached_clone(NULL, container->parent); + test_true((container->memc != NULL)); return TEST_SUCCESS; } @@ -74,12 +96,13 @@ test_return_t world_flush(libmemcached_test_container_st *container) 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++) + 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_true(instance->fd == -1); + test_true(instance->cursor_active == 0); } return TEST_SUCCESS; @@ -88,7 +111,7 @@ test_return_t world_pre_run(libmemcached_test_container_st *container) test_return_t world_post_run(libmemcached_test_container_st *container) { - assert(container->memc); + test_true(container->memc); return TEST_SUCCESS; } @@ -97,6 +120,7 @@ test_return_t world_on_error(test_return_t test_state, libmemcached_test_contain { (void)test_state; memcached_free(container->memc); + container->memc= NULL; return TEST_SUCCESS; } @@ -109,6 +133,10 @@ test_return_t world_destroy(libmemcached_test_container_st *container) server_shutdown(construct); +#ifdef LIBMEMCACHED_WITH_SASL_SUPPORT + sasl_done(); +#endif + return TEST_SUCCESS; } @@ -125,6 +153,30 @@ static test_return_t _runner_default(libmemcached_test_callback_fn func, libmemc } } +static test_return_t _pre_runner_default(libmemcached_test_callback_fn func, libmemcached_test_container_st *container) +{ + if (func) + { + return func(container->parent); + } + else + { + return TEST_SUCCESS; + } +} + +static test_return_t _post_runner_default(libmemcached_test_callback_fn func, libmemcached_test_container_st *container) +{ + if (func) + { + return func(container->parent); + } + else + { + return TEST_SUCCESS; + } +} + #ifdef __cplusplus } #endif @@ -132,17 +184,17 @@ static test_return_t _runner_default(libmemcached_test_callback_fn func, libmemc #ifdef __cplusplus static world_runner_st defualt_libmemcached_runner= { + reinterpret_cast(_pre_runner_default), reinterpret_cast(_runner_default), - reinterpret_cast(_runner_default), - reinterpret_cast(_runner_default) + reinterpret_cast(_post_runner_default) }; #else static world_runner_st defualt_libmemcached_runner= { + (test_callback_runner_fn)_pre_runner_default, (test_callback_runner_fn)_runner_default, - (test_callback_runner_fn)_runner_default, - (test_callback_runner_fn)_runner_default + (test_callback_runner_fn)_post_runner_default }; #endif