From 465c1379ceec8db1fc8990a3fe3bda2f2786d339 Mon Sep 17 00:00:00 2001 From: Claudius 'keldu' Holeksa Date: Fri, 2 Aug 2024 15:42:33 +0200 Subject: wip --- modules/codec/c++/simple.hpp | 10 ++++--- modules/codec/tests/transport.cpp | 57 +++++++++++++++++++++++++++++++++++++++ 2 files changed, 63 insertions(+), 4 deletions(-) create mode 100644 modules/codec/tests/transport.cpp (limited to 'modules') diff --git a/modules/codec/c++/simple.hpp b/modules/codec/c++/simple.hpp index 1afdc33..b0cdfd9 100644 --- a/modules/codec/c++/simple.hpp +++ b/modules/codec/c++/simple.hpp @@ -14,16 +14,18 @@ struct KelSimple {}; template class data { private: - ring_buffer buffer_; + own buffer_; public: - data() = default; + data(): + buffer_{heap()} + {} - data(ring_buffer buffer__): + data(own buffer__): buffer_{std::move(buffer__)} {} buffer& get_buffer(){ - return buffer_; + return *buffer_; } }; diff --git a/modules/codec/tests/transport.cpp b/modules/codec/tests/transport.cpp new file mode 100644 index 0000000..cffee24 --- /dev/null +++ b/modules/codec/tests/transport.cpp @@ -0,0 +1,57 @@ +#include +#include "../c++/data.hpp" +#include "../c++/simple.hpp" + +#include + +namespace { +namespace schema { +using namespace saw::schema; + +using ZeroDimArray = Array; +using OneDimArray = Array; +using TwoDimArray = Array; +using ThreeDimArray = Array; + +using TestStruct = Struct< + Member, + Member +>; + +} + +SAW_TEST("KelSimple Struct write and read back"){ + using namespace saw; + + ring_buffer buffer{2048u}; + + data native; + + data simple; + + auto& tda = native.template get<"two_dim_array">(); + tda = {1,2}; + + tda.at(0,0).set(5); + tda.at(0,1).set(3); + native.template get<"number">().set(410); + + codec codec; + + auto eov = codec.encode(native, simple); + SAW_EXPECT(eov.is_value(), "Encoding error"); + + // Reset values + native = {}; + + eov = codec.decode(simple, native); + SAW_EXPECT(eov.is_value(), "Decoding error"); + + auto& dec_tda = native.template get<"two_dim_array">(); + + SAW_EXPECT(dec_tda.at(0,0).get() == 5, "Incorrect Decoding in array 0,0"); + SAW_EXPECT(dec_tda.at(0,1).get() == 3, "Incorrect Decoding in array 0,1"); + SAW_EXPECT(native.template get<"number">().get() == 410, "Incorrect Decoding in number"); +} + +} -- cgit v1.2.3