IXWebSocket/test/IXWebSocketTestConnectionDisconnection.cpp

166 lines
4.7 KiB
C++
Raw Permalink Normal View History

2019-01-07 03:54:16 +01:00
/*
* IXWebSocketTestConnectionDisconnection.cpp
* Author: Benjamin Sergeant
* Copyright (c) 2017 Machine Zone. All rights reserved.
*/
#include "IXTest.h"
#include "catch.hpp"
2019-09-23 19:25:23 +02:00
#include <iostream>
#include <ixwebsocket/IXWebSocket.h>
#include <set>
#include <sstream>
2019-01-07 03:54:16 +01:00
using namespace ix;
namespace
{
2019-01-07 20:28:53 +01:00
const std::string WEBSOCKET_DOT_ORG_URL("wss://echo.websocket.org");
2019-01-07 03:54:16 +01:00
const std::string GOOGLE_URL("wss://google.com");
const std::string UNKNOWN_URL("wss://asdcasdcaasdcasdcasdcasdcasdcasdcasassdd.com");
2019-09-23 19:25:23 +02:00
} // namespace
2019-01-07 03:54:16 +01:00
namespace
{
class IXWebSocketTestConnectionDisconnection
{
2019-09-23 19:25:23 +02:00
public:
IXWebSocketTestConnectionDisconnection();
void start(const std::string& url);
void stop();
2019-01-07 03:54:16 +01:00
2019-09-23 19:25:23 +02:00
private:
ix::WebSocket _webSocket;
2019-01-07 03:54:16 +01:00
};
IXWebSocketTestConnectionDisconnection::IXWebSocketTestConnectionDisconnection()
{
;
}
void IXWebSocketTestConnectionDisconnection::stop()
{
_webSocket.stop();
}
void IXWebSocketTestConnectionDisconnection::start(const std::string& url)
{
_webSocket.setUrl(url);
SocketTLSOptions tlsOptions;
tlsOptions.caFile = "cacert.pem";
_webSocket.setTLSOptions(tlsOptions);
2019-01-07 03:54:16 +01:00
std::stringstream ss;
log(std::string("Connecting to url: ") + url);
2019-09-23 19:25:23 +02:00
_webSocket.setOnMessageCallback([](const ix::WebSocketMessagePtr& msg) {
std::stringstream ss;
if (msg->type == ix::WebSocketMessageType::Open)
{
log("TestConnectionDisconnection: connected !");
}
else if (msg->type == ix::WebSocketMessageType::Close)
{
log("TestConnectionDisconnection: disconnected !");
}
else if (msg->type == ix::WebSocketMessageType::Error)
{
ss << "TestConnectionDisconnection: Error! ";
ss << msg->errorInfo.reason;
log(ss.str());
}
else if (msg->type == ix::WebSocketMessageType::Message)
{
log("TestConnectionDisconnection: received message.!");
}
else if (msg->type == ix::WebSocketMessageType::Ping)
2019-01-07 03:54:16 +01:00
{
2019-09-23 19:25:23 +02:00
log("TestConnectionDisconnection: received ping message.!");
}
else if (msg->type == ix::WebSocketMessageType::Pong)
{
log("TestConnectionDisconnection: received pong message.!");
}
else if (msg->type == ix::WebSocketMessageType::Fragment)
{
log("TestConnectionDisconnection: received fragment.!");
}
else
{
log("Invalid ix::WebSocketMessageType");
}
});
2019-01-07 03:54:16 +01:00
_webSocket.enableAutomaticReconnection();
REQUIRE(_webSocket.isAutomaticReconnectionEnabled() == true);
_webSocket.disableAutomaticReconnection();
REQUIRE(_webSocket.isAutomaticReconnectionEnabled() == false);
2019-01-07 03:54:16 +01:00
// Start the connection
_webSocket.start();
}
2019-09-23 19:25:23 +02:00
} // namespace
2019-01-07 03:54:16 +01:00
//
// We try to connect to different servers, and make sure there are no crashes.
2019-09-23 19:25:23 +02:00
// FIXME: We could do more checks (make sure that we were not able to connect to unknown servers,
// etc...)
2019-01-07 03:54:16 +01:00
//
TEST_CASE("websocket_connections", "[websocket]")
{
SECTION("Try to connect to invalid servers.")
{
IXWebSocketTestConnectionDisconnection test;
2019-01-07 03:54:16 +01:00
test.start(GOOGLE_URL);
2019-01-07 03:54:16 +01:00
ix::msleep(1000);
test.stop();
2019-01-07 03:54:16 +01:00
test.start(UNKNOWN_URL);
2019-01-07 03:54:16 +01:00
ix::msleep(1000);
test.stop();
2019-01-07 03:54:16 +01:00
}
2019-09-23 19:25:23 +02:00
SECTION("Try to connect and disconnect with different timing, not enough time to succesfully "
"connect")
2019-01-07 03:54:16 +01:00
{
IXWebSocketTestConnectionDisconnection test;
log(std::string("50 Runs"));
2019-01-07 03:54:16 +01:00
for (int i = 0; i < 50; ++i)
{
log(std::string("Run: ") + std::to_string(i));
test.start(WEBSOCKET_DOT_ORG_URL);
log(std::string("Sleeping"));
2019-01-07 03:54:16 +01:00
ix::msleep(i);
log(std::string("Stopping"));
test.stop();
2019-01-07 03:54:16 +01:00
}
}
// This test breaks on travis CI - Ubuntu Xenial + gcc + tsan
// We should fix this.
2019-09-23 19:25:23 +02:00
SECTION("Try to connect and disconnect with different timing, from not enough time to "
"successfull connect")
{
IXWebSocketTestConnectionDisconnection test;
log(std::string("20 Runs"));
for (int i = 0; i < 20; ++i)
{
log(std::string("Run: ") + std::to_string(i));
test.start(WEBSOCKET_DOT_ORG_URL);
log(std::string("Sleeping"));
2019-09-23 19:25:23 +02:00
ix::msleep(i * 50);
log(std::string("Stopping"));
test.stop();
}
}
2019-01-07 03:54:16 +01:00
}