X-Git-Url: https://codewiz.org/gitweb?a=blobdiff_plain;ds=sidebyside;f=bertos%2Fcfg%2Ftest.h;h=048ff57b8855b3de2192f10f90e0399ec5869474;hb=4695182ccb9c285778768d7fe95dac52956a7f68;hp=507ec17e8a9c22bc628e31629365e8a5e7263226;hpb=05b29c052a3454757bad2a8d2344261a59cd7a55;p=bertos.git diff --git a/bertos/cfg/test.h b/bertos/cfg/test.h index 507ec17e..048ff57b 100644 --- a/bertos/cfg/test.h +++ b/bertos/cfg/test.h @@ -48,14 +48,16 @@ * All of these should return 0 if ok or a value != 0 on errors. * * Then, at the end of your module_test you can write: - * #include TEST_ONLY(whatuneed.h) - * #include TEST_ONLY(whatuneed.c) - * #include TEST_ONLY(...) + * \code + * #if UNIT_TEST + * #include + * #include + * #include <...> * - * TEST_MAIN(module); + * TEST_MAIN(module); + * #endif + * \endcode * - * The macro TEST_ONLY expand to nothing in non-TEST mode or to - * the specified filename if _TEST is defined. * Including directly into your module the file.c you need to * run the test allows you to build and run the test compiling * only one file. @@ -69,33 +71,29 @@ #ifndef CFG_TEST_H #define CFG_TEST_H -#ifdef _TEST +#include "cfg/cfg_arch.h" - /** - * Macro used to generate a main() for a test to be compiled - * on hosted platform. - */ - #define TEST_MAIN(module) \ - int main(void) \ - { \ - if (module##_testSetup() != 0) \ - return 1; \ - if (module##_testRun() != 0) \ - return 2; \ - if (module##_testTearDown() != 0) \ - return 3; \ - return 0; \ - } +#if defined(ARCH_UNITTEST) && (ARCH & ARCH_UNITTEST) + #define UNIT_TEST 1 +#else /* !TEST */ + #define UNIT_TEST 0 +#endif /* TEST */ - /** This macro will include the specified file only in test-mode */ - #define TEST_ONLY(file) PP_STRINGIZE(file) - -#else /* !_TEST */ - - #define TEST_MAIN(module) /* nothing */ - #define TEST_ONLY(file) - -#endif /* _TEST */ +/** + * Macro used to generate a main() for a test to be compiled + * on hosted platform. + */ +#define TEST_MAIN(module) \ +int main(void) \ +{ \ + if (module##_testSetup() != 0) \ + return 1; \ + if (module##_testRun() != 0) \ + return 2; \ + if (module##_testTearDown() != 0) \ + return 3; \ + return 0; \ +} /** * Silent an assert in a test.