2020-03-12 17:07:01 +01:00
|
|
|
/*
|
|
|
|
* cmd_satori_chat.cpp
|
|
|
|
* Author: Benjamin Sergeant
|
|
|
|
* Copyright (c) 2017 Machine Zone. All rights reserved.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "IXTest.h"
|
|
|
|
#include "catch.hpp"
|
|
|
|
#include <chrono>
|
|
|
|
#include <iostream>
|
2020-03-12 20:15:56 +01:00
|
|
|
#include <ixbots/IXCobraToSentryBot.h>
|
2020-03-12 17:07:01 +01:00
|
|
|
#include <ixcobra/IXCobraConnection.h>
|
|
|
|
#include <ixcobra/IXCobraMetricsPublisher.h>
|
|
|
|
#include <ixcrypto/IXUuid.h>
|
2020-03-13 00:27:25 +01:00
|
|
|
#include <ixsentry/IXSentryClient.h>
|
2020-03-12 17:07:01 +01:00
|
|
|
#include <ixsnake/IXRedisServer.h>
|
|
|
|
#include <ixsnake/IXSnakeServer.h>
|
|
|
|
#include <ixwebsocket/IXHttpServer.h>
|
|
|
|
#include <ixwebsocket/IXUserAgent.h>
|
|
|
|
|
|
|
|
using namespace ix;
|
|
|
|
|
|
|
|
namespace
|
|
|
|
{
|
|
|
|
std::atomic<size_t> incomingBytes(0);
|
|
|
|
std::atomic<size_t> outgoingBytes(0);
|
|
|
|
|
|
|
|
void setupTrafficTrackerCallback()
|
|
|
|
{
|
|
|
|
ix::CobraConnection::setTrafficTrackerCallback([](size_t size, bool incoming) {
|
|
|
|
if (incoming)
|
|
|
|
{
|
|
|
|
incomingBytes += size;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
outgoingBytes += size;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
void runPublisher(const ix::CobraConfig& config, const std::string& channel)
|
|
|
|
{
|
|
|
|
ix::CobraMetricsPublisher cobraMetricsPublisher;
|
|
|
|
|
|
|
|
SocketTLSOptions socketTLSOptions;
|
|
|
|
bool perMessageDeflate = true;
|
|
|
|
cobraMetricsPublisher.configure(config.appkey,
|
|
|
|
config.endpoint,
|
|
|
|
channel,
|
|
|
|
config.rolename,
|
|
|
|
config.rolesecret,
|
|
|
|
perMessageDeflate,
|
|
|
|
socketTLSOptions);
|
|
|
|
cobraMetricsPublisher.setSession(uuid4());
|
|
|
|
cobraMetricsPublisher.enable(true); // disabled by default, needs to be enabled to be active
|
|
|
|
|
|
|
|
Json::Value msg;
|
|
|
|
msg["fps"] = 60;
|
|
|
|
|
|
|
|
cobraMetricsPublisher.setGenericAttributes("game", "ody");
|
|
|
|
|
|
|
|
// Wait a bit
|
|
|
|
ix::msleep(500);
|
|
|
|
|
|
|
|
// publish some messages
|
|
|
|
cobraMetricsPublisher.push("sms_metric_A_id", msg); // (msg #1)
|
|
|
|
cobraMetricsPublisher.push("sms_metric_B_id", msg); // (msg #2)
|
|
|
|
ix::msleep(500);
|
|
|
|
|
|
|
|
cobraMetricsPublisher.push("sms_metric_A_id", msg); // (msg #3)
|
|
|
|
cobraMetricsPublisher.push("sms_metric_D_id", msg); // (msg #4)
|
|
|
|
ix::msleep(500);
|
|
|
|
|
|
|
|
cobraMetricsPublisher.push("sms_metric_A_id", msg); // (msg #4)
|
|
|
|
cobraMetricsPublisher.push("sms_metric_F_id", msg); // (msg #5)
|
|
|
|
ix::msleep(500);
|
|
|
|
}
|
2020-03-12 20:15:56 +01:00
|
|
|
} // namespace
|
2020-03-12 17:07:01 +01:00
|
|
|
|
2020-03-20 02:50:46 +01:00
|
|
|
TEST_CASE("Cobra_to_sentry_bot", "[cobra_bots]")
|
2020-03-12 17:07:01 +01:00
|
|
|
{
|
|
|
|
SECTION("Exchange and count sent/received messages.")
|
|
|
|
{
|
|
|
|
int port = getFreePort();
|
|
|
|
snake::AppConfig appConfig = makeSnakeServerConfig(port);
|
|
|
|
|
|
|
|
// Start a redis server
|
|
|
|
ix::RedisServer redisServer(appConfig.redisPort);
|
|
|
|
auto res = redisServer.listen();
|
|
|
|
REQUIRE(res.first);
|
|
|
|
redisServer.start();
|
|
|
|
|
|
|
|
// Start a snake server
|
|
|
|
snake::SnakeServer snakeServer(appConfig);
|
|
|
|
snakeServer.run();
|
|
|
|
|
|
|
|
// Start a fake sentry http server
|
2020-03-13 00:18:28 +01:00
|
|
|
SocketTLSOptions tlsOptionsServer;
|
|
|
|
tlsOptionsServer.certFile = ".certs/trusted-server-crt.pem";
|
|
|
|
tlsOptionsServer.keyFile = ".certs/trusted-server-key.pem";
|
|
|
|
tlsOptionsServer.caFile = ".certs/trusted-ca-crt.pem";
|
|
|
|
|
2020-03-20 02:50:46 +01:00
|
|
|
#if defined(IXWEBSOCKET_USE_MBED_TLS) || defined(IXWEBSOCKET_USE_OPEN_SSL)
|
|
|
|
tlsOptionsServer.tls = true;
|
|
|
|
#else
|
|
|
|
tlsOptionsServer.tls = false;
|
|
|
|
#endif
|
|
|
|
|
2020-03-12 17:07:01 +01:00
|
|
|
int sentryPort = getFreePort();
|
|
|
|
ix::HttpServer sentryServer(sentryPort, "127.0.0.1");
|
2020-03-13 00:18:28 +01:00
|
|
|
sentryServer.setTLSOptions(tlsOptionsServer);
|
|
|
|
|
2020-03-12 17:07:01 +01:00
|
|
|
sentryServer.setOnConnectionCallback(
|
|
|
|
[](HttpRequestPtr request,
|
2020-03-12 20:15:56 +01:00
|
|
|
std::shared_ptr<ConnectionState> /*connectionState*/) -> HttpResponsePtr {
|
2020-03-12 17:07:01 +01:00
|
|
|
WebSocketHttpHeaders headers;
|
|
|
|
headers["Server"] = userAgent();
|
|
|
|
|
|
|
|
// Log request
|
|
|
|
std::stringstream ss;
|
|
|
|
ss << request->method << " " << request->headers["User-Agent"] << " "
|
|
|
|
<< request->uri;
|
|
|
|
|
|
|
|
if (request->method == "POST")
|
|
|
|
{
|
|
|
|
return std::make_shared<HttpResponse>(
|
|
|
|
200, "OK", HttpErrorCode::Ok, headers, std::string());
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return std::make_shared<HttpResponse>(
|
|
|
|
405, "OK", HttpErrorCode::Invalid, headers, std::string("Invalid method"));
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
res = sentryServer.listen();
|
|
|
|
REQUIRE(res.first);
|
|
|
|
sentryServer.start();
|
|
|
|
|
|
|
|
setupTrafficTrackerCallback();
|
|
|
|
|
|
|
|
// Run the bot for a small amount of time
|
|
|
|
std::string channel = ix::generateSessionId();
|
|
|
|
std::string appkey("FC2F10139A2BAc53BB72D9db967b024f");
|
|
|
|
std::string role = "_sub";
|
|
|
|
std::string secret = "66B1dA3ED5fA074EB5AE84Dd8CE3b5ba";
|
2020-03-12 20:15:56 +01:00
|
|
|
|
2020-03-12 17:07:01 +01:00
|
|
|
std::stringstream ss;
|
|
|
|
ss << "ws://localhost:" << port;
|
|
|
|
std::string endpoint = ss.str();
|
|
|
|
|
|
|
|
ix::CobraConfig config;
|
|
|
|
config.endpoint = endpoint;
|
|
|
|
config.appkey = appkey;
|
|
|
|
config.rolename = role;
|
|
|
|
config.rolesecret = secret;
|
|
|
|
|
|
|
|
std::thread publisherThread(runPublisher, config, channel);
|
|
|
|
|
|
|
|
std::string filter;
|
2020-03-14 00:06:13 +01:00
|
|
|
std::string position("$");
|
2020-03-12 17:07:01 +01:00
|
|
|
bool verbose = true;
|
|
|
|
bool strict = true;
|
|
|
|
size_t maxQueueSize = 10;
|
|
|
|
bool enableHeartbeat = false;
|
|
|
|
|
2020-03-13 00:18:28 +01:00
|
|
|
// FIXME: try to get this working with https instead of http
|
2020-03-13 00:27:25 +01:00
|
|
|
// to regress the TLS 1.3 OpenSSL bug
|
2020-03-13 00:18:28 +01:00
|
|
|
// -> https://github.com/openssl/openssl/issues/7967
|
2020-03-12 17:07:01 +01:00
|
|
|
// https://xxxxx:yyyyyy@sentry.io/1234567
|
2020-03-20 02:50:46 +01:00
|
|
|
#if defined(IXWEBSOCKET_USE_MBED_TLS) || defined(IXWEBSOCKET_USE_OPEN_SSL)
|
|
|
|
std::string scheme("https://");
|
|
|
|
#else
|
2020-03-12 20:13:31 +01:00
|
|
|
std::string scheme("http://");
|
2020-03-20 02:50:46 +01:00
|
|
|
#endif
|
|
|
|
std::stringstream oss;
|
2020-03-12 20:13:31 +01:00
|
|
|
oss << scheme << "xxxxxxx:yyyyyyy@localhost:" << sentryPort << "/1234567";
|
2020-03-12 17:07:01 +01:00
|
|
|
std::string dsn = oss.str();
|
|
|
|
|
2020-03-13 00:18:28 +01:00
|
|
|
SocketTLSOptions tlsOptionsClient;
|
|
|
|
tlsOptionsClient.certFile = ".certs/trusted-client-crt.pem";
|
|
|
|
tlsOptionsClient.keyFile = ".certs/trusted-client-key.pem";
|
|
|
|
tlsOptionsClient.caFile = ".certs/trusted-ca-crt.pem";
|
|
|
|
|
2020-03-12 20:30:58 +01:00
|
|
|
SentryClient sentryClient(dsn);
|
2020-03-13 00:18:28 +01:00
|
|
|
sentryClient.setTLSOptions(tlsOptionsClient);
|
2020-03-12 20:30:58 +01:00
|
|
|
|
2020-03-12 17:07:01 +01:00
|
|
|
// Only run the bot for 3 seconds
|
|
|
|
int runtime = 3;
|
|
|
|
|
2020-03-12 20:15:56 +01:00
|
|
|
int sentCount = cobra_to_sentry_bot(config,
|
|
|
|
channel,
|
|
|
|
filter,
|
2020-03-14 00:06:13 +01:00
|
|
|
position,
|
2020-03-12 20:30:58 +01:00
|
|
|
sentryClient,
|
2020-03-12 20:15:56 +01:00
|
|
|
verbose,
|
|
|
|
strict,
|
|
|
|
maxQueueSize,
|
|
|
|
enableHeartbeat,
|
|
|
|
runtime);
|
2020-03-12 17:07:01 +01:00
|
|
|
//
|
|
|
|
// We want at least 2 messages to be sent
|
|
|
|
//
|
|
|
|
REQUIRE(sentCount >= 2);
|
|
|
|
|
|
|
|
// Give us 1s for all messages to be received
|
|
|
|
ix::msleep(1000);
|
|
|
|
|
|
|
|
spdlog::info("Incoming bytes {}", incomingBytes);
|
|
|
|
spdlog::info("Outgoing bytes {}", outgoingBytes);
|
|
|
|
|
|
|
|
spdlog::info("Stopping snake server...");
|
|
|
|
snakeServer.stop();
|
|
|
|
|
|
|
|
spdlog::info("Stopping redis server...");
|
|
|
|
redisServer.stop();
|
|
|
|
|
|
|
|
publisherThread.join();
|
|
|
|
sentryServer.stop();
|
|
|
|
}
|
|
|
|
}
|