1 /* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
3 * Data Differential YATL (i.e. libtest) library
5 * Copyright (C) 2012 Data Differential, http://datadifferential.com/
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions are
11 * * Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
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
19 * * The names of its contributors may not be used to endorse or
20 * promote products derived from this software without specific prior
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.
37 #include "libtest/yatlcon.h"
38 #include <libtest/common.h>
40 /* Use this for string generation */
41 static const char ALPHANUMERICS
[]=
42 "0123456789ABCDEFGHIJKLMNOPQRSTWXYZabcdefghijklmnopqrstuvwxyz";
44 #define ALPHANUMERICS_SIZE (sizeof(ALPHANUMERICS)-1)
46 static size_t get_alpha_num(void)
48 return (size_t)random() % ALPHANUMERICS_SIZE
;
53 int random_alpha_num(void)
55 return ALPHANUMERICS
[get_alpha_num()];
58 static std::string
printer(const char *str
, size_t length
)
60 std::ostringstream buf
;
61 for (size_t x
= 0; x
< length
; x
++)
69 buf
<< "(" << int(str
[x
]) << ")";
78 int compare(libtest::vchar_t
& arg
, const char *str
, size_t length
)
80 if (arg
.size() == length
and (memcmp(&arg
[0], str
, length
) == 0))
84 else if (arg
.size() > length
)
92 void make(libtest::vchar_t
& arg
)
94 size_t length
= rand() % 1024;
98 void make(libtest::vchar_t
& arg
, size_t length
)
101 for (uint32_t x
= 0; x
< length
; ++x
)
103 arg
.push_back(ALPHANUMERICS
[get_alpha_num()]);
107 void chomp(libtest::vchar_t
& arg
)
122 void append(libtest::vchar_ptr_t
& arg
, const char* ptr
)
126 char* new_ptr
= strdup(ptr
);
129 FATAL("UNABLE to allocate %s(%p)", ptr
, ptr
);
132 arg
.push_back(new_ptr
);
136 void append(libtest::vchar_t
& arg
, const char* ptr
)
140 size_t length
= strlen(ptr
);
155 void make_vector(libtest::vchar_t
& arg
, const char *str
, size_t length
)
158 memcpy(&arg
[0], str
, length
);
161 std::ostream
& operator<<(std::ostream
& output
, const libtest::vchar_t
& arg
)
163 std::string tmp
= libtest::printer(&arg
[0], arg
.size());
164 output
<< tmp
<< "[" << arg
.size() << "]";
169 } // namespace libtest