Commit 980791d1 authored by Simon Giesecke's avatar Simon Giesecke

Problem: test_stream_timeout not yet using unity

Solution: migrate to unity
parent f0168229
...@@ -553,11 +553,12 @@ tests_test_stream_empty_LDADD = src/libzmq.la ${UNITY_LIBS} ...@@ -553,11 +553,12 @@ tests_test_stream_empty_LDADD = src/libzmq.la ${UNITY_LIBS}
tests_test_stream_empty_CPPFLAGS = ${UNITY_CPPFLAGS} tests_test_stream_empty_CPPFLAGS = ${UNITY_CPPFLAGS}
tests_test_stream_timeout_SOURCES = tests/test_stream_timeout.cpp tests_test_stream_timeout_SOURCES = tests/test_stream_timeout.cpp
tests_test_stream_timeout_LDADD = src/libzmq.la tests_test_stream_timeout_LDADD = src/libzmq.la ${UNITY_LIBS}
tests_test_stream_timeout_CPPFLAGS = ${UNITY_CPPFLAGS}
tests_test_stream_disconnect_SOURCES = tests/test_stream_disconnect.cpp tests_test_stream_disconnect_SOURCES = tests/test_stream_disconnect.cpp
tests_test_stream_disconnect_LDADD = src/libzmq.la ${UNITY_LIBS} tests_test_stream_disconnect_LDADD = src/libzmq.la ${UNITY_LIBS}
tests_test_stream_empty_CPPFLAGS = ${UNITY_CPPFLAGS} tests_test_stream_disconnect_CPPFLAGS = ${UNITY_CPPFLAGS}
tests_test_disconnect_inproc_SOURCES = tests/test_disconnect_inproc.cpp tests_test_disconnect_inproc_SOURCES = tests/test_disconnect_inproc.cpp
tests_test_disconnect_inproc_LDADD = src/libzmq.la tests_test_disconnect_inproc_LDADD = src/libzmq.la
......
...@@ -28,6 +28,17 @@ ...@@ -28,6 +28,17 @@
*/ */
#include "testutil.hpp" #include "testutil.hpp"
#include "testutil_unity.hpp"
void setUp ()
{
setup_test_context ();
}
void tearDown ()
{
teardown_test_context ();
}
// Read one event off the monitor socket; return value and address // Read one event off the monitor socket; return value and address
// by reference, if not null, and event number by value. Returns -1 // by reference, if not null, and event number by value. Returns -1
...@@ -40,7 +51,7 @@ static int get_monitor_event (void *monitor_, int *value_, char **address_) ...@@ -40,7 +51,7 @@ static int get_monitor_event (void *monitor_, int *value_, char **address_)
zmq_msg_init (&msg); zmq_msg_init (&msg);
if (zmq_msg_recv (&msg, monitor_, 0) == -1) if (zmq_msg_recv (&msg, monitor_, 0) == -1)
return -1; // Interruped, presumably return -1; // Interruped, presumably
assert (zmq_msg_more (&msg)); TEST_ASSERT_TRUE (zmq_msg_more (&msg));
uint8_t *data = (uint8_t *) zmq_msg_data (&msg); uint8_t *data = (uint8_t *) zmq_msg_data (&msg);
uint16_t event = *(uint16_t *) (data); uint16_t event = *(uint16_t *) (data);
...@@ -51,7 +62,7 @@ static int get_monitor_event (void *monitor_, int *value_, char **address_) ...@@ -51,7 +62,7 @@ static int get_monitor_event (void *monitor_, int *value_, char **address_)
zmq_msg_init (&msg); zmq_msg_init (&msg);
if (zmq_msg_recv (&msg, monitor_, 0) == -1) if (zmq_msg_recv (&msg, monitor_, 0) == -1)
return -1; // Interruped, presumably return -1; // Interruped, presumably
assert (!zmq_msg_more (&msg)); TEST_ASSERT_TRUE (!zmq_msg_more (&msg));
if (address_) { if (address_) {
uint8_t *data = (uint8_t *) zmq_msg_data (&msg); uint8_t *data = (uint8_t *) zmq_msg_data (&msg);
...@@ -63,172 +74,132 @@ static int get_monitor_event (void *monitor_, int *value_, char **address_) ...@@ -63,172 +74,132 @@ static int get_monitor_event (void *monitor_, int *value_, char **address_)
return event; return event;
} }
static void test_stream_handshake_timeout_accept (void) static void test_stream_handshake_timeout_accept ()
{ {
int rc;
size_t len = MAX_SOCKET_STRING;
char my_endpoint[MAX_SOCKET_STRING]; char my_endpoint[MAX_SOCKET_STRING];
// Set up our context and sockets
void *ctx = zmq_ctx_new ();
assert (ctx);
// We use this socket in raw mode, to make a connection and send nothing // We use this socket in raw mode, to make a connection and send nothing
void *stream = zmq_socket (ctx, ZMQ_STREAM); void *stream = test_context_socket (ZMQ_STREAM);
assert (stream);
int zero = 0; int zero = 0;
rc = zmq_setsockopt (stream, ZMQ_LINGER, &zero, sizeof (zero)); TEST_ASSERT_SUCCESS_ERRNO (
assert (rc == 0); zmq_setsockopt (stream, ZMQ_LINGER, &zero, sizeof (zero)));
// We'll be using this socket to test TCP stream handshake timeout // We'll be using this socket to test TCP stream handshake timeout
void *dealer = zmq_socket (ctx, ZMQ_DEALER); void *dealer = test_context_socket (ZMQ_DEALER);
assert (dealer); TEST_ASSERT_SUCCESS_ERRNO (
rc = zmq_setsockopt (dealer, ZMQ_LINGER, &zero, sizeof (zero)); zmq_setsockopt (dealer, ZMQ_LINGER, &zero, sizeof (zero)));
assert (rc == 0);
int val, tenth = 100; int val, tenth = 100;
size_t vsize = sizeof (val); size_t vsize = sizeof (val);
// check for the expected default handshake timeout value - 30 sec // check for the expected default handshake timeout value - 30 sec
rc = zmq_getsockopt (dealer, ZMQ_HANDSHAKE_IVL, &val, &vsize); TEST_ASSERT_SUCCESS_ERRNO (
assert (rc == 0); zmq_getsockopt (dealer, ZMQ_HANDSHAKE_IVL, &val, &vsize));
assert (vsize == sizeof (val)); TEST_ASSERT_EQUAL (sizeof (val), vsize);
assert (val == 30000); TEST_ASSERT_EQUAL_INT (30000, val);
// make handshake timeout faster - 1/10 sec // make handshake timeout faster - 1/10 sec
rc = zmq_setsockopt (dealer, ZMQ_HANDSHAKE_IVL, &tenth, sizeof (tenth)); TEST_ASSERT_SUCCESS_ERRNO (
assert (rc == 0); zmq_setsockopt (dealer, ZMQ_HANDSHAKE_IVL, &tenth, sizeof (tenth)));
vsize = sizeof (val); vsize = sizeof (val);
// make sure zmq_setsockopt changed the value // make sure zmq_setsockopt changed the value
rc = zmq_getsockopt (dealer, ZMQ_HANDSHAKE_IVL, &val, &vsize); TEST_ASSERT_SUCCESS_ERRNO (
assert (rc == 0); zmq_getsockopt (dealer, ZMQ_HANDSHAKE_IVL, &val, &vsize));
assert (vsize == sizeof (val)); TEST_ASSERT_EQUAL (sizeof (val), vsize);
assert (val == tenth); TEST_ASSERT_EQUAL_INT (tenth, val);
// Create and connect a socket for collecting monitor events on dealer // Create and connect a socket for collecting monitor events on dealer
void *dealer_mon = zmq_socket (ctx, ZMQ_PAIR); void *dealer_mon = test_context_socket (ZMQ_PAIR);
assert (dealer_mon);
rc = zmq_socket_monitor (dealer, "inproc://monitor-dealer", TEST_ASSERT_SUCCESS_ERRNO (zmq_socket_monitor (
ZMQ_EVENT_CONNECTED | ZMQ_EVENT_DISCONNECTED dealer, "inproc://monitor-dealer",
| ZMQ_EVENT_ACCEPTED); ZMQ_EVENT_CONNECTED | ZMQ_EVENT_DISCONNECTED | ZMQ_EVENT_ACCEPTED));
assert (rc == 0);
// Connect to the inproc endpoint so we'll get events // Connect to the inproc endpoint so we'll get events
rc = zmq_connect (dealer_mon, "inproc://monitor-dealer"); TEST_ASSERT_SUCCESS_ERRNO (
assert (rc == 0); zmq_connect (dealer_mon, "inproc://monitor-dealer"));
// bind dealer socket to accept connection from non-sending stream socket // bind dealer socket to accept connection from non-sending stream socket
rc = zmq_bind (dealer, "tcp://127.0.0.1:*"); bind_loopback_ipv4 (dealer, my_endpoint, sizeof my_endpoint);
assert (rc == 0);
rc = zmq_getsockopt (dealer, ZMQ_LAST_ENDPOINT, my_endpoint, &len);
assert (rc == 0);
rc = zmq_connect (stream, my_endpoint); TEST_ASSERT_SUCCESS_ERRNO (zmq_connect (stream, my_endpoint));
assert (rc == 0);
// we should get ZMQ_EVENT_ACCEPTED and then ZMQ_EVENT_DISCONNECTED // we should get ZMQ_EVENT_ACCEPTED and then ZMQ_EVENT_DISCONNECTED
int event = get_monitor_event (dealer_mon, NULL, NULL); int event = get_monitor_event (dealer_mon, NULL, NULL);
assert (event == ZMQ_EVENT_ACCEPTED); TEST_ASSERT_EQUAL_INT (ZMQ_EVENT_ACCEPTED, event);
event = get_monitor_event (dealer_mon, NULL, NULL); event = get_monitor_event (dealer_mon, NULL, NULL);
assert (event == ZMQ_EVENT_DISCONNECTED); TEST_ASSERT_EQUAL_INT (ZMQ_EVENT_DISCONNECTED, event);
rc = zmq_close (dealer);
assert (rc == 0);
rc = zmq_close (dealer_mon); test_context_socket_close (dealer);
assert (rc == 0); test_context_socket_close (dealer_mon);
test_context_socket_close (stream);
rc = zmq_close (stream);
assert (rc == 0);
rc = zmq_ctx_term (ctx);
assert (rc == 0);
} }
static void test_stream_handshake_timeout_connect (void) static void test_stream_handshake_timeout_connect ()
{ {
int rc;
size_t len = MAX_SOCKET_STRING;
char my_endpoint[MAX_SOCKET_STRING]; char my_endpoint[MAX_SOCKET_STRING];
// Set up our context and sockets
void *ctx = zmq_ctx_new ();
assert (ctx);
// We use this socket in raw mode, to accept a connection and send nothing // We use this socket in raw mode, to accept a connection and send nothing
void *stream = zmq_socket (ctx, ZMQ_STREAM); void *stream = test_context_socket (ZMQ_STREAM);
assert (stream);
int zero = 0; int zero = 0;
rc = zmq_setsockopt (stream, ZMQ_LINGER, &zero, sizeof (zero)); TEST_ASSERT_SUCCESS_ERRNO (
assert (rc == 0); zmq_setsockopt (stream, ZMQ_LINGER, &zero, sizeof (zero)));
rc = zmq_bind (stream, "tcp://127.0.0.1:*");
assert (rc == 0); bind_loopback_ipv4 (stream, my_endpoint, sizeof my_endpoint);
rc = zmq_getsockopt (stream, ZMQ_LAST_ENDPOINT, my_endpoint, &len);
assert (rc == 0);
// We'll be using this socket to test TCP stream handshake timeout // We'll be using this socket to test TCP stream handshake timeout
void *dealer = zmq_socket (ctx, ZMQ_DEALER); void *dealer = test_context_socket (ZMQ_DEALER);
assert (dealer); TEST_ASSERT_SUCCESS_ERRNO (
rc = zmq_setsockopt (dealer, ZMQ_LINGER, &zero, sizeof (zero)); zmq_setsockopt (dealer, ZMQ_LINGER, &zero, sizeof (zero)));
assert (rc == 0);
int val, tenth = 100; int val, tenth = 100;
size_t vsize = sizeof (val); size_t vsize = sizeof (val);
// check for the expected default handshake timeout value - 30 sec // check for the expected default handshake timeout value - 30 sec
rc = zmq_getsockopt (dealer, ZMQ_HANDSHAKE_IVL, &val, &vsize); TEST_ASSERT_SUCCESS_ERRNO (
assert (rc == 0); zmq_getsockopt (dealer, ZMQ_HANDSHAKE_IVL, &val, &vsize));
assert (vsize == sizeof (val)); TEST_ASSERT_EQUAL (sizeof (val), vsize);
assert (val == 30000); TEST_ASSERT_EQUAL_INT (30000, val);
// make handshake timeout faster - 1/10 sec // make handshake timeout faster - 1/10 sec
rc = zmq_setsockopt (dealer, ZMQ_HANDSHAKE_IVL, &tenth, sizeof (tenth)); TEST_ASSERT_SUCCESS_ERRNO (
assert (rc == 0); zmq_setsockopt (dealer, ZMQ_HANDSHAKE_IVL, &tenth, sizeof (tenth)));
vsize = sizeof (val); vsize = sizeof (val);
// make sure zmq_setsockopt changed the value // make sure zmq_setsockopt changed the value
rc = zmq_getsockopt (dealer, ZMQ_HANDSHAKE_IVL, &val, &vsize); TEST_ASSERT_SUCCESS_ERRNO (
assert (rc == 0); zmq_getsockopt (dealer, ZMQ_HANDSHAKE_IVL, &val, &vsize));
assert (vsize == sizeof (val)); TEST_ASSERT_EQUAL (sizeof (val), vsize);
assert (val == tenth); TEST_ASSERT_EQUAL_INT (tenth, val);
// Create and connect a socket for collecting monitor events on dealer // Create and connect a socket for collecting monitor events on dealer
void *dealer_mon = zmq_socket (ctx, ZMQ_PAIR); void *dealer_mon = test_context_socket (ZMQ_PAIR);
assert (dealer_mon);
rc = zmq_socket_monitor (dealer, "inproc://monitor-dealer", TEST_ASSERT_SUCCESS_ERRNO (zmq_socket_monitor (
ZMQ_EVENT_CONNECTED | ZMQ_EVENT_DISCONNECTED dealer, "inproc://monitor-dealer",
| ZMQ_EVENT_ACCEPTED); ZMQ_EVENT_CONNECTED | ZMQ_EVENT_DISCONNECTED | ZMQ_EVENT_ACCEPTED));
assert (rc == 0);
// Connect to the inproc endpoint so we'll get events // Connect to the inproc endpoint so we'll get events
rc = zmq_connect (dealer_mon, "inproc://monitor-dealer"); TEST_ASSERT_SUCCESS_ERRNO (
assert (rc == 0); zmq_connect (dealer_mon, "inproc://monitor-dealer"));
// connect dealer socket to non-sending stream socket // connect dealer socket to non-sending stream socket
rc = zmq_connect (dealer, my_endpoint); TEST_ASSERT_SUCCESS_ERRNO (zmq_connect (dealer, my_endpoint));
assert (rc == 0);
// we should get ZMQ_EVENT_CONNECTED and then ZMQ_EVENT_DISCONNECTED // we should get ZMQ_EVENT_CONNECTED and then ZMQ_EVENT_DISCONNECTED
int event = get_monitor_event (dealer_mon, NULL, NULL); int event = get_monitor_event (dealer_mon, NULL, NULL);
assert (event == ZMQ_EVENT_CONNECTED); TEST_ASSERT_EQUAL_INT (ZMQ_EVENT_CONNECTED, event);
event = get_monitor_event (dealer_mon, NULL, NULL); event = get_monitor_event (dealer_mon, NULL, NULL);
assert (event == ZMQ_EVENT_DISCONNECTED); TEST_ASSERT_EQUAL_INT (ZMQ_EVENT_DISCONNECTED, event);
rc = zmq_close (dealer); test_context_socket_close (dealer);
assert (rc == 0); test_context_socket_close (dealer_mon);
test_context_socket_close (stream);
rc = zmq_close (dealer_mon);
assert (rc == 0);
rc = zmq_close (stream);
assert (rc == 0);
rc = zmq_ctx_term (ctx);
assert (rc == 0);
} }
int main (void) int main ()
{ {
setup_test_environment (); setup_test_environment ();
test_stream_handshake_timeout_accept ();
test_stream_handshake_timeout_connect (); UNITY_BEGIN ();
RUN_TEST (test_stream_handshake_timeout_accept);
RUN_TEST (test_stream_handshake_timeout_connect);
return UNITY_END ();
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment