mirror of
https://github.com/zeromq/libzmq.git
synced 2025-01-07 09:48:07 +01:00
Problem: test_security_curve fails due to ECONNABORTED
Solution: expect that error, which can happen on very slow machines due to a client timimng out or RST before the connection is accepted by the server
This commit is contained in:
parent
1c1f10a25a
commit
5f6ff69f62
@ -311,8 +311,8 @@ void expect_new_client_curve_bounce_fail (void *ctx,
|
|||||||
// expects that one or more occurrences of the expected event are received
|
// expects that one or more occurrences of the expected event are received
|
||||||
// via the specified socket monitor
|
// via the specified socket monitor
|
||||||
// returns the number of occurrences of the expected event
|
// returns the number of occurrences of the expected event
|
||||||
// interrupts, if a ZMQ_EVENT_HANDSHAKE_FAILED_NO_DETAIL/EPIPE/ECONNRESET
|
// interrupts, if a ZMQ_EVENT_HANDSHAKE_FAILED_NO_DETAIL with EPIPE, ECONNRESET
|
||||||
// occurs; in this case, 0 is returned
|
// or ECONNABORTED occurs; in this case, 0 is returned
|
||||||
// this should be investigated further, see
|
// this should be investigated further, see
|
||||||
// https://github.com/zeromq/libzmq/issues/2644
|
// https://github.com/zeromq/libzmq/issues/2644
|
||||||
int expect_monitor_event_multiple (void *server_mon,
|
int expect_monitor_event_multiple (void *server_mon,
|
||||||
@ -330,11 +330,12 @@ int expect_monitor_event_multiple (void *server_mon,
|
|||||||
!= -1) {
|
!= -1) {
|
||||||
timeout = 250;
|
timeout = 250;
|
||||||
|
|
||||||
// ignore errors with EPIPE/ECONNRESET, which happen sporadically
|
// ignore errors with EPIPE/ECONNRESET/ECONNABORTED, which can happen
|
||||||
// ECONNRESET can happen on very slow machines, when the engine writes
|
// ECONNRESET can happen on very slow machines, when the engine writes
|
||||||
// to the peer and then tries to read the socket before the peer reads
|
// to the peer and then tries to read the socket before the peer reads
|
||||||
|
// 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 == EPIPE || err == ECONNRESET || err == ECONNABORTED)) {
|
||||||
fprintf (stderr, "Ignored event: %x (err = %i)\n", event, err);
|
fprintf (stderr, "Ignored event: %x (err = %i)\n", event, err);
|
||||||
client_closed_connection = 1;
|
client_closed_connection = 1;
|
||||||
break;
|
break;
|
||||||
|
Loading…
Reference in New Issue
Block a user