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:
parent
612d81a831
commit
834b9e4cd7
@ -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);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user