From b95e5e36dc679e6e0817bfc634f3da0c9f40ab11 Mon Sep 17 00:00:00 2001 From: Benjamin Sergeant Date: Tue, 1 Jan 2019 22:21:07 -0800 Subject: [PATCH] use select to detect new incoming connections --- ixwebsocket/IXWebSocketServer.cpp | 25 +++++++++++++++++++------ test/cmd_websocket_chat.cpp | 6 +++--- 2 files changed, 22 insertions(+), 9 deletions(-) diff --git a/ixwebsocket/IXWebSocketServer.cpp b/ixwebsocket/IXWebSocketServer.cpp index e822a581..22bcaacf 100644 --- a/ixwebsocket/IXWebSocketServer.cpp +++ b/ixwebsocket/IXWebSocketServer.cpp @@ -152,25 +152,38 @@ namespace ix // Set the socket to non blocking mode, so that accept calls are not blocking SocketConnect::configure(_serverFd); + // Return value of std::async, ignored std::future f; + // Select arguments + fd_set rfds; + struct timeval timeout; + timeout.tv_sec = 0; + timeout.tv_usec = 10 * 1000; // 10ms + for (;;) { if (_stop) return; + FD_ZERO(&rfds); + FD_SET(_serverFd, &rfds); + select(_serverFd + 1, &rfds, nullptr, nullptr, &timeout); + + if (!FD_ISSET(_serverFd, &rfds)) + { + // We reached the select timeout, and no new connections are pending + continue; + } + // Accept a connection. struct sockaddr_in client; // client address information int clientFd; // socket connected to client socklen_t addressLen = sizeof(socklen_t); + memset(&client, 0, sizeof(client)); if ((clientFd = accept(_serverFd, (struct sockaddr *)&client, &addressLen)) < 0) { - if (errno == EWOULDBLOCK) - { - std::chrono::duration wait(10); - std::this_thread::sleep_for(wait); - } - else + if (errno != EWOULDBLOCK) { // FIXME: that error should be propagated std::stringstream ss; diff --git a/test/cmd_websocket_chat.cpp b/test/cmd_websocket_chat.cpp index 2e90c4a7..b78da6b6 100644 --- a/test/cmd_websocket_chat.cpp +++ b/test/cmd_websocket_chat.cpp @@ -83,7 +83,7 @@ namespace void WebSocketChat::start() { - std::string url("ws://localhost:8080/"); + std::string url("ws://localhost:8090/"); _webSocket.setUrl(url); std::stringstream ss; @@ -232,9 +232,9 @@ TEST_CASE("Websocket chat", "[websocket_chat]") { ix::setupWebSocketTrafficTrackerCallback(); - int port = 8080; + int port = 8090; ix::WebSocketServer server(port); - startServer(server); + REQUIRE(startServer(server)); std::string session = ix::generateSessionId(); WebSocketChat chatA("jean", session);