| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278 |
- /*
- * Copyright (C) 2019 Intel Corporation. All rights reserved.
- * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
- */
- #include "test_helper.h"
- #include "gtest/gtest.h"
- #include "bh_platform.h"
- class bh_queue_test_suite : public testing::Test
- {
- protected:
- // You should make the members protected s.t. they can be
- // accessed from sub-classes.
- // virtual void SetUp() will be called before each test is run. You
- // should define it if you need to initialize the variables.
- // Otherwise, this can be skipped.
- virtual void SetUp() {}
- // virtual void TearDown() will be called after each test is run.
- // You should define it if there is cleanup work to do. Otherwise,
- // you don't have to provide it.
- //
- virtual void TearDown() {}
- public:
- WAMRRuntimeRAII<512 * 1024> runtime;
- };
- typedef struct bh_queue_node {
- struct bh_queue_node *next;
- struct bh_queue_node *prev;
- unsigned short tag;
- unsigned int len;
- void *body;
- bh_msg_cleaner msg_cleaner;
- } bh_queue_node;
- struct bh_queue {
- bh_queue_mutex queue_lock;
- bh_queue_cond queue_wait_cond;
- unsigned int cnt;
- unsigned int max;
- unsigned int drops;
- bh_queue_node *head;
- bh_queue_node *tail;
- bool exit_loop_run;
- };
- typedef enum LINK_MSG_TYPE {
- COAP_TCP_RAW = 0,
- COAP_UDP_RAW = 1,
- REQUEST_PACKET,
- RESPONSE_PACKET,
- INSTALL_WASM_APP,
- CBOR_GENERIC = 30,
- LINK_MSG_TYPE_MAX = 50
- } LINK_MSG_TYPE;
- typedef enum QUEUE_MSG_TYPE {
- COAP_PARSED = LINK_MSG_TYPE_MAX + 1,
- RESTFUL_REQUEST,
- RESTFUL_RESPONSE,
- TIMER_EVENT = 5,
- SENSOR_EVENT = 6,
- GPIO_INTERRUPT_EVENT = 7,
- BLE_EVENT = 8,
- JDWP_REQUEST = 9,
- WD_TIMEOUT = 10,
- BASE_EVENT_MAX = 100
- } QUEUE_MSG_TYPE;
- enum {
- WASM_Msg_Start = BASE_EVENT_MAX,
- TIMER_EVENT_WASM,
- SENSOR_EVENT_WASM,
- CONNECTION_EVENT_WASM,
- WIDGET_EVENT_WASM,
- WASM_Msg_End = WASM_Msg_Start + 100
- };
- // If RES_CMP == 1, the function bh_queue_enter_loop_run run error.
- int RES_CMP = 0;
- TEST_F(bh_queue_test_suite, bh_queue_create)
- {
- EXPECT_NE(nullptr, bh_queue_create());
- }
- TEST_F(bh_queue_test_suite, bh_queue_destroy)
- {
- bh_message_t msg_ptr;
- bh_queue *queue_ptr = bh_queue_create();
- // Normally.
- msg_ptr = bh_new_msg(RESTFUL_REQUEST, nullptr, 0, nullptr);
- bh_post_msg2(queue_ptr, msg_ptr);
- bh_queue_destroy(queue_ptr);
- EXPECT_EQ(nullptr, queue_ptr->head);
- // Illegal parameters.
- bh_queue_destroy(nullptr);
- }
- TEST_F(bh_queue_test_suite, bh_message_payload)
- {
- bh_message_t msg_ptr;
- msg_ptr = bh_new_msg(RESTFUL_REQUEST, (void *)"test_msg_body",
- sizeof("test_msg_body"), nullptr);
- EXPECT_EQ("test_msg_body", bh_message_payload(msg_ptr));
- }
- TEST_F(bh_queue_test_suite, bh_message_payload_len)
- {
- bh_message_t msg_ptr;
- msg_ptr = bh_new_msg(RESTFUL_REQUEST, (void *)"test_msg_body",
- sizeof("test_msg_body"), nullptr);
- EXPECT_EQ(sizeof("test_msg_body"), bh_message_payload_len(msg_ptr));
- }
- TEST_F(bh_queue_test_suite, bh_message_type)
- {
- bh_message_t msg_ptr;
- msg_ptr = bh_new_msg(RESTFUL_REQUEST, (void *)"test_msg_body",
- sizeof("test_msg_body"), nullptr);
- EXPECT_EQ(RESTFUL_REQUEST, bh_message_type(msg_ptr));
- }
- TEST_F(bh_queue_test_suite, bh_new_msg)
- {
- EXPECT_NE(nullptr, bh_new_msg(RESTFUL_REQUEST, (void *)"test_msg_body",
- sizeof("test_msg_body"), nullptr));
- }
- void
- msg_cleaner_test(void *)
- {
- return;
- }
- TEST_F(bh_queue_test_suite, bh_free_msg)
- {
- bh_message_t msg_ptr;
- msg_ptr = bh_new_msg(RESTFUL_REQUEST, (void *)"test_msg_body",
- sizeof("test_msg_body"), (void *)msg_cleaner_test);
- bh_free_msg(msg_ptr);
- msg_ptr = bh_new_msg(RESTFUL_REQUEST, (void *)"test_msg_body",
- sizeof("test_msg_body"), nullptr);
- bh_free_msg(msg_ptr);
- msg_ptr = bh_new_msg(RESTFUL_REQUEST, (void *)(uintptr_t)100, 0, nullptr);
- bh_free_msg(msg_ptr);
- }
- TEST_F(bh_queue_test_suite, bh_post_msg)
- {
- int i = 0;
- bh_queue *queue_ptr = bh_queue_create();
- bh_message_t msg_ptr;
- EXPECT_EQ(true, bh_post_msg(queue_ptr, TIMER_EVENT_WASM, nullptr, 0));
- EXPECT_EQ(1, queue_ptr->cnt);
- // queue_ptr->cnt >= queue_ptr->max.
- msg_ptr = bh_new_msg(RESTFUL_REQUEST, (void *)"test_msg_body",
- sizeof("test_msg_body"), nullptr);
- for (i = 1; i <= 50; i++) {
- bh_post_msg2(queue_ptr, msg_ptr);
- }
- EXPECT_EQ(false, bh_post_msg(queue_ptr, TIMER_EVENT_WASM, nullptr, 0));
- }
- TEST_F(bh_queue_test_suite, bh_post_msg2)
- {
- bh_message_t msg_ptr;
- bh_queue *queue_ptr = bh_queue_create();
- msg_ptr = bh_new_msg(RESTFUL_REQUEST, nullptr, 0, nullptr);
- EXPECT_EQ(true, bh_post_msg2(queue_ptr, msg_ptr));
- EXPECT_EQ(1, queue_ptr->cnt);
- }
- TEST_F(bh_queue_test_suite, bh_get_msg)
- {
- bh_message_t msg_ptr;
- bh_queue *queue_ptr = bh_queue_create();
- msg_ptr = bh_new_msg(RESTFUL_REQUEST, (void *)"test_msg_body",
- sizeof("test_msg_body"), nullptr);
- // queue->cnt == 0, timeout_us == 0.
- EXPECT_EQ(nullptr, bh_get_msg(queue_ptr, 0));
- // queue->cnt == 0, timeout_us != 0.
- bh_get_msg(queue_ptr, 1);
- bh_post_msg2(queue_ptr, msg_ptr);
- EXPECT_EQ(1, queue_ptr->cnt);
- bh_get_msg(queue_ptr, -1);
- EXPECT_EQ(0, queue_ptr->cnt);
- }
- TEST_F(bh_queue_test_suite, bh_queue_get_message_count)
- {
- int i = 0, j = 0;
- bh_message_t msg_ptr;
- bh_queue *queue_ptr = bh_queue_create();
- // Normally.
- msg_ptr = bh_new_msg(RESTFUL_REQUEST, (void *)"test_msg_body",
- sizeof("test_msg_body"), nullptr);
- for (i = 1; i <= 20; i++) {
- bh_post_msg2(queue_ptr, msg_ptr);
- }
- i = i - 1;
- // The count of msg is less than queue_ptr->max.
- EXPECT_EQ(i, bh_queue_get_message_count(queue_ptr));
- // The count of msg is more than queue_ptr->max.
- for (j = 1; j <= 60; j++) {
- bh_post_msg2(queue_ptr, msg_ptr);
- }
- j = j - 1;
- EXPECT_EQ(queue_ptr->max, bh_queue_get_message_count(queue_ptr));
- EXPECT_EQ(j + i - queue_ptr->max, queue_ptr->drops);
- // Illegal parameters.
- EXPECT_EQ(0, bh_queue_get_message_count(nullptr));
- }
- void
- bh_queue_enter_loop_run_test_fun(void *message, void *arg)
- {
- static int count = 0;
- RES_CMP =
- strncmp("test_queue_loop", (char *)((bh_message_t)message)->body, 15);
- count++;
- if (2 == count) {
- bh_queue_exit_loop_run((bh_queue *)arg);
- }
- }
- TEST_F(bh_queue_test_suite, bh_queue_enter_loop_run)
- {
- bh_queue *queue_ptr = bh_queue_create();
- bh_message_t msg_ptr1 =
- bh_new_msg(RESTFUL_REQUEST, (void *)"test_queue_loop",
- sizeof("test_queue_loop"), nullptr);
- bh_message_t msg_ptr2 =
- bh_new_msg(RESTFUL_REQUEST, (void *)"test_queue_loop",
- sizeof("test_queue_loop"), nullptr);
- bh_post_msg2(queue_ptr, msg_ptr1);
- bh_post_msg2(queue_ptr, msg_ptr2);
- bh_queue_enter_loop_run(queue_ptr, bh_queue_enter_loop_run_test_fun,
- queue_ptr);
- EXPECT_EQ(0, RES_CMP);
- // Illegal parameters.
- bh_queue_enter_loop_run(nullptr, bh_queue_enter_loop_run_test_fun,
- queue_ptr);
- }
- TEST_F(bh_queue_test_suite, bh_queue_exit_loop_run)
- {
- // Illegal parameters.
- bh_queue_exit_loop_run(nullptr);
- }
|