2018-01-03 21:34:26 +08:00
|
|
|
#include <ctime>
|
|
|
|
#include <random>
|
|
|
|
#include <thread>
|
|
|
|
|
|
|
|
#include <fmt/format.h>
|
|
|
|
#include <gflags/gflags.h>
|
|
|
|
#include <glog/logging.h>
|
|
|
|
|
2018-01-24 19:16:14 +08:00
|
|
|
#include "communication/rpc/client.hpp"
|
2018-01-15 21:03:07 +08:00
|
|
|
#include "io/network/endpoint.hpp"
|
2018-01-03 21:34:26 +08:00
|
|
|
#include "messages.hpp"
|
2018-01-15 21:03:07 +08:00
|
|
|
#include "utils/network.hpp"
|
2018-01-03 21:34:26 +08:00
|
|
|
#include "utils/signals/handler.hpp"
|
|
|
|
#include "utils/terminate_handler.hpp"
|
|
|
|
|
|
|
|
using namespace communication::rpc;
|
|
|
|
using namespace std::literals::chrono_literals;
|
|
|
|
|
|
|
|
DEFINE_string(server_interface, "127.0.0.1",
|
|
|
|
"Server interface on which to communicate.");
|
2018-01-15 21:03:07 +08:00
|
|
|
DEFINE_int32(server_port, 8010, "Server port on which to communicate.");
|
2018-01-03 21:34:26 +08:00
|
|
|
|
|
|
|
volatile sig_atomic_t is_shutting_down = 0;
|
|
|
|
|
|
|
|
int main(int argc, char **argv) {
|
|
|
|
google::SetUsageMessage("Raft RPC Client");
|
|
|
|
|
|
|
|
gflags::ParseCommandLineFlags(&argc, &argv, true);
|
|
|
|
google::InitGoogleLogging(argv[0]);
|
|
|
|
|
|
|
|
// Initialize client.
|
2018-02-23 17:56:56 +08:00
|
|
|
Client client(io::network::Endpoint(
|
|
|
|
utils::ResolveHostname(FLAGS_server_interface), FLAGS_server_port));
|
2018-01-03 21:34:26 +08:00
|
|
|
|
|
|
|
// Try to send 100 values to server.
|
|
|
|
// If requests timeout, try to resend it.
|
|
|
|
// Log output on server should contain all values once
|
|
|
|
// in correct order.
|
|
|
|
for (int i = 1; i <= 100; ++i) {
|
|
|
|
LOG(INFO) << fmt::format("Apennding value: {}", i);
|
2018-01-24 19:16:14 +08:00
|
|
|
auto result_tuple = client.Call<AppendEntry>(i);
|
2018-01-03 21:34:26 +08:00
|
|
|
if (!result_tuple) {
|
|
|
|
LOG(INFO) << "Request unsuccessful";
|
|
|
|
// Try to resend value
|
|
|
|
--i;
|
|
|
|
} else {
|
|
|
|
LOG(INFO) << fmt::format("Appended value: {}", i);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|