summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
Diffstat (limited to 'tests')
-rw-r--r--tests/codec.cpp108
1 files changed, 108 insertions, 0 deletions
diff --git a/tests/codec.cpp b/tests/codec.cpp
index 7253ecc..439332a 100644
--- a/tests/codec.cpp
+++ b/tests/codec.cpp
@@ -1,6 +1,7 @@
#include <forstio/test/suite.h>
#include <forstio/codec/data.h>
#include <forstio/codec/simple.h>
+#include <forstio/codec/rpc.h>
#include <iostream>
@@ -27,6 +28,19 @@ using TestTuple = Tuple<
TwoDimArray,
UInt64
>;
+
+using TestInt32Pair = Tuple<
+ Int32,
+ Int32
+>;
+
+using TestCalcFunction = Function<TestInt32Pair, Int32>;
+
+using TestInterface = Interface<
+ Member<TestCalcFunction, "add">,
+ Member<TestCalcFunction, "sub">,
+ Member<TestCalcFunction, "multiply">
+>;
}
SAW_TEST("One Dimensional Array") {
using namespace saw;
@@ -256,6 +270,7 @@ SAW_TEST("KelSimple Tuple write and read back"){
SAW_EXPECT(dec_tda.at(0,1).get() == 3, "Incorrect Decoding in array 0,1");
SAW_EXPECT(native.template get<1>().get() == 410, "Incorrect Decoding in number");
}
+
SAW_TEST("KelSimple String write and read back"){
using namespace saw;
@@ -279,4 +294,97 @@ SAW_TEST("KelSimple String write and read back"){
SAW_EXPECT(native == str, "String should've been decoded back correctly");
}
+
+SAW_TEST("Function basics"){
+ using namespace saw;
+
+ {
+ data<schema::TestInt32Pair, encode::Native> native;
+
+ native.get<0>().set(5);
+ native.get<1>().set(40);
+
+ auto func_add = function_factory<schema::TestCalcFunction, encode::Native>::create(
+ [](data<schema::TestInt32Pair, encode::Native> req){
+ data<schema::Int32, encode::Native> resp;
+
+ resp.set(req.get<0>().get() + req.get<1>().get());
+
+ return resp;
+ }
+ );
+
+ auto eov = func_add.call(std::move(native));
+ SAW_EXPECT(eov.is_value(), "Returned value is an error");
+
+ auto& val = eov.get_value();
+ SAW_EXPECT(val.get() == 45, "Sum is incorrect");
+ }
+}
+
+SAW_TEST("Interface basics"){
+ using namespace saw;
+
+ data<schema::TestInt32Pair, encode::Native> native;
+
+ auto func_add =
+ [](data<schema::TestInt32Pair, encode::Native> req){
+ data<schema::Int32, encode::Native> resp;
+
+ resp.set(req.get<0>().get() + req.get<1>().get());
+
+ return resp;
+ };
+ auto func_sub =
+ [](data<schema::TestInt32Pair, encode::Native> req){
+ data<schema::Int32, encode::Native> resp;
+
+ resp.set(req.get<0>().get() - req.get<1>().get());
+
+ return resp;
+ };
+ auto func_multiply = [](data<schema::TestInt32Pair, encode::Native> req){
+ data<schema::Int32, encode::Native> resp;
+
+ resp.set(req.get<0>().get() * req.get<1>().get());
+
+ return resp;
+ };
+
+ auto iface = interface_factory<schema::TestInterface, encode::Native>::create(std::move(func_add), std::move(func_sub), std::move(func_multiply));
+
+ {
+ data<schema::TestInt32Pair, encode::Native> native;
+
+ native.get<0>().set(5);
+ native.get<1>().set(40);
+ auto eov = iface.template call<"add">(std::move(native));
+ SAW_EXPECT(eov.is_value(), "Returned value is an error");
+
+ auto& val = eov.get_value();
+ SAW_EXPECT(val.get() == 45, "Sum is incorrect");
+ }
+ {
+ data<schema::TestInt32Pair, encode::Native> native;
+
+ native.get<0>().set(5);
+ native.get<1>().set(40);
+ auto eov = iface.template call<"sub">(std::move(native));
+ SAW_EXPECT(eov.is_value(), "Returned value is an error");
+
+ auto& val = eov.get_value();
+ SAW_EXPECT(val.get() == -35, "Sum is incorrect");
+ }
+ {
+ data<schema::TestInt32Pair, encode::Native> native;
+
+ native.get<0>().set(5);
+ native.get<1>().set(40);
+ auto eov = iface.template call<"multiply">(std::move(native));
+ SAW_EXPECT(eov.is_value(), "Returned value is an error");
+
+ auto& val = eov.get_value();
+ SAW_EXPECT(val.get() == 200, "Sum is incorrect");
+ }
+}
}