bh_queue_test.cc 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278
  1. /*
  2. * Copyright (C) 2019 Intel Corporation. All rights reserved.
  3. * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
  4. */
  5. #include "test_helper.h"
  6. #include "gtest/gtest.h"
  7. #include "bh_platform.h"
  8. class bh_queue_test_suite : public testing::Test
  9. {
  10. protected:
  11. // You should make the members protected s.t. they can be
  12. // accessed from sub-classes.
  13. // virtual void SetUp() will be called before each test is run. You
  14. // should define it if you need to initialize the variables.
  15. // Otherwise, this can be skipped.
  16. virtual void SetUp() {}
  17. // virtual void TearDown() will be called after each test is run.
  18. // You should define it if there is cleanup work to do. Otherwise,
  19. // you don't have to provide it.
  20. //
  21. virtual void TearDown() {}
  22. public:
  23. WAMRRuntimeRAII<512 * 1024> runtime;
  24. };
  25. typedef struct bh_queue_node {
  26. struct bh_queue_node *next;
  27. struct bh_queue_node *prev;
  28. unsigned short tag;
  29. unsigned int len;
  30. void *body;
  31. bh_msg_cleaner msg_cleaner;
  32. } bh_queue_node;
  33. struct bh_queue {
  34. bh_queue_mutex queue_lock;
  35. bh_queue_cond queue_wait_cond;
  36. unsigned int cnt;
  37. unsigned int max;
  38. unsigned int drops;
  39. bh_queue_node *head;
  40. bh_queue_node *tail;
  41. bool exit_loop_run;
  42. };
  43. typedef enum LINK_MSG_TYPE {
  44. COAP_TCP_RAW = 0,
  45. COAP_UDP_RAW = 1,
  46. REQUEST_PACKET,
  47. RESPONSE_PACKET,
  48. INSTALL_WASM_APP,
  49. CBOR_GENERIC = 30,
  50. LINK_MSG_TYPE_MAX = 50
  51. } LINK_MSG_TYPE;
  52. typedef enum QUEUE_MSG_TYPE {
  53. COAP_PARSED = LINK_MSG_TYPE_MAX + 1,
  54. RESTFUL_REQUEST,
  55. RESTFUL_RESPONSE,
  56. TIMER_EVENT = 5,
  57. SENSOR_EVENT = 6,
  58. GPIO_INTERRUPT_EVENT = 7,
  59. BLE_EVENT = 8,
  60. JDWP_REQUEST = 9,
  61. WD_TIMEOUT = 10,
  62. BASE_EVENT_MAX = 100
  63. } QUEUE_MSG_TYPE;
  64. enum {
  65. WASM_Msg_Start = BASE_EVENT_MAX,
  66. TIMER_EVENT_WASM,
  67. SENSOR_EVENT_WASM,
  68. CONNECTION_EVENT_WASM,
  69. WIDGET_EVENT_WASM,
  70. WASM_Msg_End = WASM_Msg_Start + 100
  71. };
  72. // If RES_CMP == 1, the function bh_queue_enter_loop_run run error.
  73. int RES_CMP = 0;
  74. TEST_F(bh_queue_test_suite, bh_queue_create)
  75. {
  76. EXPECT_NE(nullptr, bh_queue_create());
  77. }
  78. TEST_F(bh_queue_test_suite, bh_queue_destroy)
  79. {
  80. bh_message_t msg_ptr;
  81. bh_queue *queue_ptr = bh_queue_create();
  82. // Normally.
  83. msg_ptr = bh_new_msg(RESTFUL_REQUEST, nullptr, 0, nullptr);
  84. bh_post_msg2(queue_ptr, msg_ptr);
  85. bh_queue_destroy(queue_ptr);
  86. EXPECT_EQ(nullptr, queue_ptr->head);
  87. // Illegal parameters.
  88. bh_queue_destroy(nullptr);
  89. }
  90. TEST_F(bh_queue_test_suite, bh_message_payload)
  91. {
  92. bh_message_t msg_ptr;
  93. msg_ptr = bh_new_msg(RESTFUL_REQUEST, (void *)"test_msg_body",
  94. sizeof("test_msg_body"), nullptr);
  95. EXPECT_EQ("test_msg_body", bh_message_payload(msg_ptr));
  96. }
  97. TEST_F(bh_queue_test_suite, bh_message_payload_len)
  98. {
  99. bh_message_t msg_ptr;
  100. msg_ptr = bh_new_msg(RESTFUL_REQUEST, (void *)"test_msg_body",
  101. sizeof("test_msg_body"), nullptr);
  102. EXPECT_EQ(sizeof("test_msg_body"), bh_message_payload_len(msg_ptr));
  103. }
  104. TEST_F(bh_queue_test_suite, bh_message_type)
  105. {
  106. bh_message_t msg_ptr;
  107. msg_ptr = bh_new_msg(RESTFUL_REQUEST, (void *)"test_msg_body",
  108. sizeof("test_msg_body"), nullptr);
  109. EXPECT_EQ(RESTFUL_REQUEST, bh_message_type(msg_ptr));
  110. }
  111. TEST_F(bh_queue_test_suite, bh_new_msg)
  112. {
  113. EXPECT_NE(nullptr, bh_new_msg(RESTFUL_REQUEST, (void *)"test_msg_body",
  114. sizeof("test_msg_body"), nullptr));
  115. }
  116. void
  117. msg_cleaner_test(void *)
  118. {
  119. return;
  120. }
  121. TEST_F(bh_queue_test_suite, bh_free_msg)
  122. {
  123. bh_message_t msg_ptr;
  124. msg_ptr = bh_new_msg(RESTFUL_REQUEST, (void *)"test_msg_body",
  125. sizeof("test_msg_body"), (void *)msg_cleaner_test);
  126. bh_free_msg(msg_ptr);
  127. msg_ptr = bh_new_msg(RESTFUL_REQUEST, (void *)"test_msg_body",
  128. sizeof("test_msg_body"), nullptr);
  129. bh_free_msg(msg_ptr);
  130. msg_ptr = bh_new_msg(RESTFUL_REQUEST, (void *)(uintptr_t)100, 0, nullptr);
  131. bh_free_msg(msg_ptr);
  132. }
  133. TEST_F(bh_queue_test_suite, bh_post_msg)
  134. {
  135. int i = 0;
  136. bh_queue *queue_ptr = bh_queue_create();
  137. bh_message_t msg_ptr;
  138. EXPECT_EQ(true, bh_post_msg(queue_ptr, TIMER_EVENT_WASM, nullptr, 0));
  139. EXPECT_EQ(1, queue_ptr->cnt);
  140. // queue_ptr->cnt >= queue_ptr->max.
  141. msg_ptr = bh_new_msg(RESTFUL_REQUEST, (void *)"test_msg_body",
  142. sizeof("test_msg_body"), nullptr);
  143. for (i = 1; i <= 50; i++) {
  144. bh_post_msg2(queue_ptr, msg_ptr);
  145. }
  146. EXPECT_EQ(false, bh_post_msg(queue_ptr, TIMER_EVENT_WASM, nullptr, 0));
  147. }
  148. TEST_F(bh_queue_test_suite, bh_post_msg2)
  149. {
  150. bh_message_t msg_ptr;
  151. bh_queue *queue_ptr = bh_queue_create();
  152. msg_ptr = bh_new_msg(RESTFUL_REQUEST, nullptr, 0, nullptr);
  153. EXPECT_EQ(true, bh_post_msg2(queue_ptr, msg_ptr));
  154. EXPECT_EQ(1, queue_ptr->cnt);
  155. }
  156. TEST_F(bh_queue_test_suite, bh_get_msg)
  157. {
  158. bh_message_t msg_ptr;
  159. bh_queue *queue_ptr = bh_queue_create();
  160. msg_ptr = bh_new_msg(RESTFUL_REQUEST, (void *)"test_msg_body",
  161. sizeof("test_msg_body"), nullptr);
  162. // queue->cnt == 0, timeout_us == 0.
  163. EXPECT_EQ(nullptr, bh_get_msg(queue_ptr, 0));
  164. // queue->cnt == 0, timeout_us != 0.
  165. bh_get_msg(queue_ptr, 1);
  166. bh_post_msg2(queue_ptr, msg_ptr);
  167. EXPECT_EQ(1, queue_ptr->cnt);
  168. bh_get_msg(queue_ptr, -1);
  169. EXPECT_EQ(0, queue_ptr->cnt);
  170. }
  171. TEST_F(bh_queue_test_suite, bh_queue_get_message_count)
  172. {
  173. int i = 0, j = 0;
  174. bh_message_t msg_ptr;
  175. bh_queue *queue_ptr = bh_queue_create();
  176. // Normally.
  177. msg_ptr = bh_new_msg(RESTFUL_REQUEST, (void *)"test_msg_body",
  178. sizeof("test_msg_body"), nullptr);
  179. for (i = 1; i <= 20; i++) {
  180. bh_post_msg2(queue_ptr, msg_ptr);
  181. }
  182. i = i - 1;
  183. // The count of msg is less than queue_ptr->max.
  184. EXPECT_EQ(i, bh_queue_get_message_count(queue_ptr));
  185. // The count of msg is more than queue_ptr->max.
  186. for (j = 1; j <= 60; j++) {
  187. bh_post_msg2(queue_ptr, msg_ptr);
  188. }
  189. j = j - 1;
  190. EXPECT_EQ(queue_ptr->max, bh_queue_get_message_count(queue_ptr));
  191. EXPECT_EQ(j + i - queue_ptr->max, queue_ptr->drops);
  192. // Illegal parameters.
  193. EXPECT_EQ(0, bh_queue_get_message_count(nullptr));
  194. }
  195. void
  196. bh_queue_enter_loop_run_test_fun(void *message, void *arg)
  197. {
  198. static int count = 0;
  199. RES_CMP =
  200. strncmp("test_queue_loop", (char *)((bh_message_t)message)->body, 15);
  201. count++;
  202. if (2 == count) {
  203. bh_queue_exit_loop_run((bh_queue *)arg);
  204. }
  205. }
  206. TEST_F(bh_queue_test_suite, bh_queue_enter_loop_run)
  207. {
  208. bh_queue *queue_ptr = bh_queue_create();
  209. bh_message_t msg_ptr1 =
  210. bh_new_msg(RESTFUL_REQUEST, (void *)"test_queue_loop",
  211. sizeof("test_queue_loop"), nullptr);
  212. bh_message_t msg_ptr2 =
  213. bh_new_msg(RESTFUL_REQUEST, (void *)"test_queue_loop",
  214. sizeof("test_queue_loop"), nullptr);
  215. bh_post_msg2(queue_ptr, msg_ptr1);
  216. bh_post_msg2(queue_ptr, msg_ptr2);
  217. bh_queue_enter_loop_run(queue_ptr, bh_queue_enter_loop_run_test_fun,
  218. queue_ptr);
  219. EXPECT_EQ(0, RES_CMP);
  220. // Illegal parameters.
  221. bh_queue_enter_loop_run(nullptr, bh_queue_enter_loop_run_test_fun,
  222. queue_ptr);
  223. }
  224. TEST_F(bh_queue_test_suite, bh_queue_exit_loop_run)
  225. {
  226. // Illegal parameters.
  227. bh_queue_exit_loop_run(nullptr);
  228. }