From 6f92e9da2f6b0223c34728da34be65d76d5db485 Mon Sep 17 00:00:00 2001 From: sanine Date: Thu, 23 Sep 2021 22:06:41 -0500 Subject: add basic test framework --- src/test/logging/logging_tests.c | 6 ++++++ src/test/minunit.h | 41 ++++++++++++++++++++++++++++++++++++++++ src/test/suites.h | 11 +++++++++++ src/test/test_main.c | 14 ++++++++++++++ 4 files changed, 72 insertions(+) create mode 100644 src/test/logging/logging_tests.c create mode 100644 src/test/minunit.h create mode 100644 src/test/suites.h create mode 100644 src/test/test_main.c (limited to 'src/test') diff --git a/src/test/logging/logging_tests.c b/src/test/logging/logging_tests.c new file mode 100644 index 0000000..2e92d68 --- /dev/null +++ b/src/test/logging/logging_tests.c @@ -0,0 +1,6 @@ +#include "../minunit.h" +#include "../suites.h" + +void honey_logging_tests() +{ +} diff --git a/src/test/minunit.h b/src/test/minunit.h new file mode 100644 index 0000000..b1bfda7 --- /dev/null +++ b/src/test/minunit.h @@ -0,0 +1,41 @@ +#ifndef MINUNIT_H +#define MINUNIT_H + +#include + +#define STR_IMPL(x) #x +#define STR(x) STR_IMPL(x) + +#define MU_INDENT " " + +/* minunit testing macros from /www.jera.com/techinfo/jtns/jtn002.html */ +#define mu_assert(test, message) do { if (!(test)) return message "\n" MU_INDENT "[" __FILE__ ":" STR(__LINE__) "]"; } while (0) +#define mu_assert_equal(a, b) mu_assert(a == b, "'" #a "' is not equal to '" #b "'") +#define mu_assert_unequal(a, b) mu_assert(a != b, "'" #a "' is equal to '" #b "'") +#define mu_assert_streq(a, b) mu_assert(strcmp(a, b) == 0, "'" #a "' is not equal to '" #b "'") + +#define mu_run_test(name, test) do { \ + const char *message = test(); \ + tests_run++; \ + if (message) { \ + printf(MU_INDENT "test '%s' failed: %s\n", name, message); \ + tests_failed++; \ + } \ + } while (0) +#define mu_run_suite(suite) do { \ + int tests_run_old = tests_run; \ + printf("suite: " #suite "\n"); \ + suite(); \ + printf(MU_INDENT "ran %d tests\n\n", \ + tests_run - tests_run_old); \ + } while(0) +#define mu_tests_finished() do { \ + printf("ran %d tests, %d failed\n", tests_run, tests_failed); \ + return tests_failed; \ + } while(0) + +#define mu_test const char * + +extern int tests_run, tests_failed; + +#endif diff --git a/src/test/suites.h b/src/test/suites.h new file mode 100644 index 0000000..1dec589 --- /dev/null +++ b/src/test/suites.h @@ -0,0 +1,11 @@ +#ifndef HONEY_TESTS_SUITES +#define HONEY_TESTS_SUITES + +#include "minunit.h" + +void honey_logging_tests(); + +#define RUN_TESTS \ + mu_run_suite(honey_logging_tests); + +#endif diff --git a/src/test/test_main.c b/src/test/test_main.c new file mode 100644 index 0000000..a4e776a --- /dev/null +++ b/src/test/test_main.c @@ -0,0 +1,14 @@ +#include "minunit.h" +#include "suites.h" + +int tests_run = 0; +int tests_failed = 0; + +int main() +{ + printf("~~~~~~~~ running tests ~~~~~~~~\n\n"); + RUN_TESTS; + printf("~~~~~~~~~ tests done ~~~~~~~~~~\n\n"); + + mu_tests_finished(); +} -- cgit v1.2.1