memgraph/tests/manual/ssl_client.cpp
antonio2368 28413fd626 Change log library to spdlog, expose log levels to user (#72)
* Change from glog to spdlog

* Remove HA tests

* Remove logrotate log configuration

* Define custom main for unit gtests
2021-01-21 16:30:55 +01:00

65 lines
1.6 KiB
C++

#include <gflags/gflags.h>
#include "communication/client.hpp"
#include "io/network/endpoint.hpp"
#include "utils/logging.hpp"
#include "utils/timer.hpp"
DEFINE_string(address, "127.0.0.1", "Server address");
DEFINE_int32(port, 54321, "Server port");
DEFINE_string(cert_file, "", "Certificate file to use.");
DEFINE_string(key_file, "", "Key file to use.");
bool EchoMessage(communication::Client &client, const std::string &data) {
uint16_t size = data.size();
if (!client.Write(reinterpret_cast<const uint8_t *>(&size), sizeof(size))) {
spdlog::warn("Couldn't send data size!");
return false;
}
if (!client.Write(data)) {
spdlog::warn("Couldn't send data!");
return false;
}
client.ClearData();
if (!client.Read(size)) {
spdlog::warn("Couldn't receive data!");
return false;
}
if (std::string(reinterpret_cast<const char *>(client.GetData()), size) !=
data) {
spdlog::warn("Received data isn't equal to sent data!");
return false;
}
return true;
}
int main(int argc, char **argv) {
gflags::ParseCommandLineFlags(&argc, &argv, true);
communication::SSLInit sslInit;
io::network::Endpoint endpoint(FLAGS_address, FLAGS_port);
communication::ClientContext context(FLAGS_key_file, FLAGS_cert_file);
communication::Client client(&context);
if (!client.Connect(endpoint)) return 1;
bool success = true;
while (true) {
std::string s;
std::getline(std::cin, s);
if (s == "") break;
if (!EchoMessage(client, s)) {
success = false;
break;
}
}
// Send server shutdown signal. The call will fail, we don't care.
EchoMessage(client, "");
return success ? 0 : 1;
}