Update to add ENV variable LIBMEMCACHED
[m6w6/libmemcached] / tests / parser.cc
1 /* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
2 *
3 * Libmemcached library
4 *
5 * Copyright (C) 2012 Data Differential, http://datadifferential.com/
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions are
9 * met:
10 *
11 * * Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 *
14 * * Redistributions in binary form must reproduce the above
15 * copyright notice, this list of conditions and the following disclaimer
16 * in the documentation and/or other materials provided with the
17 * distribution.
18 *
19 * * The names of its contributors may not be used to endorse or
20 * promote products derived from this software without specific prior
21 * written permission.
22 *
23 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
24 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
25 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
26 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
27 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
28 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
29 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
30 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
31 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
32 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
33 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34 *
35 */
36
37 #include <config.h>
38
39 /*
40 C++ interface test
41 */
42 #include <libmemcached-1.0/memcached.hpp>
43 #include <libtest/test.hpp>
44
45 using namespace libtest;
46
47 static test_return_t memcached_NULL_string_TEST(void*)
48 {
49 test_null(memcached(NULL, 75));
50 return TEST_SUCCESS;
51 }
52
53 static test_return_t memcached_zero_string_length_TEST(void*)
54 {
55 test_null(memcached("value", 0));
56 return TEST_SUCCESS;
57 }
58
59 static test_return_t putenv_localhost_quoted_TEST(void*)
60 {
61 char set_env[1024];
62
63 snprintf(set_env, sizeof(set_env), "LIBMEMCACHED=\"--server=localhost\"");
64 test_zero(putenv(set_env));
65 test_null(memcached(NULL, 0));
66
67 return TEST_SUCCESS;
68 }
69
70 static test_return_t putenv_NULL_TEST(void*)
71 {
72 char set_env[1024];
73
74 snprintf(set_env, sizeof(set_env), "LIBMEMCACHED");
75 test_zero(putenv(set_env));
76 memcached_st *memc= memcached(NULL, 0);
77 test_true(memc);
78
79 memcached_free(memc);
80
81 return TEST_SUCCESS;
82 }
83
84 static test_return_t putenv_NULL_TEST2(void*)
85 {
86 char set_env[1024];
87
88 snprintf(set_env, sizeof(set_env), "LIBMEMCACHED=");
89 test_zero(putenv(set_env));
90 memcached_st *memc= memcached(NULL, 0);
91 test_true(memc);
92
93 memcached_free(memc);
94
95 return TEST_SUCCESS;
96 }
97
98 static test_return_t putenv_localhost_TEST(void*)
99 {
100 char set_env[1024];
101
102 snprintf(set_env, sizeof(set_env), "LIBMEMCACHED=--server=localhost");
103 test_zero(putenv(set_env));
104 memcached_st *memc= memcached(NULL, 0);
105 test_true(memc);
106
107 memcached_free(memc);
108
109 return TEST_SUCCESS;
110 }
111
112 test_st memcached_TESTS[] ={
113 {"memcached(NULL, 75)", false, (test_callback_fn*)memcached_NULL_string_TEST },
114 {"memcached(\"value\", 0)", false, (test_callback_fn*)memcached_zero_string_length_TEST },
115 {"putenv(LIBMEMCACHED=--server=localhost)", false, (test_callback_fn*)putenv_localhost_TEST },
116 {"putenv(LIBMEMCACHED)", false, (test_callback_fn*)putenv_NULL_TEST },
117 {"putenv(LIBMEMCACHED=)", false, (test_callback_fn*)putenv_NULL_TEST2 },
118 {"putenv(LIBMEMCACHED=--server=\"localhost\")", false, (test_callback_fn*)putenv_localhost_quoted_TEST },
119 {0, 0, 0}
120 };
121
122 collection_st collection[] ={
123 {"memcached()", 0, 0, memcached_TESTS},
124 {0, 0, 0, 0}
125 };
126
127 void get_world(Framework *world)
128 {
129 world->collections= collection;
130 }
131