test.h 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. /* Copyright (c) 2001-2003, Roger Dingledine.
  2. * Copyright (c) 2004-2006, Roger Dingledine, Nick Mathewson.
  3. * Copyright (c) 2007-2013, The Tor Project, Inc. */
  4. /* See LICENSE for licensing information */
  5. #ifndef TOR_TEST_H
  6. #define TOR_TEST_H
  7. /**
  8. * \file test.h
  9. * \brief Macros and functions used by unit tests.
  10. */
  11. #include "compat.h"
  12. #include "tinytest.h"
  13. #define TT_EXIT_TEST_FUNCTION STMT_BEGIN goto done; STMT_END
  14. #include "tinytest_macros.h"
  15. #ifdef __GNUC__
  16. #define PRETTY_FUNCTION __PRETTY_FUNCTION__
  17. #else
  18. #define PRETTY_FUNCTION ""
  19. #endif
  20. #define test_assert(expr) tt_assert(expr)
  21. #define test_eq(expr1, expr2) tt_int_op((expr1), ==, (expr2))
  22. #define test_eq_ptr(expr1, expr2) tt_ptr_op((expr1), ==, (expr2))
  23. #define test_neq(expr1, expr2) tt_int_op((expr1), !=, (expr2))
  24. #define test_neq_ptr(expr1, expr2) tt_ptr_op((expr1), !=, (expr2))
  25. #define test_streq(expr1, expr2) tt_str_op((expr1), ==, (expr2))
  26. #define test_strneq(expr1, expr2) tt_str_op((expr1), !=, (expr2))
  27. #define test_mem_op(expr1, op, expr2, len) \
  28. tt_mem_op((expr1), op, (expr2), (len))
  29. #define test_memeq(expr1, expr2, len) test_mem_op((expr1), ==, (expr2), len)
  30. #define test_memneq(expr1, expr2, len) test_mem_op((expr1), !=, (expr2), len)
  31. /* As test_mem_op, but decodes 'hex' before comparing. There must be a
  32. * local char* variable called mem_op_hex_tmp for this to work. */
  33. #define test_mem_op_hex(expr1, op, hex) \
  34. STMT_BEGIN \
  35. size_t length = strlen(hex); \
  36. tor_free(mem_op_hex_tmp); \
  37. mem_op_hex_tmp = tor_malloc(length/2); \
  38. tor_assert((length&1)==0); \
  39. base16_decode(mem_op_hex_tmp, length/2, hex, length); \
  40. test_mem_op(expr1, op, mem_op_hex_tmp, length/2); \
  41. STMT_END
  42. #define test_memeq_hex(expr1, hex) test_mem_op_hex(expr1, ==, hex)
  43. #define tt_double_op(a,op,b) \
  44. tt_assert_test_type(a,b,#a" "#op" "#b,double,(val1_ op val2_),"%f", \
  45. TT_EXIT_TEST_FUNCTION)
  46. #ifdef _MSC_VER
  47. #define U64_PRINTF_TYPE uint64_t
  48. #define I64_PRINTF_TYPE int64_t
  49. #else
  50. #define U64_PRINTF_TYPE unsigned long long
  51. #define I64_PRINTF_TYPE long long
  52. #endif
  53. #define tt_size_op(a,op,b) \
  54. tt_assert_test_fmt_type(a,b,#a" "#op" "#b,size_t,(val1_ op val2_), \
  55. U64_PRINTF_TYPE, U64_FORMAT, \
  56. {print_ = (U64_PRINTF_TYPE) value_;}, {}, TT_EXIT_TEST_FUNCTION)
  57. #define tt_u64_op(a,op,b) \
  58. tt_assert_test_fmt_type(a,b,#a" "#op" "#b,uint64_t,(val1_ op val2_), \
  59. U64_PRINTF_TYPE, U64_FORMAT, \
  60. {print_ = (U64_PRINTF_TYPE) value_;}, {}, TT_EXIT_TEST_FUNCTION)
  61. #define tt_i64_op(a,op,b) \
  62. tt_assert_test_fmt_type(a,b,#a" "#op" "#b,int64_t,(val1_ op val2_), \
  63. I64_PRINTF_TYPE, I64_FORMAT, \
  64. {print_ = (I64_PRINTF_TYPE) value_;}, {}, TT_EXIT_TEST_FUNCTION)
  65. const char *get_fname(const char *name);
  66. crypto_pk_t *pk_generate(int idx);
  67. void legacy_test_helper(void *data);
  68. extern const struct testcase_setup_t legacy_setup;
  69. #define US2_CONCAT_2__(a, b) a ## __ ## b
  70. #define US_CONCAT_2__(a, b) a ## _ ## b
  71. #define US_CONCAT_3__(a, b, c) a ## _ ## b ## _ ## c
  72. #define US_CONCAT_2_(a, b) US_CONCAT_2__(a, b)
  73. #define US_CONCAT_3_(a, b, c) US_CONCAT_3__(a, b, c)
  74. /*
  75. * These macros are helpful for streamlining the authorship of several test
  76. * cases that use mocks.
  77. *
  78. * The pattern is as follows.
  79. * * Declare a top level namespace:
  80. * #define NS_MODULE foo
  81. *
  82. * * For each test case you want to write, create a new submodule in the
  83. * namespace. All mocks and other information should belong to a single
  84. * submodule to avoid interference with other test cases.
  85. * You can simply name the submodule after the function in the module you
  86. * are testing:
  87. * #define NS_SUBMODULE some_function
  88. * or, if you're wanting to write several tests against the same function,
  89. * ie., you are testing an aspect of that function, you can use:
  90. * #define NS_SUBMODULE ASPECT(some_function, behavior)
  91. *
  92. * * Declare all the mocks you will use. The NS_DECL macro serves to declare
  93. * the mock in the current namespace (defined by NS_MODULE and NS_SUBMODULE).
  94. * It behaves like MOCK_DECL:
  95. * NS_DECL(int, dependent_function, (void *));
  96. * Here, dependent_function must be declared and implemented with the
  97. * MOCK_DECL and MOCK_IMPL macros. The NS_DECL macro also defines an integer
  98. * global for use for tracking how many times a mock was called, and can be
  99. * accessed by CALLED(mock_name). For example, you might put
  100. * CALLED(dependent_function)++;
  101. * in your mock body.
  102. *
  103. * * Define a function called NS(main) that will contain the body of the
  104. * test case. The NS macro can be used to reference a name in the current
  105. * namespace.
  106. *
  107. * * In NS(main), indicate that a mock function in the current namespace,
  108. * declared with NS_DECL is to override that in the global namespace,
  109. * with the NS_MOCK macro:
  110. * NS_MOCK(dependent_function)
  111. * Unmock with:
  112. * NS_UNMOCK(dependent_function)
  113. *
  114. * * Define the mocks with the NS macro, eg.,
  115. * int
  116. * NS(dependent_function)(void *)
  117. * {
  118. * CALLED(dependent_function)++;
  119. * }
  120. *
  121. * * In the struct testcase_t array, you can use the TEST_CASE and
  122. * TEST_CASE_ASPECT macros to define the cases without having to do so
  123. * explicitly nor without having to reset NS_SUBMODULE, eg.,
  124. * struct testcase_t foo_tests[] = {
  125. * TEST_CASE_ASPECT(some_function, behavior),
  126. * ...
  127. * END_OF_TESTCASES
  128. * which will define a test case named "some_function__behavior".
  129. */
  130. #define NAME_TEST_(name) #name
  131. #define NAME_TEST(name) NAME_TEST_(name)
  132. #define ASPECT(test_module, test_name) US2_CONCAT_2__(test_module, test_name)
  133. #define TEST_CASE(function) \
  134. { \
  135. NAME_TEST(function), \
  136. NS_FULL(NS_MODULE, function, test_main), \
  137. TT_FORK, \
  138. NULL, \
  139. NULL, \
  140. }
  141. #define TEST_CASE_ASPECT(function, aspect) \
  142. { \
  143. NAME_TEST(ASPECT(function, aspect)), \
  144. NS_FULL(NS_MODULE, ASPECT(function, aspect), test_main), \
  145. TT_FORK, \
  146. NULL, \
  147. NULL, \
  148. }
  149. #define NS(name) US_CONCAT_3_(NS_MODULE, NS_SUBMODULE, name)
  150. #define NS_FULL(module, submodule, name) US_CONCAT_3_(module, submodule, name)
  151. #define CALLED(mock_name) US_CONCAT_2_(NS(mock_name), called)
  152. #define NS_DECL(retval, mock_fn, args) \
  153. static retval NS(mock_fn) args; int CALLED(mock_fn) = 0
  154. #define NS_MOCK(name) MOCK(name, NS(name))
  155. #define NS_UNMOCK(name) UNMOCK(name)
  156. #endif