1 /* libMemcached Functions Test
2 * Copyright (C) 2006-2009 Brian Aker
5 * Use and distribution licensed under the BSD license. See
6 * the COPYING file in the parent directory for full text.
8 * Description: This is the startup bits for any libmemcached test.
16 /* The structure we use for the test system */
17 struct libmemcached_test_container_st
19 server_startup_st
& construct
;
23 libmemcached_test_container_st(server_startup_st
&construct_arg
) :
24 construct(construct_arg
),
30 #define SERVERS_TO_CREATE 5
32 static void *world_create(server_startup_st
& servers
, test_return_t
& error
)
34 if (LIBMEMCACHED_WITH_SASL_SUPPORT
== 0)
40 // Assume we are running under valgrind, and bail
41 if (servers
.sasl() and getenv("TESTS_ENVIRONMENT"))
49 for (uint32_t x
= 0; x
< SERVERS_TO_CREATE
; x
++)
53 char variable_buffer
[1024];
54 snprintf(variable_buffer
, sizeof(variable_buffer
), "LIBMEMCACHED_PORT_%u", x
);
57 if ((var
= getenv(variable_buffer
)))
59 port
= in_port_t(atoi(var
));
63 port
= in_port_t(TEST_PORT_BASE
+x
);
67 const char *argv
[1]= { "memcached" };
70 if (not server_startup(servers
, "memcached-sasl", port
, 1, argv
))
78 if (not server_startup(servers
, "memcached", port
, 1, argv
))
90 const char *argv
[1]= { "memcached" };
91 if (not servers
.start_socket_server("memcached-sasl", max_port
+1, 1, argv
))
99 const char *argv
[1]= { "memcached" };
100 if (not servers
.start_socket_server("memcached", max_port
+1, 1, argv
))
109 libmemcached_test_container_st
*global_container
= new libmemcached_test_container_st(servers
);
110 if (global_container
== NULL
)
112 error
= TEST_MEMORY_ALLOCATION_FAILURE
;
118 return global_container
;
121 static test_return_t
world_container_startup(libmemcached_test_container_st
*container
)
125 test_compare_got(MEMCACHED_SUCCESS
,
126 libmemcached_check_configuration(container
->construct
.option_string().c_str(), container
->construct
.option_string().size(),
127 buffer
, sizeof(buffer
)),
128 container
->construct
.option_string().c_str());
130 test_true(not container
->parent
);
131 container
->parent
= memcached(container
->construct
.option_string().c_str(), container
->construct
.option_string().size());
132 test_true(container
->parent
);
134 if (container
->construct
.sasl())
136 if (memcached_failed(memcached_behavior_set(container
->parent
, MEMCACHED_BEHAVIOR_BINARY_PROTOCOL
, 1)))
138 memcached_free(container
->parent
);
142 if (memcached_failed(memcached_set_sasl_auth_data(container
->parent
, container
->construct
.username().c_str(), container
->construct
.password().c_str())))
144 memcached_free(container
->parent
);
149 for (uint32_t host
= 0; host
< memcached_server_count(container
->parent
); ++host
)
151 memcached_server_instance_st instance
=
152 memcached_server_instance_by_position(container
->parent
, host
);
154 if (instance
->type
== MEMCACHED_CONNECTION_TCP
)
156 test_true_got(memcached_server_port(instance
) >= TEST_PORT_BASE
, memcached_server_port(instance
));
163 static test_return_t
world_container_shutdown(libmemcached_test_container_st
*container
)
165 memcached_free(container
->parent
);
166 container
->parent
= NULL
;
171 static test_return_t
world_test_startup(libmemcached_test_container_st
*container
)
173 test_true(container
);
174 test_true(not container
->memc
);
175 test_true(container
->parent
);
176 container
->memc
= memcached_clone(NULL
, container
->parent
);
177 test_true(container
->memc
);
182 test_return_t
world_flush(libmemcached_test_container_st
*container
);
183 test_return_t
world_flush(libmemcached_test_container_st
*container
)
185 test_true(container
->memc
);
186 memcached_flush(container
->memc
, 0);
187 memcached_quit(container
->memc
);
192 static test_return_t
world_pre_run(libmemcached_test_container_st
*container
)
194 test_true(container
->memc
);
195 for (uint32_t loop
= 0; loop
< memcached_server_list_count(container
->memc
->servers
); loop
++)
197 memcached_server_instance_st instance
=
198 memcached_server_instance_by_position(container
->memc
, loop
);
200 test_compare(-1, instance
->fd
);
201 test_compare(0U, instance
->cursor_active
);
208 static test_return_t
world_post_run(libmemcached_test_container_st
*container
)
210 test_true(container
->memc
);
215 static test_return_t
world_on_error(test_return_t test_state
, libmemcached_test_container_st
*container
)
218 test_true(container
->memc
);
219 memcached_free(container
->memc
);
220 container
->memc
= NULL
;
225 static bool world_destroy(void *object
)
227 libmemcached_test_container_st
*container
= (libmemcached_test_container_st
*)object
;
228 #if defined(LIBMEMCACHED_WITH_SASL_SUPPORT) && LIBMEMCACHED_WITH_SASL_SUPPORT
229 if (LIBMEMCACHED_WITH_SASL_SUPPORT
)
240 typedef test_return_t (*libmemcached_test_callback_fn
)(memcached_st
*);
242 static test_return_t
_runner_default(libmemcached_test_callback_fn func
, libmemcached_test_container_st
*container
)
246 test_true(container
);
247 test_true(container
->memc
);
248 return func(container
->memc
);
254 static test_return_t
_pre_runner_default(libmemcached_test_callback_fn func
, libmemcached_test_container_st
*container
)
258 return func(container
->parent
);
264 static test_return_t
_post_runner_default(libmemcached_test_callback_fn func
, libmemcached_test_container_st
*container
)
268 return func(container
->parent
);
274 class LibmemcachedRunner
: public Runner
{
276 test_return_t
run(test_callback_fn
* func
, void *object
)
278 return _runner_default(libmemcached_test_callback_fn(func
), (libmemcached_test_container_st
*)object
);
281 test_return_t
pre(test_callback_fn
* func
, void *object
)
283 return _pre_runner_default(libmemcached_test_callback_fn(func
), (libmemcached_test_container_st
*)object
);
286 test_return_t
post(test_callback_fn
* func
, void *object
)
288 return _post_runner_default(libmemcached_test_callback_fn(func
), (libmemcached_test_container_st
*)object
);
292 static LibmemcachedRunner defualt_libmemcached_runner
;