Merge pull request #721 from minrk/init-raw

add missing msg->init for ROUTER_RAW with empty message
This commit is contained in:
Richard Newton 2013-10-28 01:19:00 -07:00
commit c9772d0a5c
3 changed files with 69 additions and 0 deletions

View File

@ -225,6 +225,8 @@ int zmq::router_t::xsend (msg_t *msg_)
current_out->terminate (false); current_out->terminate (false);
int rc = msg_->close (); int rc = msg_->close ();
errno_assert (rc == 0); errno_assert (rc == 0);
rc = msg_->init ();
errno_assert (rc == 0);
current_out = NULL; current_out = NULL;
return 0; return 0;
} }

View File

@ -20,6 +20,7 @@ noinst_PROGRAMS = test_system \
test_linger \ test_linger \
test_monitor \ test_monitor \
test_router_mandatory \ test_router_mandatory \
test_router_raw_empty \
test_probe_router \ test_probe_router \
test_stream \ test_stream \
test_disconnect_inproc \ test_disconnect_inproc \
@ -67,6 +68,7 @@ test_last_endpoint_SOURCES = test_last_endpoint.cpp
test_term_endpoint_SOURCES = test_term_endpoint.cpp test_term_endpoint_SOURCES = test_term_endpoint.cpp
test_monitor_SOURCES = test_monitor.cpp test_monitor_SOURCES = test_monitor.cpp
test_router_mandatory_SOURCES = test_router_mandatory.cpp test_router_mandatory_SOURCES = test_router_mandatory.cpp
test_router_raw_empty_SOURCES = test_router_raw_empty.cpp
test_probe_router_SOURCES = test_probe_router.cpp test_probe_router_SOURCES = test_probe_router.cpp
test_stream_SOURCES = test_stream.cpp test_stream_SOURCES = test_stream.cpp
test_disconnect_inproc_SOURCES = test_disconnect_inproc.cpp test_disconnect_inproc_SOURCES = test_disconnect_inproc.cpp

View File

@ -0,0 +1,65 @@
/*
Copyright (c) 2007-2013 Contributors as noted in the AUTHORS file
This file is part of 0MQ.
0MQ is free software; you can redistribute it and/or modify it under
the terms of the GNU Lesser General Public License as published by
the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.
0MQ is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "testutil.hpp"
int main (void) {
setup_test_environment();
void *ctx = zmq_ctx_new();
assert(ctx);
void *router = zmq_socket(ctx, ZMQ_ROUTER);
assert(router);
void *dealer = zmq_socket(ctx, ZMQ_DEALER);
assert(dealer);
int one=1;
int rc = zmq_setsockopt(router, ZMQ_ROUTER_RAW, &one, sizeof(int));
assert(rc >= 0);
rc = zmq_setsockopt(router, ZMQ_ROUTER_MANDATORY, &one, sizeof(int));
assert(rc >= 0);
rc = zmq_bind(router, "tcp://127.0.0.1:5555");
rc = zmq_connect(dealer, "tcp://127.0.0.1:5555");
zmq_send(dealer, "", 0, 0);
zmq_msg_t ident, empty, echo;
zmq_msg_init(&ident);
rc = zmq_msg_recv(&ident, router, 0);
assert(rc >= 0);
rc = zmq_msg_init_data(&empty, (void*)"", 0, NULL, NULL);
assert(rc >= 0);
rc = zmq_msg_send(&ident, router, ZMQ_SNDMORE);
assert(rc >= 0);
rc = zmq_msg_close(&ident);
assert(rc >= 0);
rc = zmq_msg_send(&empty, router, 0);
assert(rc >= 0);
// This close used to fail with Bad Address
rc = zmq_msg_close(&empty);
assert(rc >= 0);
close_zero_linger(dealer);
close_zero_linger(router);
zmq_ctx_term(ctx);
}