2017-03-09 18:42:16 +08:00
|
|
|
#pragma once
|
2017-03-06 20:37:51 +08:00
|
|
|
|
|
|
|
#include <array>
|
2017-10-17 20:05:08 +08:00
|
|
|
#include <chrono>
|
2017-03-06 20:37:51 +08:00
|
|
|
#include <cstring>
|
|
|
|
#include <iostream>
|
2017-08-03 21:26:48 +08:00
|
|
|
#include <random>
|
2017-03-06 20:37:51 +08:00
|
|
|
#include <vector>
|
|
|
|
|
2017-06-21 17:29:13 +08:00
|
|
|
#include <glog/logging.h>
|
|
|
|
#include <gtest/gtest.h>
|
2017-03-06 20:37:51 +08:00
|
|
|
|
|
|
|
#include "communication/server.hpp"
|
2017-10-17 20:05:08 +08:00
|
|
|
#include "database/graph_db_accessor.hpp"
|
2017-03-06 20:37:51 +08:00
|
|
|
|
|
|
|
static constexpr const int SIZE = 60000;
|
|
|
|
static constexpr const int REPLY = 10;
|
|
|
|
|
2018-01-15 21:03:07 +08:00
|
|
|
using io::network::Endpoint;
|
2017-10-17 20:05:08 +08:00
|
|
|
using io::network::Socket;
|
2017-03-06 20:37:51 +08:00
|
|
|
|
2017-08-03 21:26:48 +08:00
|
|
|
class TestData {};
|
|
|
|
|
2017-03-06 20:37:51 +08:00
|
|
|
class TestSession {
|
|
|
|
public:
|
2018-03-23 23:32:17 +08:00
|
|
|
TestSession(TestData &, communication::InputStream &input_stream,
|
|
|
|
communication::OutputStream &output_stream)
|
|
|
|
: input_stream_(input_stream), output_stream_(output_stream) {}
|
2017-03-06 20:37:51 +08:00
|
|
|
|
2017-04-15 21:14:12 +08:00
|
|
|
void Execute() {
|
2018-03-23 23:32:17 +08:00
|
|
|
if (input_stream_.size() < 2) return;
|
|
|
|
const uint8_t *data = input_stream_.data();
|
2017-04-15 21:14:12 +08:00
|
|
|
size_t size = data[0];
|
|
|
|
size <<= 8;
|
|
|
|
size += data[1];
|
2018-03-23 23:32:17 +08:00
|
|
|
input_stream_.Resize(size + 2);
|
|
|
|
if (input_stream_.size() < size + 2) return;
|
2017-03-06 20:37:51 +08:00
|
|
|
|
|
|
|
for (int i = 0; i < REPLY; ++i)
|
2018-03-23 23:32:17 +08:00
|
|
|
ASSERT_TRUE(output_stream_.Write(data + 2, size));
|
2018-01-24 19:16:14 +08:00
|
|
|
|
2018-03-23 23:32:17 +08:00
|
|
|
input_stream_.Shift(size + 2);
|
2018-01-24 19:16:14 +08:00
|
|
|
}
|
|
|
|
|
2018-03-23 23:32:17 +08:00
|
|
|
communication::InputStream input_stream_;
|
|
|
|
communication::OutputStream output_stream_;
|
2017-03-06 20:37:51 +08:00
|
|
|
};
|
|
|
|
|
2017-10-17 20:05:08 +08:00
|
|
|
using ServerT = communication::Server<TestSession, TestData>;
|
2017-03-06 20:37:51 +08:00
|
|
|
|
2018-01-15 21:03:07 +08:00
|
|
|
void client_run(int num, const char *interface, uint16_t port,
|
2017-06-21 17:29:13 +08:00
|
|
|
const unsigned char *data, int lo, int hi) {
|
2017-03-06 20:37:51 +08:00
|
|
|
std::stringstream name;
|
|
|
|
name << "Client " << num;
|
|
|
|
unsigned char buffer[SIZE * REPLY], head[2];
|
|
|
|
int have, read;
|
2018-01-15 21:03:07 +08:00
|
|
|
Endpoint endpoint(interface, port);
|
2017-10-17 20:05:08 +08:00
|
|
|
Socket socket;
|
2017-03-06 20:37:51 +08:00
|
|
|
ASSERT_TRUE(socket.Connect(endpoint));
|
2017-12-12 19:25:15 +08:00
|
|
|
socket.SetTimeout(2, 0);
|
2017-10-09 16:53:03 +08:00
|
|
|
DLOG(INFO) << "Socket create: " << socket.fd();
|
2017-03-06 20:37:51 +08:00
|
|
|
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));
|
2017-10-09 16:53:03 +08:00
|
|
|
DLOG(INFO) << "Socket write: " << socket.fd();
|
2017-03-06 20:37:51 +08:00
|
|
|
while (have < len * REPLY) {
|
|
|
|
read = socket.Read(buffer + have, SIZE);
|
2017-10-09 16:53:03 +08:00
|
|
|
DLOG(INFO) << "Socket read: " << socket.fd();
|
2017-03-06 20:37:51 +08:00
|
|
|
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]);
|
|
|
|
}
|
2017-10-09 16:53:03 +08:00
|
|
|
DLOG(INFO) << "Socket done: " << socket.fd();
|
2017-03-06 20:37:51 +08:00
|
|
|
socket.Close();
|
|
|
|
}
|
|
|
|
|
2017-06-21 17:29:13 +08:00
|
|
|
void initialize_data(unsigned char *data, int size) {
|
2017-03-06 20:37:51 +08:00
|
|
|
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);
|
|
|
|
}
|
|
|
|
}
|