X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=tests%2Fplus.cpp;h=4a3789b93a741c427b4b541f79c1f1314b3fb197;hb=259796df2149b11286d58158255f868cadb470bb;hp=10b2440a7c2f2ea02c5d7b86271500ff8e81cbe5;hpb=51aa1233e4981967f06dd3432cd3a6ed83a35607;p=awesomized%2Flibmemcached diff --git a/tests/plus.cpp b/tests/plus.cpp index 10b2440a..4a3789b9 100644 --- a/tests/plus.cpp +++ b/tests/plus.cpp @@ -1,8 +1,9 @@ /* C++ interface test */ +#include "libmemcached/memcached.hh" + #include -#include #include #include #include @@ -15,10 +16,18 @@ #include "test.h" -uint8_t basic_test(memcached_st *memc) +extern "C" { + test_return basic_test(memcached_st *memc); + uint8_t increment_test(memcached_st *memc); + test_return basic_master_key_test(memcached_st *memc); + void *world_create(void); + void world_destroy(void *p); +} + +test_return basic_test(memcached_st *memc) { - Memcached foo; - char *value_set= "This is some data"; + Memcached foo(memc); + const char *value_set= "This is some data"; char *value; size_t value_length; @@ -27,15 +36,49 @@ uint8_t basic_test(memcached_st *memc) assert((memcmp(value, value_set, value_length) == 0)); + return TEST_SUCCESS; +} + +uint8_t increment_test(memcached_st *memc) +{ + Memcached mcach(memc); + memcached_return rc; + const char *key= "inctest"; + const char *inc_value= "1"; + char *ret_value; + uint64_t int_inc_value; + uint64_t int_ret_value; + size_t value_length; + + mcach.set(key, inc_value, strlen(inc_value)); + ret_value= mcach.get(key, &value_length); + printf("\nretvalue %s\n",ret_value); + int_inc_value= atoi(inc_value); + int_ret_value= atoi(ret_value); + assert(int_ret_value == int_inc_value); + + rc= mcach.increment(key, 1, &int_ret_value); + assert(rc == MEMCACHED_SUCCESS); + assert(int_ret_value == 2); + + rc= mcach.increment(key, 1, &int_ret_value); + assert(rc == MEMCACHED_SUCCESS); + assert(int_ret_value == 3); + + rc= mcach.increment(key, 5, &int_ret_value); + assert(rc == MEMCACHED_SUCCESS); + assert(int_ret_value == 8); + return 0; } -uint8_t basic_master_key_test(memcached_st *memc) + +test_return 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"; + Memcached foo(memc); + const char *value_set= "Data for server A"; + const char *master_key_a= "server-a"; + const char *master_key_b= "server-b"; + const char *key= "xyz"; char *value; size_t value_length; @@ -47,7 +90,7 @@ uint8_t basic_master_key_test(memcached_st *memc) value= foo.get_by_key(master_key_b, key, &value_length); assert((memcmp(value, value_set, value_length) == 0)); - return 0; + return TEST_SUCCESS; } @@ -64,10 +107,8 @@ collection_st collection[] ={ #define SERVERS_TO_CREATE 1 -void *world_create(void) +extern "C" void *world_create(void) { - unsigned int x; - memcached_server_st *servers; server_startup_st *construct; construct= (server_startup_st *)malloc(sizeof(server_startup_st)); @@ -81,8 +122,9 @@ void *world_create(void) void world_destroy(void *p) { - server_startup_st *construct= (server_startup_st *)p; - memcached_server_st *servers= (memcached_server_st *)construct->servers; + server_startup_st *construct= static_cast(p); + memcached_server_st *servers= + static_cast(construct->servers); memcached_server_list_free(servers); server_shutdown(construct);