Compare commits
	
		
			6 Commits
		
	
	
		
			v7.4.5
			...
			user/bserg
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 4373a92c61 | ||
|  | 91e67f6e53 | ||
|  | 1ca1f612be | ||
|  | 1b9e55d3f8 | ||
|  | 0d80971328 | ||
|  | 80c1ed0611 | 
| @@ -5,5 +5,7 @@ compiler: | ||||
|   - clang | ||||
| #   - gcc | ||||
|  | ||||
|     # os: osx | ||||
| script: make test | ||||
| os: osx | ||||
| # os: windows | ||||
| # script: make test | ||||
| script: python test/run.py | ||||
|   | ||||
| @@ -156,7 +156,9 @@ namespace ix | ||||
|         _onCloseCallback = onCloseCallback;  | ||||
|     } | ||||
|  | ||||
|     bool WebSocketTransport::exceedSendHeartBeatTimeOut() | ||||
|     // Only consider send time points for that computation. | ||||
|     // The receive time points is taken into account in Socket::poll (second parameter). | ||||
|     bool WebSocketTransport::heartBeatPeriodExceeded() | ||||
|     { | ||||
|         std::lock_guard<std::mutex> lock(_lastSendTimePointMutex); | ||||
|         auto now = std::chrono::steady_clock::now(); | ||||
| @@ -172,7 +174,7 @@ namespace ix | ||||
|                 // send for a duration exceeding our heart-beat period, send a | ||||
|                 // ping to the server. | ||||
|                 if (pollResult == PollResultType_Timeout &&  | ||||
|                     exceedSendHeartBeatTimeOut()) | ||||
|                     heartBeatPeriodExceeded()) | ||||
|                 { | ||||
|                     std::stringstream ss; | ||||
|                     ss << kHeartBeatPingMessage << "::" << _heartBeatPeriod << "s"; | ||||
|   | ||||
| @@ -126,7 +126,7 @@ namespace ix | ||||
|         std::chrono::time_point<std::chrono::steady_clock> _lastSendTimePoint; | ||||
|  | ||||
|         // No data was send through the socket for longer that the hearbeat period | ||||
|         bool exceedSendHeartBeatTimeOut(); | ||||
|         bool heartBeatPeriodExceeded(); | ||||
|  | ||||
|         void sendOnSocket(); | ||||
|         WebSocketSendInfo sendData(wsheader_type::opcode_type type,  | ||||
|   | ||||
| @@ -6,6 +6,7 @@ | ||||
|  | ||||
| #include "IXTest.h" | ||||
| #include <ixwebsocket/IXWebSocket.h> | ||||
| #include <ixwebsocket/IXNetSystem.h> | ||||
|  | ||||
| #include <chrono> | ||||
| #include <thread> | ||||
| @@ -14,12 +15,14 @@ | ||||
| #include <fstream> | ||||
| #include <iostream> | ||||
| #include <stdlib.h> | ||||
| #include <stack> | ||||
|  | ||||
| namespace ix | ||||
| { | ||||
|     std::atomic<size_t> incomingBytes(0); | ||||
|     std::atomic<size_t> outgoingBytes(0); | ||||
|     std::mutex Logger::_mutex; | ||||
|     std::stack<int> freePorts; | ||||
|  | ||||
|     void setupWebSocketTrafficTrackerCallback() | ||||
|     { | ||||
| @@ -66,4 +69,52 @@ namespace ix | ||||
|         Logger() << msg; | ||||
|     } | ||||
|  | ||||
|     int getFreePort() | ||||
|     { | ||||
|         int defaultPort = 8090; | ||||
|  | ||||
|         int sockfd;  | ||||
|         if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) < 0) | ||||
|         { | ||||
|             log("Cannot compute a free port. socket error."); | ||||
|             return defaultPort; | ||||
|         } | ||||
|  | ||||
|         int enable = 1; | ||||
|         if (setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, | ||||
|                        (char*) &enable, sizeof(enable)) < 0) | ||||
|         { | ||||
|             log("Cannot compute a free port. setsockopt error."); | ||||
|             return defaultPort; | ||||
|         } | ||||
|  | ||||
|         // Bind to port 0. This is the standard way to get a free port. | ||||
|         struct sockaddr_in server; // server address information | ||||
|         server.sin_family = AF_INET; | ||||
|         server.sin_port   = htons(0); | ||||
|         server.sin_addr.s_addr = inet_addr("127.0.0.1"); | ||||
|  | ||||
|         if (bind(sockfd, (struct sockaddr *)&server, sizeof(server)) < 0) | ||||
|         { | ||||
|             log("Cannot compute a free port. bind error."); | ||||
|  | ||||
|             ::close(sockfd); | ||||
|             return defaultPort; | ||||
|         } | ||||
|  | ||||
|         struct sockaddr_in sa; // server address information | ||||
|         unsigned int len; | ||||
|         if (getsockname(sockfd, (struct sockaddr *) &sa, &len) < 0) | ||||
|         { | ||||
|             log("Cannot compute a free port. getsockname error."); | ||||
|  | ||||
|             ::close(sockfd); | ||||
|             return defaultPort; | ||||
|         } | ||||
|  | ||||
|         int port = ntohs(sa.sin_port); | ||||
|         ::close(sockfd); | ||||
|  | ||||
|         return port; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -51,4 +51,7 @@ namespace ix | ||||
|     }; | ||||
|  | ||||
|     void log(const std::string& msg); | ||||
|  | ||||
|     bool computeFreePorts(int count); | ||||
|     int getFreePort(); | ||||
| } | ||||
|   | ||||
| @@ -180,7 +180,7 @@ TEST_CASE("Websocket_heartbeat", "[heartbeat]") | ||||
|     { | ||||
|         ix::setupWebSocketTrafficTrackerCallback(); | ||||
|  | ||||
|         int port = 8093; | ||||
|         int port = getFreePort(); | ||||
|         ix::WebSocketServer server(port); | ||||
|         std::atomic<int> serverReceivedPingMessages(0); | ||||
|         REQUIRE(startServer(server, serverReceivedPingMessages)); | ||||
|   | ||||
| @@ -75,7 +75,7 @@ TEST_CASE("Websocket_server", "[websocket_server]") | ||||
| { | ||||
|     SECTION("Connect to the server, do not send anything. Should timeout and return 400") | ||||
|     { | ||||
|         int port = 8091; | ||||
|         int port = getFreePort(); | ||||
|         ix::WebSocketServer server(port); | ||||
|         REQUIRE(startServer(server)); | ||||
|  | ||||
| @@ -107,7 +107,7 @@ TEST_CASE("Websocket_server", "[websocket_server]") | ||||
|  | ||||
|     SECTION("Connect to the server. Send GET request without header. Should return 400") | ||||
|     { | ||||
|         int port = 8092; | ||||
|         int port = getFreePort(); | ||||
|         ix::WebSocketServer server(port); | ||||
|         REQUIRE(startServer(server)); | ||||
|  | ||||
| @@ -142,7 +142,7 @@ TEST_CASE("Websocket_server", "[websocket_server]") | ||||
|  | ||||
|     SECTION("Connect to the server. Send GET request with correct header") | ||||
|     { | ||||
|         int port = 8093; | ||||
|         int port = getFreePort(); | ||||
|         ix::WebSocketServer server(port); | ||||
|         REQUIRE(startServer(server)); | ||||
|  | ||||
|   | ||||
| @@ -4,6 +4,11 @@ | ||||
|  *  Copyright (c) 2017 Machine Zone. All rights reserved. | ||||
|  */ | ||||
|  | ||||
| // | ||||
| // Simple chat program that talks to the node.js server at | ||||
| // websocket_chat_server/broacast-server.js | ||||
| // | ||||
|  | ||||
| #include <iostream> | ||||
| #include <sstream> | ||||
| #include <queue> | ||||
| @@ -24,7 +29,8 @@ namespace | ||||
|     { | ||||
|         public: | ||||
|             WebSocketChat(const std::string& user, | ||||
|                        const std::string& session); | ||||
|                           const std::string& session, | ||||
|                           int port); | ||||
|  | ||||
|             void subscribe(const std::string& channel); | ||||
|             void start(); | ||||
| @@ -40,6 +46,7 @@ namespace | ||||
|         private: | ||||
|             std::string _user; | ||||
|             std::string _session; | ||||
|             int _port; | ||||
|  | ||||
|             ix::WebSocket _webSocket; | ||||
|  | ||||
| @@ -47,9 +54,11 @@ namespace | ||||
|     }; | ||||
|  | ||||
|     WebSocketChat::WebSocketChat(const std::string& user, | ||||
|                                  const std::string& session) : | ||||
|                                  const std::string& session, | ||||
|                                  int port) : | ||||
|         _user(user), | ||||
|         _session(session) | ||||
|         _session(session), | ||||
|         _port(port) | ||||
|     { | ||||
|         ; | ||||
|     } | ||||
| @@ -71,7 +80,16 @@ namespace | ||||
|  | ||||
|     void WebSocketChat::start() | ||||
|     { | ||||
|         std::string url("ws://localhost:8090/"); | ||||
|         std::string url; | ||||
|         { | ||||
|             std::stringstream ss; | ||||
|             ss << "ws://localhost:" | ||||
|                << _port  | ||||
|                << "/"; | ||||
|  | ||||
|             url = ss.str(); | ||||
|         } | ||||
|  | ||||
|         _webSocket.setUrl(url); | ||||
|  | ||||
|         std::stringstream ss; | ||||
| @@ -226,8 +244,8 @@ TEST_CASE("Websocket_chat", "[websocket_chat]") | ||||
|         REQUIRE(startServer(server)); | ||||
|  | ||||
|         std::string session = ix::generateSessionId(); | ||||
|         WebSocketChat chatA("jean", session); | ||||
|         WebSocketChat chatB("paul", session); | ||||
|         WebSocketChat chatA("jean", session, port); | ||||
|         WebSocketChat chatB("paul", session, port); | ||||
|  | ||||
|         chatA.start(); | ||||
|         chatB.start(); | ||||
|   | ||||
| @@ -34,6 +34,10 @@ if osName == 'Linux': | ||||
|  | ||||
| sanitizerFlags = sanitizersFlags[sanitizer] | ||||
|  | ||||
| # if osName == 'Windows': | ||||
| #     os.environ['CC'] = 'clang-cl' | ||||
| #     os.environ['CXX'] = 'clang-cl' | ||||
|  | ||||
| cmakeCmd = 'cmake -DCMAKE_BUILD_TYPE=Debug {} {} ..'.format(generator, sanitizerFlags) | ||||
| print(cmakeCmd) | ||||
| ret = os.system(cmakeCmd) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user