Setting a max and min for gpsd timeout.
[collectd.git] / src / testing.h
1 /**
2  * collectd - src/tests/macros.h
3  * Copyright (C) 2013-2015  Florian octo Forster
4  *
5  * Permission is hereby granted, free of charge, to any person obtaining a
6  * copy of this software and associated documentation files (the "Software"),
7  * to deal in the Software without restriction, including without limitation
8  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
9  * and/or sell copies of the Software, and to permit persons to whom the
10  * Software is furnished to do so, subject to the following conditions:
11  *
12  * The above copyright notice and this permission notice shall be included in
13  * all copies or substantial portions of the Software.
14  *
15  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
21  * DEALINGS IN THE SOFTWARE.
22  *
23  * Authors:
24  *   Florian octo Forster <octo at collectd.org>
25  */
26
27 #include <inttypes.h>
28
29 static int fail_count__ = 0;
30 static int check_count__ = 0;
31
32 #ifndef DBL_PRECISION
33 # define DBL_PRECISION 1e-12
34 #endif
35
36 #define DEF_TEST(func) static int test_##func ()
37
38 #define RUN_TEST(func) do { \
39   int status; \
40   printf ("Testing %s ...\n", #func); \
41   status = test_ ## func (); \
42   printf ("%s.\n", (status == 0) ? "Success" : "FAILURE"); \
43   if (status != 0) { fail_count__++; } \
44 } while (0)
45
46 #define END_TEST exit ((fail_count__ == 0) ? 0 : 1);
47
48 #define OK1(cond, text) do { \
49   _Bool result = (cond); \
50   printf ("%s %i - %s\n", result ? "ok" : "not ok", ++check_count__, text); \
51   if (!result) { return -1; } \
52 } while (0)
53 #define OK(cond) OK1(cond, #cond)
54
55 #define EXPECT_EQ_STR(expect, actual) do { \
56   if (strcmp (expect, actual) != 0) { \
57     printf ("not ok %i - %s = \"%s\", want \"%s\"\n", \
58         ++check_count__, #actual, actual, expect); \
59     return (-1); \
60   } \
61   printf ("ok %i - %s = \"%s\"\n", ++check_count__, #actual, actual); \
62 } while (0)
63
64 #define EXPECT_EQ_INT(expect, actual) do { \
65   int want__ = (int) expect; \
66   int got__  = (int) actual; \
67   if (got__ != want__) { \
68     printf ("not ok %i - %s = %d, want %d\n", \
69         ++check_count__, #actual, got__, want__); \
70     return (-1); \
71   } \
72   printf ("ok %i - %s = %d\n", ++check_count__, #actual, got__); \
73 } while (0)
74
75 #define EXPECT_EQ_UINT64(expect, actual) do { \
76   uint64_t want__ = (uint64_t) expect; \
77   uint64_t got__  = (uint64_t) actual; \
78   if (got__ != want__) { \
79     printf ("not ok %i - %s = %"PRIu64", want %"PRIu64"\n", \
80         ++check_count__, #actual, got__, want__); \
81     return (-1); \
82   } \
83   printf ("ok %i - %s = %"PRIu64"\n", ++check_count__, #actual, got__); \
84 } while (0)
85
86 #define EXPECT_EQ_DOUBLE(expect, actual) do { \
87   double want__ = (double) expect; \
88   double got__  = (double) actual; \
89   if (isnan (want__) && !isnan (got__)) { \
90     printf ("not ok %i - %s = %.15g, want %.15g\n", \
91         ++check_count__, #actual, got__, want__); \
92     return (-1); \
93   } else if (!isnan (want__) && (((want__-got__) < -DBL_PRECISION) || ((want__-got__) > DBL_PRECISION))) { \
94     printf ("not ok %i - %s = %.15g, want %.15g\n", \
95         ++check_count__, #actual, got__, want__); \
96     return (-1); \
97   } \
98   printf ("ok %i - %s = %.15g\n", ++check_count__, #actual, got__); \
99 } while (0)
100
101 #define CHECK_NOT_NULL(expr) do { \
102   void *ptr_; \
103   ptr_ = (expr); \
104   OK1(ptr_ != NULL, #expr); \
105 } while (0)
106
107 #define CHECK_ZERO(expr) do { \
108   long status_; \
109   status_ = (long) (expr); \
110   OK1(status_ == 0L, #expr); \
111 } while (0)