X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=tests%2Fplus.cpp;h=10b2440a7c2f2ea02c5d7b86271500ff8e81cbe5;hb=83d63a1f916b073f8cf44cf91b6c0b3d118dabe5;hp=37b6260e7fe78460f8067f49db334b6033bd81a0;hpb=9cfc3faa3f8471083350cecce7e49114ce827c89;p=m6w6%2Flibmemcached diff --git a/tests/plus.cpp b/tests/plus.cpp index 37b6260e..10b2440a 100644 --- a/tests/plus.cpp +++ b/tests/plus.cpp @@ -2,7 +2,6 @@ C++ interface test */ #include -#include #include #include #include @@ -12,6 +11,7 @@ #include #include #include +#include "server.h" #include "test.h" @@ -29,9 +29,31 @@ uint8_t basic_test(memcached_st *memc) return 0; } +uint8_t basic_master_key_test(memcached_st *memc) +{ + Memcached foo; + char *value_set= "Data for server A"; + char *master_key_a= "server-a"; + char *master_key_b= "server-b"; + char *key= "xyz"; + char *value; + size_t value_length; + + foo.set_by_key(master_key_a, key, value_set, strlen(value_set)); + value= foo.get_by_key(master_key_a, key, &value_length); + + assert((memcmp(value, value_set, value_length) == 0)); + + value= foo.get_by_key(master_key_b, key, &value_length); + assert((memcmp(value, value_set, value_length) == 0)); + + return 0; +} + test_st tests[] ={ {"basic", 0, basic_test }, + {"basic_master_key", 0, basic_master_key_test }, {0, 0, 0} }; @@ -40,7 +62,36 @@ collection_st collection[] ={ {0, 0, 0, 0} }; -collection_st *gets_collections(void) +#define SERVERS_TO_CREATE 1 + +void *world_create(void) +{ + unsigned int x; + memcached_server_st *servers; + server_startup_st *construct; + + construct= (server_startup_st *)malloc(sizeof(server_startup_st)); + memset(construct, 0, sizeof(server_startup_st)); + + construct->count= SERVERS_TO_CREATE; + server_startup(construct); + + return construct; +} + +void world_destroy(void *p) +{ + server_startup_st *construct= (server_startup_st *)p; + memcached_server_st *servers= (memcached_server_st *)construct->servers; + memcached_server_list_free(servers); + + server_shutdown(construct); + free(construct); +} + +void get_world(world_st *world) { - return collection; + world->collections= collection; + world->create= world_create; + world->destroy= world_destroy; }