// Copyright 2022 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. #pragma once #include #include #include #include #include #include #include #include "communication/server.hpp" inline constexpr const int SIZE = 60000; inline constexpr const int REPLY = 10; using memgraph::io::network::Endpoint; using memgraph::io::network::Socket; class TestData {}; class TestSession { public: TestSession(TestData *, const memgraph::io::network::Endpoint &, memgraph::communication::InputStream *input_stream, memgraph::communication::OutputStream *output_stream) : input_stream_(input_stream), output_stream_(output_stream) {} void Execute() { if (input_stream_->size() < 2) return; const uint8_t *data = input_stream_->data(); size_t size = data[0]; size <<= 8; size += data[1]; input_stream_->Resize(size + 2); if (input_stream_->size() < size + 2) return; for (int i = 0; i < REPLY; ++i) ASSERT_TRUE(output_stream_->Write(data + 2, size)); input_stream_->Shift(size + 2); } memgraph::communication::InputStream *input_stream_; memgraph::communication::OutputStream *output_stream_; }; using ContextT = memgraph::communication::ServerContext; using ServerT = memgraph::communication::Server; void client_run(int num, const char *interface, uint16_t port, const unsigned char *data, int lo, int hi) { std::stringstream name; name << "Client " << num; unsigned char buffer[SIZE * REPLY], head[2]; int have, read; Endpoint endpoint(interface, port); Socket socket; ASSERT_TRUE(socket.Connect(endpoint)); socket.SetTimeout(2, 0); SPDLOG_INFO("Socket create: {}", socket.fd()); for (int len = lo; len <= hi; len += 100) { have = 0; head[0] = (len >> 8) & 0xff; head[1] = len & 0xff; ASSERT_TRUE(socket.Write(head, 2)); ASSERT_TRUE(socket.Write(data, len)); SPDLOG_INFO("Socket write: {}", socket.fd()); while (have < len * REPLY) { read = socket.Read(buffer + have, SIZE); SPDLOG_INFO("Socket read: {}", socket.fd()); if (read == -1) break; have += read; } for (int i = 0; i < REPLY; ++i) for (int j = 0; j < len; ++j) ASSERT_EQ(buffer[i * len + j], data[j]); } SPDLOG_INFO("Socket done: {}", socket.fd()); socket.Close(); } void initialize_data(unsigned char *data, int size) { std::random_device rd; std::mt19937 gen(rd()); std::uniform_int_distribution<> dis(0, 255); for (int i = 0; i < size; ++i) { data[i] = dis(gen); } }