X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/f9df6a0ce7023e4e22d83bb6c50f27bd21fab329..c4de3b4124781ae066e774981efb0a6ef8c857ed:/include/xbt/cunit.h diff --git a/include/xbt/cunit.h b/include/xbt/cunit.h index 6bfa6a0d40..5b9ee2df29 100644 --- a/include/xbt/cunit.h +++ b/include/xbt/cunit.h @@ -1,18 +1,19 @@ /* cunit - A little C Unit facility */ -/* Copyright (c) 2005-2014. The SimGrid Team. - * All rights reserved. */ +/* Copyright (c) 2005-2019. The SimGrid Team. All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it * under the terms of the license (GNU LGPL) which comes with this package. */ /* This is partially inspired from the OSSP ts (Test Suite Library) */ -#ifndef _XBT_CUNIT_H_ -#define _XBT_CUNIT_H_ +#ifndef XBT_CUNIT_H_ +#define XBT_CUNIT_H_ -#include "xbt/sysdep.h" /* XBT_GNU_PRINTF */ -#include "xbt/ex.h" +#ifdef __cplusplus +#include +#endif +#include /* XBT_ATTRIB_PRINTF */ SG_BEGIN_DECL() @@ -28,19 +29,17 @@ typedef struct s_xbt_test_unit *xbt_test_unit_t; typedef void (*ts_test_cb_t) (); /* test suite operations */ -XBT_PUBLIC(xbt_test_suite_t) xbt_test_suite_new(const char *name, const char *fmt, ...); -XBT_PUBLIC(xbt_test_suite_t) xbt_test_suite_by_name(const char *name, const char *fmt, ...); -XBT_PUBLIC(void) xbt_test_suite_dump(xbt_test_suite_t suite); -XBT_PUBLIC(void) xbt_test_suite_push(xbt_test_suite_t suite, const char *name, ts_test_cb_t func, const char *fmt, ...); +XBT_PUBLIC xbt_test_suite_t xbt_test_suite_by_name(const char* name, const char* fmt, ...); +XBT_PUBLIC void xbt_test_suite_push(xbt_test_suite_t suite, const char* name, ts_test_cb_t func, const char* fmt, ...); /* Run all the specified tests. what_to_do allows to disable some tests. * It is a coma (,) separated list of directives. They are applied from left to right. * * Each of them of form: - * + * * [-|+]suitename[:unitname[:testname]] - * - * * First char: + * + * * First char: * if it's a '-', the directive disables something * if it's a '+', the directive enables something * By default, everything is enabled, but you can disable a suite and reenable some parts @@ -49,30 +48,30 @@ XBT_PUBLIC(void) xbt_test_suite_push(xbt_test_suite_t suite, const char *name, t * * testname: if given, the test on which the directive acts. If not, acts on any tests. */ -XBT_PUBLIC(int) xbt_test_run(char *selection, int verbosity); +XBT_PUBLIC int xbt_test_run(char* selection, int verbosity); /* Show information about the selection of tests */ -XBT_PUBLIC(void) xbt_test_dump(char *selection); +XBT_PUBLIC void xbt_test_dump(char* selection); /* Cleanup the mess */ -XBT_PUBLIC(void) xbt_test_exit(); +XBT_PUBLIC void xbt_test_exit(); -/** +/** * @addtogroup XBT_cunit * @brief Unit testing implementation (see @ref inside_tests_add_units) - * + * * This module is mainly intended to allow the tests of SimGrid itself and may lack the level of genericity that you * would expect as a user. Only use it in external projects at your own risk (but it works rather well for us). We play * with the idea of migrating to an external solution for our unit tests, possibly offering more features, but having * absolutely no dependencies is a nice feature of SimGrid (and this code is sufficient to cover our needs, actually, * so why should we bother switching?) - * + * * Unit testing is not intended to write integration tests. - * Please refer to \ref inside_tests_add_integration for that instead. + * Please refer to @ref inside_tests_add_integration for that instead. * - * @{ + * @{ */ /** @brief Provide information about the suite declared in this file * @hideinitializer - * + * * Actually, this macro is only used by the script extracting the test units, but that should be transparent for you. * * @param suite_name the short name of this suite, to be used in the --tests argument of testall afterward. Avoid @@ -99,18 +98,18 @@ XBT_PUBLIC(void) xbt_test_exit(); #endif /* test operations */ -XBT_PUBLIC(void) _xbt_test_add(const char *file, int line, const char *fmt, ...) XBT_ATTRIB_PRINTF(3, 4); -XBT_PUBLIC(void) _xbt_test_fail(const char *file, int line, const char *fmt, ...) XBT_ATTRIB_PRINTF(3, 4); -XBT_PUBLIC(void) _xbt_test_log(const char *file, int line, const char *fmt, ...) XBT_ATTRIB_PRINTF(3, 4); -/** @brief Declare that a new test begins (printf-like parameters, describing the test) +XBT_PUBLIC void _xbt_test_add(const char* file, int line, const char* fmt, ...) XBT_ATTRIB_PRINTF(3, 4); +XBT_PUBLIC void _xbt_test_fail(const char* file, int line, const char* fmt, ...) XBT_ATTRIB_PRINTF(3, 4); +XBT_PUBLIC void _xbt_test_log(const char* file, int line, const char* fmt, ...) XBT_ATTRIB_PRINTF(3, 4); +/** @brief Declare that a new test begins (printf-like parameters, describing the test) * @hideinitializer */ #define xbt_test_add(...) _xbt_test_add(__FILE__, __LINE__, __VA_ARGS__) -/** @brief Declare that the lastly started test failed (printf-like parameters, describing failure cause) +/** @brief Declare that the lastly started test failed (printf-like parameters, describing failure cause) * @hideinitializer */ #define xbt_test_fail(...) _xbt_test_fail(__FILE__, __LINE__, __VA_ARGS__) /** @brief The lastly started test is actually an assert - * @hideinitializer - * + * @hideinitializer + * * - If provided a uniq parameter, this is assumed to be a condition that is expected to be true * - If provided more parameters, the first one is a condition, and the other ones are printf-like arguments that are * to be displayed when the condition fails. @@ -126,15 +125,17 @@ XBT_PUBLIC(void) _xbt_test_log(const char *file, int line, const char *fmt, ...) * @hideinitializer */ #define xbt_test_log(...) _xbt_test_log(__FILE__, __LINE__, __VA_ARGS__) +#ifdef __cplusplus /** @brief Declare that the lastly started test failed because of the provided exception */ -XBT_PUBLIC(void) xbt_test_exception(xbt_ex_t e); +XBT_PUBLIC void xbt_test_exception(xbt_ex e); +#endif /** @brief Declare that the lastly started test was expected to fail (and actually failed) */ -XBT_PUBLIC(void) xbt_test_expect_failure(); +XBT_PUBLIC void xbt_test_expect_failure(); /** @brief Declare that the lastly started test should be skipped today */ -XBT_PUBLIC(void) xbt_test_skip(); +XBT_PUBLIC void xbt_test_skip(); /** @} */ SG_END_DECL() -#endif /* _XBT_CUNIT_H_ */ +#endif /* XBT_CUNIT_H_ */