2017-10-17 20:05:08 +08:00
|
|
|
#include <chrono>
|
|
|
|
#include <experimental/filesystem>
|
|
|
|
#include <iostream>
|
|
|
|
|
|
|
|
#include <gflags/gflags.h>
|
|
|
|
#include <glog/logging.h>
|
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
|
|
|
#include "communication/bolt/client.hpp"
|
|
|
|
#include "communication/bolt/v1/session.hpp"
|
|
|
|
#include "communication/server.hpp"
|
2018-01-15 21:03:07 +08:00
|
|
|
#include "io/network/endpoint.hpp"
|
2017-10-17 20:05:08 +08:00
|
|
|
#include "io/network/socket.hpp"
|
|
|
|
|
|
|
|
DECLARE_int32(query_execution_time_sec);
|
|
|
|
DECLARE_int32(session_inactivity_timeout);
|
|
|
|
|
|
|
|
using namespace std::chrono_literals;
|
|
|
|
class TestClientSocket;
|
2018-01-10 20:56:12 +08:00
|
|
|
using communication::bolt::ClientException;
|
|
|
|
using communication::bolt::SessionData;
|
2018-01-15 21:03:07 +08:00
|
|
|
using io::network::Endpoint;
|
2017-10-17 20:05:08 +08:00
|
|
|
using io::network::Socket;
|
|
|
|
using SessionT = communication::bolt::Session<Socket>;
|
|
|
|
using ResultStreamT = SessionT::ResultStreamT;
|
|
|
|
using ServerT = communication::Server<SessionT, SessionData>;
|
|
|
|
using ClientT = communication::bolt::Client<Socket>;
|
|
|
|
|
|
|
|
class RunningServer {
|
|
|
|
public:
|
2018-01-12 22:17:04 +08:00
|
|
|
database::SingleNode db_;
|
|
|
|
SessionData session_data_{db_};
|
2018-01-15 21:03:07 +08:00
|
|
|
Endpoint endpoint_{"127.0.0.1", 0};
|
2018-02-22 23:17:45 +08:00
|
|
|
ServerT server_{endpoint_, session_data_, true, 1};
|
2017-10-17 20:05:08 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
class TestClient : public ClientT {
|
|
|
|
public:
|
2018-01-15 21:03:07 +08:00
|
|
|
TestClient(Endpoint endpoint)
|
2017-10-17 20:05:08 +08:00
|
|
|
: ClientT(
|
|
|
|
[&] {
|
|
|
|
Socket socket;
|
|
|
|
socket.Connect(endpoint);
|
|
|
|
return socket;
|
|
|
|
}(),
|
|
|
|
"", "") {}
|
|
|
|
};
|
|
|
|
|
|
|
|
TEST(NetworkTimeouts, InactiveSession) {
|
|
|
|
FLAGS_query_execution_time_sec = 60;
|
2018-02-22 23:17:45 +08:00
|
|
|
FLAGS_session_inactivity_timeout = 2;
|
2017-10-17 20:05:08 +08:00
|
|
|
RunningServer rs;
|
|
|
|
|
|
|
|
TestClient client(rs.server_.endpoint());
|
|
|
|
// Check that we can execute first query.
|
|
|
|
client.Execute("RETURN 1", {});
|
|
|
|
|
|
|
|
// After sleep, session should still be alive.
|
|
|
|
std::this_thread::sleep_for(500ms);
|
|
|
|
client.Execute("RETURN 1", {});
|
|
|
|
|
|
|
|
// After sleep, session should still be alive.
|
|
|
|
std::this_thread::sleep_for(500ms);
|
|
|
|
client.Execute("RETURN 1", {});
|
|
|
|
|
|
|
|
// After sleep, session should still be alive.
|
|
|
|
std::this_thread::sleep_for(500ms);
|
|
|
|
client.Execute("RETURN 1", {});
|
|
|
|
|
|
|
|
// After sleep, session should have timed out.
|
2018-02-22 23:17:45 +08:00
|
|
|
std::this_thread::sleep_for(3500ms);
|
2017-10-17 20:05:08 +08:00
|
|
|
EXPECT_THROW(client.Execute("RETURN 1", {}), ClientException);
|
|
|
|
}
|
|
|
|
|
|
|
|
TEST(NetworkTimeouts, TimeoutInMultiCommandTransaction) {
|
2018-02-22 23:17:45 +08:00
|
|
|
FLAGS_query_execution_time_sec = 2;
|
2017-10-17 20:05:08 +08:00
|
|
|
FLAGS_session_inactivity_timeout = 60;
|
|
|
|
RunningServer rs;
|
|
|
|
|
|
|
|
TestClient client(rs.server_.endpoint());
|
|
|
|
|
|
|
|
// Start explicit multicommand transaction.
|
|
|
|
client.Execute("BEGIN", {});
|
|
|
|
client.Execute("RETURN 1", {});
|
|
|
|
|
|
|
|
// Session should still be alive.
|
|
|
|
std::this_thread::sleep_for(500ms);
|
|
|
|
client.Execute("RETURN 1", {});
|
|
|
|
|
|
|
|
// Session shouldn't be alive anymore.
|
2018-02-22 23:17:45 +08:00
|
|
|
std::this_thread::sleep_for(4s);
|
2017-10-17 20:05:08 +08:00
|
|
|
EXPECT_THROW(client.Execute("RETURN 1", {}), ClientException);
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(int argc, char **argv) {
|
|
|
|
::testing::InitGoogleTest(&argc, argv);
|
|
|
|
google::InitGoogleLogging(argv[0]);
|
|
|
|
return RUN_ALL_TESTS();
|
|
|
|
}
|