From 9c0d176d68b4efb0004b3e4f7e6ce2721f87e250 Mon Sep 17 00:00:00 2001 From: Pieter Hintjens Date: Fri, 12 Feb 2016 15:46:55 +0100 Subject: [PATCH] Problem: tests don't build on Windows There were numerous small issues with test cases: - some lacked the right source file header - some were not portable at all - some were using internal libzmq APIs (headers) Solution: fixed and cleaned up. --- tests/README.md | 2 +- tests/test_filter_ipc.cpp | 13 ++++--------- tests/test_fork.cpp | 2 ++ tests/test_heartbeats.cpp | 7 ++----- tests/test_router_mandatory_hwm.cpp | 2 +- tests/test_security_curve.cpp | 2 +- tests/test_security_null.cpp | 2 +- tests/test_security_plain.cpp | 4 ++-- tests/test_stream_exceeds_buffer.cpp | 2 +- 9 files changed, 15 insertions(+), 21 deletions(-) diff --git a/tests/README.md b/tests/README.md index cdf826b3..a9463ef4 100644 --- a/tests/README.md +++ b/tests/README.md @@ -10,4 +10,4 @@ Note that testutil.hpp includes platform.h. Do not include it yourself as it cha All sources must contain the correct header. Please copy from test_system.cpp if you're not certain. - +Please use only ANSI C99 in test cases, no C++. This is to make the code more reusable. diff --git a/tests/test_filter_ipc.cpp b/tests/test_filter_ipc.cpp index 7b0154c3..6bfc7cb6 100644 --- a/tests/test_filter_ipc.cpp +++ b/tests/test_filter_ipc.cpp @@ -27,12 +27,6 @@ along with this program. If not, see . */ -#include -#include - -#include -#include - #include "testutil.hpp" static void bounce_fail (void *server, void *client) @@ -78,9 +72,9 @@ static void run_test (int opt, T optval, int expected_error, int bounce_test) if (expected_error) { assert (rc == -1); assert (zmq_errno () == expected_error); - } else { - assert (rc == 0); } + else + assert (rc == 0); } void *sc = zmq_socket (ctx, ZMQ_DEALER); @@ -113,7 +107,6 @@ static void run_test (int opt, T optval, int expected_error, int bounce_test) else bounce_fail (sb, sc); } - close_zero_linger (sc); close_zero_linger (sb); @@ -123,6 +116,7 @@ static void run_test (int opt, T optval, int expected_error, int bounce_test) int main (void) { +#if !defined (ZMQ_HAVE_WINDOWS) setup_test_environment(); // No filters @@ -166,6 +160,7 @@ int main (void) run_test (ZMQ_IPC_FILTER_PID, 0, EINVAL, 0); #endif // defined ZMQ_HAVE_SO_PEERCRED || defined ZMQ_HAVE_LOCAL_PEERCRED +#endif return 0 ; } diff --git a/tests/test_fork.cpp b/tests/test_fork.cpp index 973e2907..70f4a77c 100644 --- a/tests/test_fork.cpp +++ b/tests/test_fork.cpp @@ -35,6 +35,7 @@ const char *address = "tcp://127.0.0.1:6571"; int main (void) { +#if !defined (ZMQ_HAVE_WINDOWS) setup_test_environment (); void *ctx = zmq_ctx_new (); assert (ctx); @@ -87,5 +88,6 @@ int main (void) } exit (0); } +#endif return 0; } diff --git a/tests/test_heartbeats.cpp b/tests/test_heartbeats.cpp index b5d034ff..1a4338d3 100644 --- a/tests/test_heartbeats.cpp +++ b/tests/test_heartbeats.cpp @@ -24,10 +24,7 @@ # include # define close closesocket #else -# include -# include # include -# include #endif // Read one event off the monitor socket; return value and address @@ -184,8 +181,8 @@ test_heartbeat_timeout (void) int s; ip4addr.sin_family = AF_INET; - ip4addr.sin_port = htons(5556); -#if (ZMQ_HAVE_WINDOWS and _WIN32_WINNT < 0x0600) + ip4addr.sin_port = htons (5556); +#if defined (ZMQ_HAVE_WINDOWS) && (_WIN32_WINNT < 0x0600) ip4addr.sin_addr.s_addr = inet_addr ("127.0.0.1"); #else inet_pton(AF_INET, "127.0.0.1", &ip4addr.sin_addr); diff --git a/tests/test_router_mandatory_hwm.cpp b/tests/test_router_mandatory_hwm.cpp index 9d19cd25..81b8fc63 100644 --- a/tests/test_router_mandatory_hwm.cpp +++ b/tests/test_router_mandatory_hwm.cpp @@ -95,7 +95,7 @@ int main (void) // This should fail after one message but kernel buffering could // skew results assert (i < 10); - sleep(1); + msleep (1000); // Send second batch of messages for(; i < 100000; ++i) { if (TRACE_ENABLED) fprintf(stderr, "Sending message %d (part 2) ...\n", i); diff --git a/tests/test_security_curve.cpp b/tests/test_security_curve.cpp index 18bcc2df..64bd0bfc 100644 --- a/tests/test_security_curve.cpp +++ b/tests/test_security_curve.cpp @@ -244,7 +244,7 @@ int main (void) ip4addr.sin_family = AF_INET; ip4addr.sin_port = htons (9998); -#if (ZMQ_HAVE_WINDOWS and _WIN32_WINNT < 0x0600) +#if defined (ZMQ_HAVE_WINDOWS) && (_WIN32_WINNT < 0x0600) ip4addr.sin_addr.s_addr = inet_addr ("127.0.0.1"); #else inet_pton(AF_INET, "127.0.0.1", &ip4addr.sin_addr); diff --git a/tests/test_security_null.cpp b/tests/test_security_null.cpp index af2f44da..7874aa75 100644 --- a/tests/test_security_null.cpp +++ b/tests/test_security_null.cpp @@ -158,7 +158,7 @@ int main (void) ip4addr.sin_family = AF_INET; ip4addr.sin_port = htons(9003); -#if (ZMQ_HAVE_WINDOWS and _WIN32_WINNT < 0x0600) +#if defined (ZMQ_HAVE_WINDOWS) && (_WIN32_WINNT < 0x0600) ip4addr.sin_addr.s_addr = inet_addr ("127.0.0.1"); #else inet_pton(AF_INET, "127.0.0.1", &ip4addr.sin_addr); diff --git a/tests/test_security_plain.cpp b/tests/test_security_plain.cpp index 655a1140..a0337f0a 100644 --- a/tests/test_security_plain.cpp +++ b/tests/test_security_plain.cpp @@ -164,10 +164,10 @@ int main (void) ip4addr.sin_family = AF_INET; ip4addr.sin_port = htons (9998); -#if (ZMQ_HAVE_WINDOWS and _WIN32_WINNT < 0x0600) +#if defined (ZMQ_HAVE_WINDOWS) && (_WIN32_WINNT < 0x0600) ip4addr.sin_addr.s_addr = inet_addr ("127.0.0.1"); #else - inet_pton(AF_INET, "127.0.0.1", &ip4addr.sin_addr); + inet_pton (AF_INET, "127.0.0.1", &ip4addr.sin_addr); #endif s = socket (AF_INET, SOCK_STREAM, IPPROTO_TCP); diff --git a/tests/test_stream_exceeds_buffer.cpp b/tests/test_stream_exceeds_buffer.cpp index fe526b73..4c07d00a 100644 --- a/tests/test_stream_exceeds_buffer.cpp +++ b/tests/test_stream_exceeds_buffer.cpp @@ -52,7 +52,7 @@ int main() int server_sock = socket(AF_INET, SOCK_STREAM, 0); assert(server_sock!=-1); int enable = 1; - int rc = setsockopt(server_sock, SOL_SOCKET, SO_REUSEADDR, &enable, sizeof(enable)); + int rc = setsockopt (server_sock, SOL_SOCKET, SO_REUSEADDR, (char *) &enable, sizeof(enable)); assert(rc!=-1); struct sockaddr_in saddr;