Tactility/Tests/TactilityCore/MessageQueueTest.cpp
Ken Van Hoeylandt 50bd6e8bf6
Merge develop into main branch (#137)
* SdCard HAL refactored (#135)

- Refactor SdCard HAL
- introduce Lockable

* Screenshot and FatFS improvements (#136)

- Fix screenshots on ESP32
- Improve Screenshot service
- Convert Screenshot app to class-based instead of structs
- Screenshot app now automatically updates when task is finished
- Enable FatFS long filename support

* Re-use common log messages (#138)

For consistency and binary size reduction

* Toolbar spinner should get margin to the right

* More TactilityC features (#139)

* Rewrote Loader

- Simplified Loader by removing custom threa
- Created DispatcherThread
- Move auto-starting apps to Boot app
- Fixed Dispatcher bug where it could get stuck not processing new
messages

* Hide AP settings if the AP is not saved

* Missing from previous commit

* Replace LV_EVENT_CLICKED with LV_EVENT_SHORT_CLICKED

* Refactored files app and created InputDialog (#140)

- Changed Files app so that it has a View and State
- Files app now allows for long-pressing on files to perform actions
- Files app now has rename and delete actions
- Created InputDialog app
- Improved AlertDialog app layout
2024-12-27 23:12:39 +01:00

87 lines
2.2 KiB
C++

#include "doctest.h"
#include "MessageQueue.h"
using namespace tt;
TEST_CASE("message queue capacity should be correct") {
MessageQueue queue(10, 1);
uint32_t capacity = queue.getCapacity();
CHECK_EQ(capacity, 10);
}
TEST_CASE("message queue initial count should be 0") {
MessageQueue queue(10, 1);
uint32_t count = queue.getCount();
CHECK_EQ(count, 0);
}
TEST_CASE("message queue message size should be correct") {
MessageQueue queue(1, 123);
uint32_t message_size = queue.getMessageSize();
CHECK_EQ(message_size, 123);
}
TEST_CASE("message queue count should increase when message is added") {
MessageQueue queue(10, sizeof(uint32_t));
uint32_t message = 123;
queue.put(&message, 100);
uint32_t count = queue.getCount();
CHECK_EQ(count, 1);
}
TEST_CASE("message queue count should be 0 when message is added and queue is reset") {
MessageQueue queue(10, sizeof(uint32_t));
uint32_t message = 123;
queue.put(&message, 100);
queue.reset();
uint32_t count = queue.getCount();
CHECK_EQ(count, 0);
}
TEST_CASE("message queue consumption should work") {
MessageQueue queue(10, sizeof(uint32_t));
uint32_t out_message = 123;
queue.put(&out_message, 100);
uint32_t in_message = 0;
queue.get(&in_message, 100);
CHECK_EQ(in_message, 123);
}
TEST_CASE("message queue count should decrease when message is consumed") {
MessageQueue queue(10, sizeof(uint32_t));
uint32_t out_message = 123;
queue.put(&out_message, 100);
uint32_t in_message = 0;
queue.get(&in_message, 100);
uint32_t count = queue.getCount();
CHECK_EQ(count, 0);
}
TEST_CASE("message queue should make copy of data") {
// Given a number that we can later delete
MessageQueue queue(1, sizeof(int32_t));
const int32_t test_value = 123;
auto* number = new int32_t();
*number = test_value;
// When we put the number in the queue and then delete it
queue.put(number, 100);
delete number;
// We want to verify that the value was copied into the queue and retrieved properly
int32_t queue_number = 0;
CHECK_EQ(queue.get(&queue_number, 100), true);
CHECK_EQ(queue_number, test_value);
}