diff --git a/tests/unittests/Makefile b/tests/unittests/Makefile index 0040596b657a29048dd4e0aaea955021c17aacf3..1eac995e0a4ae9e119d8dde93717880ab8a80bbb 100644 --- a/tests/unittests/Makefile +++ b/tests/unittests/Makefile @@ -32,5 +32,15 @@ $(UNIT_TESTS): all $(UNITTEST_LIBS): $(BINDIR)%.a: "$(MAKE)" -C $(CURDIR)/$* -CFLAGS += $(shell echo $(UNIT_TESTS:tests-%=-DTEST_%_ENABLED) | tr a-z A-Z) +charEMPTY := +charSPACE := $(charEMPTY) $(charEMPTY) +charCOMMA := , + +ifeq (, $(UNIT_TESTS)) + CFLAGS += -DNO_TEST_SUITES + $(warning There was no test suite specified!) +else + CFLAGS += -DTEST_SUITES='$(subst $(charSPACE),$(charCOMMA),$(UNIT_TESTS:tests-%=%))' +endif + BASELIBS += $(UNITTEST_LIBS) diff --git a/tests/unittests/main.c b/tests/unittests/main.c index 5af00349abd5488147460ee75bb25345f60637d4..b9869d75fdb515ca23aeddae909313310771eed4 100644 --- a/tests/unittests/main.c +++ b/tests/unittests/main.c @@ -7,9 +7,18 @@ */ #include "unittests.h" +#include "map.h" #include "lpm.h" +#define UNCURRY(FUN, ARGS) FUN(ARGS) +#define RUN_TEST_SUITES(...) MAP(RUN_TEST_SUITE, __VA_ARGS__) +#define RUN_TEST_SUITE(TEST_SUITE) \ + do { \ + extern void tests_##TEST_SUITE(void); \ + tests_##TEST_SUITE(); \ + } while (0); + int main(void) { #ifdef OUTPUT @@ -17,13 +26,9 @@ int main(void) #endif TESTS_START(); - - /* put test TEST_RUN() calls here: */ - /* #ifdef TEST_xxx_ENABLED - * tests_xxx(); - * #endif - */ - +#ifndef NO_TEST_SUITES + UNCURRY(RUN_TEST_SUITES, TEST_SUITES) +#endif TESTS_END(); #if defined (BOARD_NATIVE) && !defined (OUTPUT) diff --git a/tests/unittests/map.h b/tests/unittests/map.h new file mode 100644 index 0000000000000000000000000000000000000000..452ae0348d588d2547487dd17db07924cd9704be --- /dev/null +++ b/tests/unittests/map.h @@ -0,0 +1,51 @@ +/* + * Copyright (C) 2012 William Swanson + * + * Permission is hereby granted, free of charge, to any person + * obtaining a copy of this software and associated documentation + * files (the "Software"), to deal in the Software without + * restriction, including without limitation the rights to use, copy, + * modify, merge, publish, distribute, sublicense, and/or sell copies + * of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be + * included in all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, + * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF + * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND + * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY + * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF + * CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION + * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + * + * Except as contained in this notice, the names of the authors or + * their institutions shall not be used in advertising or otherwise to + * promote the sale, use or other dealings in this Software without + * prior written authorization from the authors. + */ + +#ifndef MAP_H_INCLUDED +#define MAP_H_INCLUDED + +#define EVAL0(...) __VA_ARGS__ +#define EVAL1(...) EVAL0 (EVAL0 (EVAL0 (__VA_ARGS__))) +#define EVAL2(...) EVAL1 (EVAL1 (EVAL1 (__VA_ARGS__))) +#define EVAL3(...) EVAL2 (EVAL2 (EVAL2 (__VA_ARGS__))) +#define EVAL4(...) EVAL3 (EVAL3 (EVAL3 (__VA_ARGS__))) +#define EVAL(...) EVAL4 (EVAL4 (EVAL4 (__VA_ARGS__))) + +#define MAP_END(...) +#define MAP_OUT + +#define MAP_GET_END() 0, MAP_END +#define MAP_NEXT0(test, next, ...) next MAP_OUT +#define MAP_NEXT1(test, next) MAP_NEXT0 (test, next, 0) +#define MAP_NEXT(test, next) MAP_NEXT1 (MAP_GET_END test, next) + +#define MAP0(f, x, peek, ...) f(x) MAP_NEXT (peek, MAP1) (f, peek, __VA_ARGS__) +#define MAP1(f, x, peek, ...) f(x) MAP_NEXT (peek, MAP0) (f, peek, __VA_ARGS__) +#define MAP(f, ...) EVAL (MAP1 (f, __VA_ARGS__, (), 0)) + +#endif