Merge branch 'mueller/data-wrapper' into mueller/dhb-handle-device-tm

This commit is contained in:
Robin Müller 2022-08-30 14:03:45 +02:00
commit 093052604a
4 changed files with 39 additions and 6 deletions

View File

@ -10,6 +10,7 @@
namespace util { namespace util {
struct RawData { struct RawData {
RawData() = default;
const uint8_t* data = nullptr; const uint8_t* data = nullptr;
size_t len = 0; size_t len = 0;
}; };
@ -17,8 +18,8 @@ struct RawData {
enum DataTypes { NONE, RAW, SERIALIZABLE }; enum DataTypes { NONE, RAW, SERIALIZABLE };
union DataUnion { union DataUnion {
RawData raw; RawData raw{};
SerializeIF* serializable = nullptr; SerializeIF* serializable;
}; };
struct DataWrapper { struct DataWrapper {
@ -36,9 +37,8 @@ struct DataWrapper {
} }
[[nodiscard]] bool isNull() const { [[nodiscard]] bool isNull() const {
if (type == DataTypes::RAW and dataUnion.raw.data == nullptr or if ((type == DataTypes::NONE) or (type == DataTypes::RAW and dataUnion.raw.data == nullptr) or
(type == DataTypes::SERIALIZABLE and dataUnion.serializable == nullptr) or (type == DataTypes::SERIALIZABLE and dataUnion.serializable == nullptr)) {
(type == DataTypes::NONE)) {
return true; return true;
} }
return false; return false;

View File

@ -1,3 +1,4 @@
target_sources(${FSFW_TEST_TGT} PRIVATE target_sources(${FSFW_TEST_TGT} PRIVATE
testUnsignedByteField.cpp testUnsignedByteField.cpp
testDataWrapper.cpp
) )

View File

@ -0,0 +1,32 @@
#include <array>
#include <catch2/catch_test_macros.hpp>
#include "fsfw/util/dataWrapper.h"
#include "mocks/SimpleSerializable.h"
TEST_CASE("Data Wrapper", "[util]") {
util::DataWrapper wrapper;
SECTION("State") {
REQUIRE(wrapper.isNull());
REQUIRE(wrapper.type == util::DataTypes::NONE);
}
SECTION("Set Raw Data") {
REQUIRE(wrapper.isNull());
std::array<uint8_t, 4> data = {1, 2, 3, 4};
wrapper.setRawData({data.data(), data.size()});
REQUIRE(not wrapper.isNull());
REQUIRE(wrapper.type == util::DataTypes::RAW);
REQUIRE(wrapper.dataUnion.raw.data == data.data());
REQUIRE(wrapper.dataUnion.raw.len == data.size());
}
SECTION("Simple Serializable") {
REQUIRE(wrapper.isNull());
SimpleSerializable serializable;
wrapper.setSerializable(serializable);
REQUIRE(not wrapper.isNull());
REQUIRE(wrapper.type == util::DataTypes::SERIALIZABLE);
REQUIRE(wrapper.dataUnion.serializable == &serializable);
}
}

View File

@ -4,7 +4,7 @@
#include "fsfw/util/UnsignedByteField.h" #include "fsfw/util/UnsignedByteField.h"
TEST_CASE("Unsigned Byte Field", "[unsigned-byte-field]") { TEST_CASE("Unsigned Byte Field", "[util]") {
auto testByteField = UnsignedByteField<uint32_t>(10); auto testByteField = UnsignedByteField<uint32_t>(10);
auto u32ByteField = U32ByteField(10); auto u32ByteField = U32ByteField(10);
auto u16ByteField = U16ByteField(5); auto u16ByteField = U16ByteField(5);