// Copyright 2023 Memgraph Ltd. // // Use of this software is governed by the Business Source License // included in the file licenses/BSL.txt; by using this file, you agree to be bound by the terms of the Business Source // License, and you may not use this file except in compliance with the Business Source License. // // As of the Change Date specified in that file, in accordance with // the Business Source License, use of this software will be governed // by the Apache License, Version 2.0, included in the file // licenses/APL.txt. #include #include #include #include "io/local_transport/local_system.hpp" #include "io/local_transport/local_transport.hpp" #include "io/transport.hpp" namespace memgraph::io::tests { using memgraph::io::local_transport::LocalSystem; using memgraph::io::local_transport::LocalTransport; struct CounterRequest { uint64_t proposal; }; struct CounterResponse { uint64_t highest_seen; }; void RunServer(Io io) { uint64_t highest_seen = 0; while (!io.ShouldShutDown()) { spdlog::info("[SERVER] Is receiving..."); auto request_result = io.Receive(); if (request_result.HasError()) { spdlog::info("[SERVER] timed out, continue"); continue; } auto request_envelope = request_result.GetValue(); ASSERT_TRUE(std::holds_alternative(request_envelope.message)); auto req = std::get(request_envelope.message); highest_seen = std::max(highest_seen, req.proposal); auto srv_res = CounterResponse{highest_seen}; io.Send(request_envelope.from_address, request_envelope.request_id, std::move(srv_res)); } } TEST(LocalTransport, BasicRequest) { LocalSystem local_system; // rely on uuid to be unique on default Address auto cli_addr = Address::UniqueLocalAddress(); auto srv_addr = Address::UniqueLocalAddress(); Io cli_io = local_system.Register(cli_addr); Io srv_io = local_system.Register(srv_addr); auto srv_thread = std::jthread(RunServer, std::move(srv_io)); for (int i = 1; i < 3; ++i) { // send request CounterRequest cli_req; auto value = 1; // i; cli_req.proposal = value; spdlog::info("[CLIENT] sending request"); auto res_f = cli_io.Request(srv_addr, std::move(cli_req)); spdlog::info("[CLIENT] waiting on future"); auto res_rez = std::move(res_f).Wait(); spdlog::info("[CLIENT] future returned"); MG_ASSERT(!res_rez.HasError()); spdlog::info("[CLIENT] Got a valid response"); auto env = res_rez.GetValue(); MG_ASSERT(env.message.highest_seen == value); } local_system.ShutDown(); } } // namespace memgraph::io::tests