utest_assert.h 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. /*
  2. * Copyright (c) 2006-2021, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2018-11-19 MurphyZhao the first version
  9. */
  10. #ifndef __UTEST_ASSERT_H__
  11. #define __UTEST_ASSERT_H__
  12. #include "utest.h"
  13. #include <rtthread.h>
  14. #ifdef __cplusplus
  15. extern "C" {
  16. #endif
  17. /* No need for the user to use this function directly */
  18. rt_bool_t utest_assert(int value, const char *file, int line, const char *func, const char *msg);
  19. /* No need for the user to use this function directly */
  20. void utest_assert_string(const char *a, const char *b, rt_bool_t equal, const char *file, int line, const char *func, const char *msg);
  21. void utest_assert_buf(const char *a, const char *b, rt_size_t sz, rt_bool_t equal, const char *file, int line, const char *func, const char *msg);
  22. /* No need for the user to use this macro directly */
  23. #define __utest_assert(value, msg) utest_assert(value, __FILE__, __LINE__, __func__, msg)
  24. #define __uassert_value_op(a, b, op) __utest_assert((a) op (b), "(" #a ") not " #op " (" #b ")")
  25. /**
  26. * uassert_x macros
  27. *
  28. * @brief Get the utest data structure handle.
  29. * No need for the user to call this function directly.
  30. *
  31. * @macro uassert_true if @value is true, not assert, means passing.
  32. * @macro uassert_false if @value is false, not assert, means passing.
  33. * @macro uassert_null if @value is null, not assert, means passing.
  34. * @macro uassert_not_null if @value is not null, not assert, means passing.
  35. * @macro uassert_int_equal if @a equal to @b, not assert, means passing. Integer type test.
  36. * @macro uassert_int_not_equal if @a not equal to @b, not assert, means passing. Integer type test.
  37. * @macro uassert_str_equal if @a equal to @b, not assert, means passing. String type test.
  38. * @macro uassert_str_not_equal if @a not equal to @b, not assert, means passing. String type test.
  39. * @macro uassert_buf_equal if @a equal to @b, not assert, means passing. buf type test.
  40. * @macro uassert_buf_not_equal if @a not equal to @b, not assert, means passing. buf type test.
  41. * @macro uassert_in_range if @value is in range of min and max, not assert, means passing.
  42. * @macro uassert_not_in_range if @value is not in range of min and max, not assert, means passing.
  43. * @macro uassert_float_equal if @a equal to @b, not assert, means passing. Float type test.
  44. * @macro uassert_float_not_equal if @a not equal to @b, not assert, means passing. Float type test.
  45. * @macro uassert_value_less if @a less than @b, not assert, means passing.
  46. * @macro uassert_value_less_equal if @a less than or equal to @b, not assert, means passing.
  47. * @macro uassert_value_greater if @a greater than @b, not assert, means passing.
  48. * @macro uassert_value_greater_equal if @a greater than or equal to @b, not assert, means passing.
  49. * @macro uassert_ptr_equal if @a equal to @b, not assert, means passing. Pointer type test.
  50. * @macro uassert_ptr_not_equal if @a not equal to @b, not assert, means passing. Pointer type test.
  51. */
  52. #define uassert_true(value) __utest_assert(value, "(" #value ") is false")
  53. #define uassert_false(value) __utest_assert(!(value), "(" #value ") is true")
  54. #define uassert_null(value) __utest_assert((const char *)(value) == RT_NULL, "(" #value ") is not null")
  55. #define uassert_not_null(value) __utest_assert((const char *)(value) != RT_NULL, "(" #value ") is null")
  56. #define uassert_in_range(value, min, max) \
  57. do { \
  58. double _value = (value); \
  59. double _min = (min); \
  60. double _max = (max); \
  61. __utest_assert((_value >= _min) && (_value <= _max), "(" #value ") not in range("#min","#max")"); \
  62. } while(0)
  63. #define uassert_not_in_range(value, min, max) \
  64. do { \
  65. double _value = (value); \
  66. double _min = (min); \
  67. double _max = (max); \
  68. __utest_assert((_value < _min) || (_value > _max), "(" #value ") in range("#min","#max")"); \
  69. } while(0)
  70. #define uassert_float_equal(a, b) \
  71. do { \
  72. double _a = (a); \
  73. double _b = (b); \
  74. uassert_in_range(_a, ((double)_b - 0.0001), ((double)_b + 0.0001)); \
  75. } while(0)
  76. #define uassert_float_not_equal(a, b) \
  77. do { \
  78. double _a = (a); \
  79. double _b = (b); \
  80. uassert_not_in_range(_a, ((double)_b - 0.0001), ((double)_b + 0.0001)); \
  81. } while(0)
  82. #define uassert_int_equal(a, b) __uassert_value_op(a, b, ==)
  83. #define uassert_int_not_equal(a, b) __uassert_value_op(a, b, !=)
  84. #define uassert_value_less(a, b) __uassert_value_op(a, b, <)
  85. #define uassert_value_less_equal(a, b) __uassert_value_op(a, b, <=)
  86. #define uassert_value_greater(a, b) __uassert_value_op(a, b, >)
  87. #define uassert_value_greater_equal(a, b) __uassert_value_op(a, b, >=)
  88. #define uassert_ptr_equal(a, b) __utest_assert((const void*)(a) == (const void*)(b), "(" #a ") not equal to (" #b ")")
  89. #define uassert_ptr_not_equal(a, b) __utest_assert((const void*)(a) != (const void*)(b), "(" #a ") equal to (" #b ")")
  90. #define uassert_str_equal(a, b) utest_assert_string((const char*)(a), (const char*)(b), RT_TRUE, __FILE__, __LINE__, __func__, "string not equal")
  91. #define uassert_str_not_equal(a, b) utest_assert_string((const char*)(a), (const char*)(b), RT_FALSE, __FILE__, __LINE__, __func__, "string equal")
  92. #define uassert_buf_equal(a, b, sz) utest_assert_buf((const char*)(a), (const char*)(b), (sz), RT_TRUE, __FILE__, __LINE__, __func__, "buf not equal")
  93. #define uassert_buf_not_equal(a, b, sz) utest_assert_buf((const char*)(a), (const char*)(b), (sz), RT_FALSE, __FILE__, __LINE__, __func__, "buf equal")
  94. #ifdef __cplusplus
  95. }
  96. #endif
  97. #endif /* __UTEST_ASSERT_H__ */