From a78e7fcfe3b393133c5f94609096528f3204e260 Mon Sep 17 00:00:00 2001 From: apolisskyi Date: Wed, 18 Oct 2023 20:10:59 +0300 Subject: [PATCH] Queue test: cover more branches to improve test coverage --- src/event_queue/event_queue.c | 2 - test/event_queue/event_queue.test.c | 77 +++++++++++++++++++++++++++++ 2 files changed, 77 insertions(+), 2 deletions(-) diff --git a/src/event_queue/event_queue.c b/src/event_queue/event_queue.c index 0f700cd..e84aa60 100755 --- a/src/event_queue/event_queue.c +++ b/src/event_queue/event_queue.c @@ -1,7 +1,5 @@ #include "./event_queue.h" -#include "event_queue.h" - void EventQueue_Initialize(TEventQueue* queue, TEvent* events, uint32_t capacity) { queue->events = events; queue->capacity = capacity; diff --git a/test/event_queue/event_queue.test.c b/test/event_queue/event_queue.test.c index 84b2d7b..5ff8e10 100755 --- a/test/event_queue/event_queue.test.c +++ b/test/event_queue/event_queue.test.c @@ -39,6 +39,23 @@ void test_EventQueue_Enqueue(void) { TEST_ASSERT_FALSE(EventQueue_IsEmpty(&queue)); } +void test_EventQueue_Enqueue_FullQueue(void) { + // Fill the queue to its capacity + for (int i = 0; i < QUEUE_MAX_CAPACITY; ++i) { + TEvent event = {i, NULL, 0}; + bool enqueueResult = EventQueue_Enqueue(&queue, event); + TEST_ASSERT_TRUE(enqueueResult); + } + + // Try to enqueue one more event + TEvent extraEvent = {TEST_SIG_1, NULL, 0}; + bool enqueueResult = EventQueue_Enqueue(&queue, extraEvent); + + // Check that enqueueResult is false, indicating that the queue is full + TEST_ASSERT_FALSE(enqueueResult); +} + + void test_EventQueue_Dequeue(void) { TEvent event = {TEST_SIG_1, NULL, 0}; EventQueue_Enqueue(&queue, event); @@ -49,6 +66,47 @@ void test_EventQueue_Dequeue(void) { TEST_ASSERT_TRUE(EventQueue_IsEmpty(&queue)); } +void test_EventQueue_Dequeue_EmptyQueue(void) { + // Ensure the queue is empty + TEST_ASSERT_TRUE(EventQueue_IsEmpty(&queue)); + + // Try to dequeue an event from an empty queue + TEvent dequeuedEvent = EventQueue_Dequeue(&queue); + + // Check that the dequeuedEvent is an empty event (all fields set to zero) + TEST_ASSERT_EQUAL_INT(0, dequeuedEvent.sig); + TEST_ASSERT_NULL(dequeuedEvent.payload); + TEST_ASSERT_EQUAL_INT(0, dequeuedEvent.size); +} + +void test_EventQueue_Dequeue_FrontEqualsRear(void) { + // Enqueue an event + TEvent event = {TEST_SIG_1, NULL, 0}; + EventQueue_Enqueue(&queue, event); + + // Dequeue the event, causing front and rear to become equal + TEvent dequeuedEvent = EventQueue_Dequeue(&queue); + + // Check that front and rear are set to -1 + TEST_ASSERT_EQUAL_INT(-1, queue.front); + TEST_ASSERT_EQUAL_INT(-1, queue.rear); +} + +void test_EventQueue_Dequeue_FrontNotEqualsRear(void) { + // Enqueue two events + TEvent event1 = {TEST_SIG_1, NULL, 0}; + TEvent event2 = {TEST_SIG_2, NULL, 0}; + EventQueue_Enqueue(&queue, event1); + EventQueue_Enqueue(&queue, event2); + + // Dequeue the first event, front and rear should not be equal + TEvent dequeuedEvent = EventQueue_Dequeue(&queue); + + // Check that front is incremented + TEST_ASSERT_EQUAL_INT(1, queue.front); + TEST_ASSERT_EQUAL_INT(-1, queue.rear); +} + void test_EventQueue_Peek(void) { TEvent event = {TEST_SIG_1, NULL, 0}; EventQueue_Enqueue(&queue, event); @@ -58,6 +116,20 @@ void test_EventQueue_Peek(void) { TEST_ASSERT_EQUAL_INT(TEST_SIG_1, peekedEvent.sig); } +void test_EventQueue_Peek_EmptyQueue(void) { + // Ensure the queue is empty + TEST_ASSERT_TRUE(EventQueue_IsEmpty(&queue)); + + // Try to peek into an empty queue + TEvent peekedEvent = EventQueue_Peek(&queue); + + // Check that the peekedEvent is an empty event (all fields set to zero) + TEST_ASSERT_EQUAL_INT(0, peekedEvent.sig); + TEST_ASSERT_NULL(peekedEvent.payload); + TEST_ASSERT_EQUAL_INT(0, peekedEvent.size); +} + + void test_EventQueue_IsEmpty(void) { TEST_ASSERT_TRUE(EventQueue_IsEmpty(&queue)); } @@ -76,8 +148,13 @@ int main(void) { UNITY_BEGIN(); RUN_TEST(test_EventQueue_Initialize); RUN_TEST(test_EventQueue_Enqueue); + RUN_TEST(test_EventQueue_Enqueue_FullQueue); RUN_TEST(test_EventQueue_Dequeue); + RUN_TEST(test_EventQueue_Dequeue_EmptyQueue); + RUN_TEST(test_EventQueue_Dequeue_FrontEqualsRear); + RUN_TEST(test_EventQueue_Dequeue_FrontNotEqualsRear); RUN_TEST(test_EventQueue_Peek); + RUN_TEST(test_EventQueue_Peek_EmptyQueue); RUN_TEST(test_EventQueue_IsEmpty); RUN_TEST(test_EventQueue_IsFull); return UNITY_END();