X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Ftesting.h;h=c0a9e88ac09cd6c50f7631d281e5afd98a061670;hb=124f321bbbf0d27fe2b3e5bcb53773fc1686e133;hp=805449f7b933dad837f42b56137b613263e00fb8;hpb=bf1613564dfcb0a517b77d658a844ea37b45803f;p=collectd.git diff --git a/src/testing.h b/src/testing.h index 805449f7..c0a9e88a 100644 --- a/src/testing.h +++ b/src/testing.h @@ -24,9 +24,18 @@ * Florian octo Forster */ +#ifndef TESTING_H +#define TESTING_H 1 + +#include + static int fail_count__ = 0; static int check_count__ = 0; +#ifndef DBL_PRECISION +# define DBL_PRECISION 1e-12 +#endif + #define DEF_TEST(func) static int test_##func () #define RUN_TEST(func) do { \ @@ -46,36 +55,50 @@ static int check_count__ = 0; } while (0) #define OK(cond) OK1(cond, #cond) -#define STREQ(expect, actual) do { \ +#define EXPECT_EQ_STR(expect, actual) do { \ if (strcmp (expect, actual) != 0) { \ - printf ("not ok %i - %s incorrect: expected \"%s\", got \"%s\"\n", \ - ++check_count__, #actual, expect, actual); \ + printf ("not ok %i - %s = \"%s\", want \"%s\"\n", \ + ++check_count__, #actual, actual, expect); \ + return (-1); \ + } \ + printf ("ok %i - %s = \"%s\"\n", ++check_count__, #actual, actual); \ +} while (0) + +#define EXPECT_EQ_INT(expect, actual) do { \ + int want__ = (int) expect; \ + int got__ = (int) actual; \ + if (got__ != want__) { \ + printf ("not ok %i - %s = %d, want %d\n", \ + ++check_count__, #actual, got__, want__); \ return (-1); \ } \ - printf ("ok %i - %s evaluates to \"%s\"\n", ++check_count__, #actual, expect); \ + printf ("ok %i - %s = %d\n", ++check_count__, #actual, got__); \ } while (0) -#define EXPECT_INTEQ(expect, actual) do { \ - if ((expect) != (actual)) {\ - printf ("not ok %i - %s incorrect: expected %d, got %d\n", \ - ++check_count__, #actual, expect, actual); \ +#define EXPECT_EQ_UINT64(expect, actual) do { \ + uint64_t want__ = (uint64_t) expect; \ + uint64_t got__ = (uint64_t) actual; \ + if (got__ != want__) { \ + printf ("not ok %i - %s = %"PRIu64", want %"PRIu64"\n", \ + ++check_count__, #actual, got__, want__); \ return (-1); \ } \ - printf ("ok %i - %s evaluates to %d\n", ++check_count__, #actual, expect); \ + printf ("ok %i - %s = %"PRIu64"\n", ++check_count__, #actual, got__); \ } while (0) -#define DBLEQ(expect, actual) do { \ - double e = (expect); double a = (actual); \ - if (isnan (e) && !isnan (a)) { \ - printf ("not ok %i - %s incorrect: expected %.15g, got %.15g\n", \ - ++check_count__, #actual, e, a); \ +#define EXPECT_EQ_DOUBLE(expect, actual) do { \ + double want__ = (double) expect; \ + double got__ = (double) actual; \ + if (isnan (want__) && !isnan (got__)) { \ + printf ("not ok %i - %s = %.15g, want %.15g\n", \ + ++check_count__, #actual, got__, want__); \ return (-1); \ - } else if (!isnan (e) && (((e-a) < -1e-12) || ((e-a) > 1e-12))) { \ - printf ("not ok %i - %s incorrect: expected %.15g, got %.15g\n", \ - ++check_count__, #actual, e, a); \ + } else if (!isnan (want__) && (((want__-got__) < -DBL_PRECISION) || ((want__-got__) > DBL_PRECISION))) { \ + printf ("not ok %i - %s = %.15g, want %.15g\n", \ + ++check_count__, #actual, got__, want__); \ return (-1); \ } \ - printf ("ok %i - %s evaluates to %.15g\n", ++check_count__, #actual, e); \ + printf ("ok %i - %s = %.15g\n", ++check_count__, #actual, got__); \ } while (0) #define CHECK_NOT_NULL(expr) do { \ @@ -89,3 +112,5 @@ static int check_count__ = 0; status_ = (long) (expr); \ OK1(status_ == 0L, #expr); \ } while (0) + +#endif /* TESTING_H */