Update testing to allow for distributed testing.
[awesomized/libmemcached] / tests / libmemcached-1.0 / setup_and_teardowns.cc
1 /* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
2 *
3 * Libmemcached Client and Server
4 *
5 * Copyright (C) 2012 Data Differential, http://datadifferential.com/
6 * All rights reserved.
7 *
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions are
10 * met:
11 *
12 * * Redistributions of source code must retain the above copyright
13 * notice, this list of conditions and the following disclaimer.
14 *
15 * * Redistributions in binary form must reproduce the above
16 * copyright notice, this list of conditions and the following disclaimer
17 * in the documentation and/or other materials provided with the
18 * distribution.
19 *
20 * * The names of its contributors may not be used to endorse or
21 * promote products derived from this software without specific prior
22 * written permission.
23 *
24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
25 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
26 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
27 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
28 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
29 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
30 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
31 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
32 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
33 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
34 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
35 *
36 */
37
38 #include <config.h>
39 #include <libtest/test.hpp>
40
41 #include <libmemcached/util.h>
42
43 #include "tests/libmemcached-1.0/setup_and_teardowns.h"
44
45 #include <sys/stat.h>
46
47 /**
48 @note This should be testing to see if the server really supports the binary protocol.
49 */
50 test_return_t pre_binary(memcached_st *memc)
51 {
52 test_skip(true, libmemcached_util_version_check(memc, 1, 4, 4));
53 test_skip(MEMCACHED_SUCCESS, memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_BINARY_PROTOCOL, true));
54
55 return TEST_SUCCESS;
56 }
57
58 test_return_t pre_unix_socket(memcached_st *memc)
59 {
60 struct stat buf;
61
62 memcached_servers_reset(memc);
63 const char *socket_file= libtest::default_socket();
64 test_skip(true, bool(socket_file));
65
66 test_skip(0, stat(socket_file, &buf));
67
68 test_compare(MEMCACHED_SUCCESS,
69 memcached_server_add_unix_socket_with_weight(memc, socket_file, 0));
70
71 return TEST_SUCCESS;
72 }
73
74 test_return_t pre_nodelay(memcached_st *memc)
75 {
76 memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_NO_BLOCK, 0);
77 memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_TCP_NODELAY, 0);
78
79 return TEST_SUCCESS;
80 }
81
82 test_return_t pre_settimer(memcached_st *memc)
83 {
84 memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_SND_TIMEOUT, 1000);
85 memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_RCV_TIMEOUT, 1000);
86
87 return TEST_SUCCESS;
88 }
89
90 test_return_t pre_murmur(memcached_st *memc)
91 {
92 test_skip(MEMCACHED_SUCCESS, memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_HASH, (uint64_t)MEMCACHED_HASH_MURMUR));
93 return TEST_SUCCESS;
94 }
95
96 test_return_t pre_jenkins(memcached_st *memc)
97 {
98 memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_HASH, (uint64_t)MEMCACHED_HASH_JENKINS);
99
100 return TEST_SKIPPED;
101 }
102
103
104 test_return_t pre_md5(memcached_st *memc)
105 {
106 memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_HASH, (uint64_t)MEMCACHED_HASH_MD5);
107
108 return TEST_SUCCESS;
109 }
110
111 test_return_t pre_crc(memcached_st *memc)
112 {
113 memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_HASH, (uint64_t)MEMCACHED_HASH_CRC);
114
115 return TEST_SUCCESS;
116 }
117
118 test_return_t pre_hsieh(memcached_st *memc)
119 {
120 test_skip(MEMCACHED_SUCCESS, memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_HASH, (uint64_t)MEMCACHED_HASH_HSIEH));
121 return TEST_SUCCESS;
122 }
123
124 test_return_t pre_hash_fnv1_64(memcached_st *memc)
125 {
126 test_skip(MEMCACHED_SUCCESS, memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_HASH, (uint64_t)MEMCACHED_HASH_MURMUR));
127
128 return TEST_SUCCESS;
129 }
130
131 test_return_t pre_hash_fnv1a_64(memcached_st *memc)
132 {
133 test_skip(MEMCACHED_SUCCESS, memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_HASH, (uint64_t)MEMCACHED_HASH_FNV1A_64));
134
135 return TEST_SUCCESS;
136 }
137
138 test_return_t pre_hash_fnv1_32(memcached_st *memc)
139 {
140 memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_HASH, (uint64_t)MEMCACHED_HASH_FNV1_32);
141
142 return TEST_SUCCESS;
143 }
144
145 test_return_t pre_hash_fnv1a_32(memcached_st *memc)
146 {
147 memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_HASH, (uint64_t)MEMCACHED_HASH_FNV1A_32);
148
149 return TEST_SUCCESS;
150 }
151
152 test_return_t pre_behavior_ketama(memcached_st *memc)
153 {
154 memcached_return_t rc= memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_KETAMA, 1);
155 test_compare(MEMCACHED_SUCCESS, rc);
156
157 uint64_t value= memcached_behavior_get(memc, MEMCACHED_BEHAVIOR_KETAMA);
158 test_compare(value, uint64_t(1));
159
160 return TEST_SUCCESS;
161 }
162
163 test_return_t pre_behavior_ketama_weighted(memcached_st *memc)
164 {
165 memcached_return_t rc= memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_KETAMA_WEIGHTED, 1);
166 test_compare(MEMCACHED_SUCCESS, rc);
167
168 uint64_t value= memcached_behavior_get(memc, MEMCACHED_BEHAVIOR_KETAMA_WEIGHTED);
169 test_compare(value, uint64_t(1));
170
171 test_compare(MEMCACHED_SUCCESS,
172 memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_KETAMA_HASH, MEMCACHED_HASH_MD5));
173
174 value= memcached_behavior_get(memc, MEMCACHED_BEHAVIOR_KETAMA_HASH);
175 test_compare(MEMCACHED_HASH_MD5, memcached_hash_t(value));
176
177 return TEST_SUCCESS;
178 }
179
180 test_return_t pre_replication(memcached_st *memc)
181 {
182 test_skip(TEST_SUCCESS, pre_binary(memc));
183
184 /*
185 * Make sure that we store the item on all servers
186 * (master + replicas == number of servers)
187 */
188 test_compare(MEMCACHED_SUCCESS, memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_NUMBER_OF_REPLICAS, memcached_server_count(memc) - 1));
189 test_compare(memcached_behavior_get(memc, MEMCACHED_BEHAVIOR_NUMBER_OF_REPLICAS), uint64_t(memcached_server_count(memc) - 1));
190
191 return TEST_SUCCESS;
192 }
193
194
195 test_return_t pre_replication_noblock(memcached_st *memc)
196 {
197 test_skip(TEST_SUCCESS, pre_replication(memc));
198
199 return pre_nonblock(memc);
200 }
201
202 test_return_t pre_nonblock(memcached_st *memc)
203 {
204 memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_NO_BLOCK, 0);
205
206 return TEST_SUCCESS;
207 }
208
209 test_return_t pre_cork(memcached_st *memc)
210 {
211 #ifdef __APPLE__
212 return TEST_SKIPPED;
213 #endif
214 bool set= true;
215 if (memcached_success(memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_CORK, set)))
216 return TEST_SUCCESS;
217
218 return TEST_SKIPPED;
219 }
220
221 test_return_t pre_cork_and_nonblock(memcached_st *memc)
222 {
223 #ifdef __APPLE__
224 return TEST_SKIPPED;
225 #endif
226 test_return_t test_rc;
227 if ((test_rc= pre_cork(memc)) != TEST_SUCCESS)
228 return test_rc;
229
230 return pre_nonblock(memc);
231 }
232
233 test_return_t pre_nonblock_binary(memcached_st *memc)
234 {
235 memcached_st *memc_clone= memcached_clone(NULL, memc);
236 test_true(memc_clone);
237
238 // The memcached_version needs to be done on a clone, because the server
239 // will not toggle protocol on an connection.
240 memcached_version(memc_clone);
241
242 memcached_return_t rc= MEMCACHED_FAILURE;
243 if (libmemcached_util_version_check(memc_clone, 1, 4, 4))
244 {
245 memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_NO_BLOCK, 0);
246 test_compare(MEMCACHED_SUCCESS,
247 memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_BINARY_PROTOCOL, 1));
248 test_compare(uint64_t(1), memcached_behavior_get(memc, MEMCACHED_BEHAVIOR_BINARY_PROTOCOL));
249 }
250 else
251 {
252 memcached_free(memc_clone);
253 return TEST_SKIPPED;
254 }
255
256 memcached_free(memc_clone);
257
258 return rc == MEMCACHED_SUCCESS ? TEST_SUCCESS : TEST_SKIPPED;
259 }