summaryrefslogtreecommitdiff
path: root/tests/pubsub_udp.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'tests/pubsub_udp.cpp')
-rw-r--r--tests/pubsub_udp.cpp90
1 files changed, 90 insertions, 0 deletions
diff --git a/tests/pubsub_udp.cpp b/tests/pubsub_udp.cpp
new file mode 100644
index 0000000..e981457
--- /dev/null
+++ b/tests/pubsub_udp.cpp
@@ -0,0 +1,90 @@
+/*
+ Copyright (c) 2012 Martin Lucina <martin@lucina.net>
+
+ This file is part of Crossroads I/O.
+
+ Crossroads I/O 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.
+
+ Crossroads I/O 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 XS_TEST_MAIN ()
+{
+ fprintf (stderr, "pubsub_udp test running...\n");
+
+ void *ctx = xs_init ();
+ assert (ctx);
+
+ void *pub = xs_socket (ctx, XS_PUB);
+ assert (pub);
+ int rc = xs_bind (pub, "udp://127.0.0.1:5555");
+ assert (rc != -1);
+
+ void *sub = xs_socket (ctx, XS_SUB);
+ assert (sub);
+ rc = xs_connect (sub, "udp://127.0.0.1:5555");
+ assert (rc != -1);
+ rc = xs_setsockopt (sub, XS_SUBSCRIBE, "", 0);
+ assert (rc == 0);
+
+ const char *content = "12345678ABCDEFGH12345678abcdefgh";
+
+ // TODO: Due to a core bug, the first message on a PUB/SUB socket
+ // is always lost. For now just send a dummy message.
+ rc = xs_send (pub, "", 0, 0);
+ assert (rc == 0);
+
+ // Send a message with two identical parts.
+ rc = xs_send (pub, content, 32, XS_SNDMORE);
+ assert (rc == 32);
+ rc = xs_send (pub, content, 32, 0);
+ assert (rc == 32);
+
+ // Receive the first part.
+ char rcvbuf [32];
+ int rcvmore = 0;
+ size_t rcvmore_sz = sizeof rcvmore;
+ rc = xs_recv (sub, rcvbuf, 32, 0);
+ assert (rc == 32);
+ rc = xs_getsockopt (sub, XS_RCVMORE, &rcvmore, &rcvmore_sz);
+ assert (rc == 0);
+
+ // There must be one more part to receive.
+ assert (rcvmore);
+ // And the content must match what was sent.
+ assert (memcmp (rcvbuf, content, 32) == 0);
+
+ // Receive the second part.
+ rc = xs_recv (sub, rcvbuf, 32, 0);
+ assert (rc == 32);
+ rcvmore_sz = sizeof rcvmore;
+ rc = xs_getsockopt (sub, XS_RCVMORE, &rcvmore, &rcvmore_sz);
+ assert (rc == 0);
+
+ // There must not be another part.
+ assert (!rcvmore);
+ // And the content must match what was sent.
+ assert (memcmp (rcvbuf, content, 32) == 0);
+
+ rc = xs_close (pub);
+ assert (rc == 0);
+
+ rc = xs_close (sub);
+ assert (rc == 0);
+
+ rc = xs_term (ctx);
+ assert (rc == 0);
+
+ return 0 ;
+}