0
0
mirror of https://github.com/zeromq/libzmq.git synced 2025-01-14 09:47:56 +08:00

Problem: some test cases may still fail because of EPIPE/ECONNABORT/ECONNRESET (#2664)

* Problem: CI failure on Appveyor with err==ECONNRESET

Solution: ignore ECONNRESET analogous to EPIPE

* Problem: blocking test execution

Solution: added more debug output, do not wait for monitor infinitely without output
This commit is contained in:
Simon Giesecke 2017-08-07 18:07:37 +02:00 committed by Luca Boccassi
parent 612d81a831
commit 834b9e4cd7

View File

@ -54,7 +54,7 @@ void *zap_requests_handled;
// in case of error. // in case of error.
static int static int
get_monitor_event (void *monitor, int *value, char **address, int recv_flag) get_monitor_event_internal (void *monitor, int *value, char **address, int recv_flag)
{ {
// First frame in message contains event number and value // First frame in message contains event number and value
zmq_msg_t msg; zmq_msg_t msg;
@ -91,8 +91,25 @@ int get_monitor_event_with_timeout (void *monitor,
char **address, char **address,
int timeout) int timeout)
{ {
zmq_setsockopt (monitor, ZMQ_RCVTIMEO, &timeout, sizeof (timeout)); int res;
int res = get_monitor_event (monitor, value, address, 0); if (timeout == -1) {
// process infinite timeout in small steps to allow the user
// to see some information on the console
int timeout_step = 250;
int wait_time = 0;
zmq_setsockopt (monitor, ZMQ_RCVTIMEO, &timeout_step,
sizeof (timeout_step));
while ((res = get_monitor_event_internal (monitor, value, address, 0))
== -1) {
wait_time += timeout_step;
fprintf (stderr, "Still waiting for monitor event after %i ms\n",
wait_time);
}
} else {
zmq_setsockopt (monitor, ZMQ_RCVTIMEO, &timeout, sizeof (timeout));
res = get_monitor_event_internal (monitor, value, address, 0);
}
int timeout_infinite = -1; int timeout_infinite = -1;
zmq_setsockopt (monitor, ZMQ_RCVTIMEO, &timeout_infinite, zmq_setsockopt (monitor, ZMQ_RCVTIMEO, &timeout_infinite,
sizeof (timeout_infinite)); sizeof (timeout_infinite));
@ -114,22 +131,6 @@ int get_monitor_event_with_timeout (void *monitor,
assert (event_count == 0); \ assert (event_count == 0); \
} }
#define assert_monitor_event(monitor, expected_events) \
{ \
int err; \
int event = get_monitor_event (monitor, &err, NULL, 0); \
assert (event != -1); \
if ((event & (expected_events)) == 0) { \
fprintf (stderr, "Unexpected event: %x (err = %i)\n", event, err); \
while ( \
(event = get_monitor_event (monitor, NULL, NULL, (timeout))) \
!= -1) { \
fprintf (stderr, "Further event: %x\n", event); \
} \
assert (false); \
} \
}
#endif #endif
// -------------------------------------------------------------------------- // --------------------------------------------------------------------------
@ -336,7 +337,10 @@ int expect_monitor_event_multiple (void *server_mon,
// ECONNABORTED happens when a client aborts a connection via RST/timeout // ECONNABORTED happens when a client aborts a connection via RST/timeout
if (event == ZMQ_EVENT_HANDSHAKE_FAILED_NO_DETAIL && if (event == ZMQ_EVENT_HANDSHAKE_FAILED_NO_DETAIL &&
(err == EPIPE || err == ECONNRESET || err == ECONNABORTED)) { (err == EPIPE || err == ECONNRESET || err == ECONNABORTED)) {
fprintf (stderr, "Ignored event: %x (err = %i)\n", event, err); fprintf (
stderr,
"Ignored event (skipping any further events): %x (err = %i)\n",
event, err);
client_closed_connection = 1; client_closed_connection = 1;
break; break;
} }
@ -490,7 +494,7 @@ void test_curve_security_with_valid_credentials (
assert (rc == 0); assert (rc == 0);
#ifdef ZMQ_BUILD_DRAFT_API #ifdef ZMQ_BUILD_DRAFT_API
int event = get_monitor_event (server_mon, NULL, NULL, 0); int event = get_monitor_event_with_timeout (server_mon, NULL, NULL, -1);
assert (event == ZMQ_EVENT_HANDSHAKE_SUCCEEDED); assert (event == ZMQ_EVENT_HANDSHAKE_SUCCEEDED);
assert_no_more_monitor_events_with_timeout (server_mon, timeout); assert_no_more_monitor_events_with_timeout (server_mon, timeout);
@ -509,7 +513,7 @@ void test_curve_security_with_bogus_client_credentials (
bogus_secret, my_endpoint, server); bogus_secret, my_endpoint, server);
#ifdef ZMQ_BUILD_DRAFT_API #ifdef ZMQ_BUILD_DRAFT_API
int event = get_monitor_event (server_mon, NULL, NULL, 0); int event = get_monitor_event_with_timeout (server_mon, NULL, NULL, -1);
// TODO add another event type ZMQ_EVENT_HANDSHAKE_FAILED_AUTH for this case? // TODO add another event type ZMQ_EVENT_HANDSHAKE_FAILED_AUTH for this case?
assert ( assert (
event event
@ -532,7 +536,7 @@ void expect_zmtp_failure (void *client, char *my_endpoint, void *server, void *s
#ifdef ZMQ_BUILD_DRAFT_API #ifdef ZMQ_BUILD_DRAFT_API
int err; int err;
int event = get_monitor_event (server_mon, &err, NULL, 0); int event = get_monitor_event_with_timeout (server_mon, &err, NULL, -1);
assert (event == ZMQ_EVENT_HANDSHAKE_FAILED_ZMTP assert (event == ZMQ_EVENT_HANDSHAKE_FAILED_ZMTP
|| (event == ZMQ_EVENT_HANDSHAKE_FAILED_NO_DETAIL && err == EPIPE)); || (event == ZMQ_EVENT_HANDSHAKE_FAILED_NO_DETAIL && err == EPIPE));
@ -618,7 +622,7 @@ void test_curve_security_zap_unsuccessful (void *ctx,
int events_received = 0; int events_received = 0;
#ifdef ZMQ_BUILD_DRAFT_API #ifdef ZMQ_BUILD_DRAFT_API
events_received = events_received =
expect_monitor_event_multiple (server_mon, expected_event, expected_err); expect_monitor_event_multiple (server_mon, expected_event, expected_err);
#endif #endif
// there may be more than one ZAP request due to repeated attempts by the client // there may be more than one ZAP request due to repeated attempts by the client
@ -682,6 +686,7 @@ int main (void)
void *server_mon; void *server_mon;
char my_endpoint [MAX_SOCKET_STRING]; char my_endpoint [MAX_SOCKET_STRING];
fprintf (stderr, "test_curve_security_with_valid_credentials\n");
setup_context_and_server_side (&ctx, &handler, &zap_thread, &server, setup_context_and_server_side (&ctx, &handler, &zap_thread, &server,
&server_mon, my_endpoint); &server_mon, my_endpoint);
test_curve_security_with_valid_credentials (ctx, my_endpoint, server, test_curve_security_with_valid_credentials (ctx, my_endpoint, server,
@ -721,6 +726,7 @@ int main (void)
shutdown_context_and_server_side (ctx, zap_thread, server, server_mon, shutdown_context_and_server_side (ctx, zap_thread, server, server_mon,
handler); handler);
fprintf (stderr, "test_curve_security_with_bogus_client_credentials\n");
setup_context_and_server_side (&ctx, &handler, &zap_thread, &server, setup_context_and_server_side (&ctx, &handler, &zap_thread, &server,
&server_mon, my_endpoint); &server_mon, my_endpoint);
test_curve_security_with_bogus_client_credentials (ctx, my_endpoint, server, test_curve_security_with_bogus_client_credentials (ctx, my_endpoint, server,
@ -728,6 +734,7 @@ int main (void)
shutdown_context_and_server_side (ctx, zap_thread, server, server_mon, shutdown_context_and_server_side (ctx, zap_thread, server, server_mon,
handler); handler);
fprintf (stderr, "test_curve_security_with_null_client_credentials\n");
setup_context_and_server_side (&ctx, &handler, &zap_thread, &server, setup_context_and_server_side (&ctx, &handler, &zap_thread, &server,
&server_mon, my_endpoint); &server_mon, my_endpoint);
test_curve_security_with_null_client_credentials (ctx, my_endpoint, server, test_curve_security_with_null_client_credentials (ctx, my_endpoint, server,
@ -735,6 +742,7 @@ int main (void)
shutdown_context_and_server_side (ctx, zap_thread, server, server_mon, shutdown_context_and_server_side (ctx, zap_thread, server, server_mon,
handler); handler);
fprintf (stderr, "test_curve_security_with_plain_client_credentials\n");
setup_context_and_server_side (&ctx, &handler, &zap_thread, &server, setup_context_and_server_side (&ctx, &handler, &zap_thread, &server,
&server_mon, my_endpoint); &server_mon, my_endpoint);
test_curve_security_with_plain_client_credentials (ctx, my_endpoint, server, test_curve_security_with_plain_client_credentials (ctx, my_endpoint, server,
@ -742,6 +750,7 @@ int main (void)
shutdown_context_and_server_side (ctx, zap_thread, server, server_mon, shutdown_context_and_server_side (ctx, zap_thread, server, server_mon,
handler); handler);
fprintf (stderr, "test_curve_security_unauthenticated_message\n");
setup_context_and_server_side (&ctx, &handler, &zap_thread, &server, setup_context_and_server_side (&ctx, &handler, &zap_thread, &server,
&server_mon, my_endpoint); &server_mon, my_endpoint);
test_curve_security_unauthenticated_message (my_endpoint, server, timeout); test_curve_security_unauthenticated_message (my_endpoint, server, timeout);
@ -751,6 +760,7 @@ int main (void)
// Invalid ZAP protocol tests // Invalid ZAP protocol tests
// wrong version // wrong version
fprintf (stderr, "test_curve_security_zap_protocol_error wrong_version\n");
setup_context_and_server_side (&ctx, &handler, &zap_thread, &server, setup_context_and_server_side (&ctx, &handler, &zap_thread, &server,
&server_mon, my_endpoint, &server_mon, my_endpoint,
&zap_handler_wrong_version); &zap_handler_wrong_version);
@ -760,6 +770,7 @@ int main (void)
handler); handler);
// wrong request id // wrong request id
fprintf (stderr, "test_curve_security_zap_protocol_error wrong_request_id\n");
setup_context_and_server_side (&ctx, &handler, &zap_thread, &server, setup_context_and_server_side (&ctx, &handler, &zap_thread, &server,
&server_mon, my_endpoint, &server_mon, my_endpoint,
&zap_handler_wrong_request_id); &zap_handler_wrong_request_id);
@ -769,6 +780,7 @@ int main (void)
handler); handler);
// status invalid (not a 3-digit number) // status invalid (not a 3-digit number)
fprintf (stderr, "test_curve_security_zap_protocol_error wrong_status_invalid\n");
setup_context_and_server_side (&ctx, &handler, &zap_thread, &server, setup_context_and_server_side (&ctx, &handler, &zap_thread, &server,
&server_mon, my_endpoint, &server_mon, my_endpoint,
&zap_handler_wrong_status_invalid); &zap_handler_wrong_status_invalid);
@ -778,6 +790,7 @@ int main (void)
handler); handler);
// too many parts // too many parts
fprintf (stderr, "test_curve_security_zap_protocol_error too_many_parts\n");
setup_context_and_server_side (&ctx, &handler, &zap_thread, &server, setup_context_and_server_side (&ctx, &handler, &zap_thread, &server,
&server_mon, my_endpoint, &server_mon, my_endpoint,
&zap_handler_too_many_parts); &zap_handler_too_many_parts);