#include #include "boost/archive/binary_iarchive.hpp" #include "boost/archive/binary_oarchive.hpp" #include "boost/archive/text_iarchive.hpp" #include "boost/archive/text_oarchive.hpp" #include "boost/serialization/access.hpp" #include "boost/serialization/base_object.hpp" #include "boost/serialization/export.hpp" #include "gmock/gmock.h" #include "gtest/gtest.h" #include "communication/messaging/distributed.hpp" #include "communication/rpc/rpc.hpp" #include "gtest/gtest.h" using communication::messaging::Message; using communication::messaging::System; using namespace communication::rpc; using namespace std::literals::chrono_literals; struct SumReq : public Message { SumReq(int x, int y) : x(x), y(y) {} int x; int y; private: friend class boost::serialization::access; SumReq() {} // Needed for serialization. template void serialize(TArchive &ar, unsigned int) { ar &boost::serialization::base_object(*this); ar &x; ar &y; } }; BOOST_CLASS_EXPORT(SumReq); struct SumRes : public Message { SumRes(int sum) : sum(sum) {} int sum; private: friend class boost::serialization::access; SumRes() {} // Needed for serialization. template void serialize(TArchive &ar, unsigned int) { ar &boost::serialization::base_object(*this); ar ∑ } }; BOOST_CLASS_EXPORT(SumRes); using Sum = RequestResponse; TEST(Rpc, Call) { System server_system("127.0.0.1", 0); Server server(server_system, "main"); server.Register([](const SumReq &request) { return std::make_unique(request.x + request.y); }); server.Start(); std::this_thread::sleep_for(100ms); System client_system("127.0.0.1", 0); Client client(client_system, "127.0.0.1", server_system.endpoint().port(), "main"); auto sum = client.Call(300ms, 10, 20); EXPECT_EQ(sum->sum, 30); server.Shutdown(); server_system.Shutdown(); client_system.Shutdown(); } TEST(Rpc, Timeout) { System server_system("127.0.0.1", 0); Server server(server_system, "main"); server.Register([](const SumReq &request) { std::this_thread::sleep_for(300ms); return std::make_unique(request.x + request.y); }); server.Start(); std::this_thread::sleep_for(100ms); System client_system("127.0.0.1", 0); Client client(client_system, "127.0.0.1", server_system.endpoint().port(), "main"); auto sum = client.Call(100ms, 10, 20); EXPECT_FALSE(sum); server.Shutdown(); server_system.Shutdown(); client_system.Shutdown(); }