Commit 0f473d14 authored by Luca Boccassi's avatar Luca Boccassi

Problem: unnecessary change to router_mandatory_hwm test

Solution:

Revert "Problem with ZMQ_ROUTER_MANDATORY option when peer lost"

This partially reverts commit 06740b5d.

The change in the mentioned commit was fixed to be backward
compatible so test changes are no longer necessary.
Partially revert the commit, leaving only the bug fix and taking out
the test change and the superfluous change in socket_base.
parent ca311f7b
...@@ -1120,13 +1120,7 @@ int zmq::socket_base_t::send (msg_t *msg_, int flags_) ...@@ -1120,13 +1120,7 @@ int zmq::socket_base_t::send (msg_t *msg_, int flags_)
if (rc == 0) { if (rc == 0) {
return 0; return 0;
} }
if (unlikely (errno != EAGAIN)) {
// In case of ZMQ_ROUTER_MANDATORY option set and peer disconnected
if (likely(errno == EHOSTUNREACH)) {
return -1;
}
if (unlikely(errno != EAGAIN)) {
return -1; return -1;
} }
......
...@@ -84,15 +84,11 @@ int main (void) ...@@ -84,15 +84,11 @@ int main (void)
const int BUF_SIZE = 65536; const int BUF_SIZE = 65536;
char buf[BUF_SIZE]; char buf[BUF_SIZE];
memset(buf, 0, BUF_SIZE); memset(buf, 0, BUF_SIZE);
// Send first batch of messages // Send first batch of messages
for(i = 0; i < 100000; ++i) { for(i = 0; i < 100000; ++i) {
if (TRACE_ENABLED) if (TRACE_ENABLED) fprintf(stderr, "Sending message %d ...\n", i);
fprintf(stderr, "Sending message %d ...\n", i);
rc = zmq_send (router, "X", 1, ZMQ_DONTWAIT | ZMQ_SNDMORE); rc = zmq_send (router, "X", 1, ZMQ_DONTWAIT | ZMQ_SNDMORE);
if (rc == -1 && zmq_errno() == EHOSTUNREACH) if (rc == -1 && zmq_errno() == EAGAIN) break;
break;
assert (rc == 1); assert (rc == 1);
rc = zmq_send (router, buf, BUF_SIZE, ZMQ_DONTWAIT); rc = zmq_send (router, buf, BUF_SIZE, ZMQ_DONTWAIT);
assert (rc == BUF_SIZE); assert (rc == BUF_SIZE);
...@@ -100,17 +96,12 @@ int main (void) ...@@ -100,17 +96,12 @@ int main (void)
// This should fail after one message but kernel buffering could // This should fail after one message but kernel buffering could
// skew results // skew results
assert (i < 10); assert (i < 10);
msleep (1000); msleep (1000);
// Send second batch of messages // Send second batch of messages
for(; i < 100000; ++i) { for(; i < 100000; ++i) {
if (TRACE_ENABLED) if (TRACE_ENABLED) fprintf(stderr, "Sending message %d (part 2) ...\n", i);
fprintf(stderr, "Sending message %d (part 2) ...\n", i);
rc = zmq_send (router, "X", 1, ZMQ_DONTWAIT | ZMQ_SNDMORE); rc = zmq_send (router, "X", 1, ZMQ_DONTWAIT | ZMQ_SNDMORE);
if (rc == -1 && zmq_errno() == EHOSTUNREACH) if (rc == -1 && zmq_errno() == EAGAIN) break;
break;
assert (rc == 1); assert (rc == 1);
rc = zmq_send (router, buf, BUF_SIZE, ZMQ_DONTWAIT); rc = zmq_send (router, buf, BUF_SIZE, ZMQ_DONTWAIT);
assert (rc == BUF_SIZE); assert (rc == BUF_SIZE);
...@@ -119,8 +110,7 @@ int main (void) ...@@ -119,8 +110,7 @@ int main (void)
// skew results // skew results
assert (i < 20); assert (i < 20);
if (TRACE_ENABLED) if (TRACE_ENABLED) fprintf(stderr, "Done sending messages.\n");
fprintf(stderr, "Done sending messages.\n");
rc = zmq_close (router); rc = zmq_close (router);
assert (rc == 0); assert (rc == 0);
......
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