aboutsummaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorBehrooze Sirang <behrooze.sirang@postmates.com>2019-04-09 17:37:46 -0700
committerGarrett D'Amore <garrett@damore.org>2019-04-11 21:31:07 -0700
commit90467583b7544b68483334070518e29b00ec6d81 (patch)
treeca31612c9c7e8373e9f3afbbeb432c44297c7a2c /tests
parentc3e062661388f70386d6766e3ce648030af340ee (diff)
downloadnng-90467583b7544b68483334070518e29b00ec6d81.tar.gz
nng-90467583b7544b68483334070518e29b00ec6d81.tar.bz2
nng-90467583b7544b68483334070518e29b00ec6d81.zip
fixes #919 Polling on subscriber socket recvfd seems broken
sub0_recv_cb was not calling nni_pollable_raise on sock->recvable.
Diffstat (limited to 'tests')
-rw-r--r--tests/CMakeLists.txt1
-rw-r--r--tests/pubsubpollfd.c125
2 files changed, 126 insertions, 0 deletions
diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt
index 99eceaaf..60bfed2e 100644
--- a/tests/CMakeLists.txt
+++ b/tests/CMakeLists.txt
@@ -160,6 +160,7 @@ add_nng_test(options 5)
add_nng_test(pipe 5)
add_nng_test(platform 5)
add_nng_test(pollfd 5)
+add_nng_test(pubsubpollfd 5)
add_nng_test(reconnect 5)
add_nng_test1(resolv 10 NNG_STATIC_LIB)
add_nng_test(scalability 20 ON)
diff --git a/tests/pubsubpollfd.c b/tests/pubsubpollfd.c
new file mode 100644
index 00000000..6a41d5f9
--- /dev/null
+++ b/tests/pubsubpollfd.c
@@ -0,0 +1,125 @@
+//
+// Copyright 2018 Staysail Systems, Inc. <info@staysail.tech>
+// Copyright 2018 Capitar IT Group BV <info@capitar.com>
+// Copyright 2019 Behrooze Sirang <behrooze@gmail.com>
+//
+// This software is supplied under the terms of the MIT License, a
+// copy of which should be located in the distribution where this
+// file was obtained (LICENSE.txt). A copy of the license may also be
+// found online at https://opensource.org/licenses/MIT.
+//
+
+#include <string.h>
+
+#ifndef _WIN32
+#include <poll.h>
+#include <unistd.h>
+#define INVALID_SOCKET -1
+#else
+
+#define poll WSAPoll
+#ifndef WIN32_LEAN_AND_MEAN
+#define WIN32_LEAN_AND_MEAN
+#endif
+
+#include <windows.h>
+#include <winsock2.h>
+
+#include <mswsock.h>
+#include <ws2tcpip.h>
+
+#endif
+
+#include <nng/nng.h>
+#include <nng/protocol/pubsub0/sub.h>
+#include <nng/protocol/pubsub0/pub.h>
+#include <nng/supplemental/util/platform.h>
+
+#include "convey.h"
+#include "stubs.h"
+
+TestMain("PUBSUB pollable", {
+ Convey("Given a connected pair of sockets", {
+ nng_socket s1;
+ nng_socket s2;
+
+ So(nng_pub0_open(&s1) == 0);
+ So(nng_sub0_open(&s2) == 0);
+ Reset({
+ nng_close(s1);
+ nng_close(s2);
+ });
+ So(nng_listen(s1, "inproc://yeahbaby", NULL, 0) == 0);
+ So(nng_dial(s2, "inproc://yeahbaby", NULL, 0) == 0);
+ So(nng_setopt(s2, NNG_OPT_SUB_SUBSCRIBE, "foo", 3) == 0);
+ nng_msleep(50);
+
+ Convey("We can get a recv FD", {
+ int fd;
+ size_t sz;
+
+ sz = sizeof(fd);
+ So(nng_getopt(s2, NNG_OPT_RECVFD, &fd, &sz) == 0);
+ So(fd != (int) INVALID_SOCKET);
+
+ Convey("And it is always the same fd", {
+ int fd2;
+ sz = sizeof(fd2);
+ So(nng_getopt(s2, NNG_OPT_RECVFD, &fd2, &sz) ==
+ 0);
+ So(fd2 == fd);
+ });
+
+ Convey("And they start non pollable", {
+ struct pollfd pfd;
+ pfd.fd = fd;
+ pfd.events = POLLIN;
+ pfd.revents = 0;
+
+ So(poll(&pfd, 1, 0) == 0);
+ So(pfd.revents == 0);
+ });
+
+ Convey("But if we write to subscribed topic they are pollable", {
+ struct pollfd pfd;
+ pfd.fd = fd;
+ pfd.events = POLLIN;
+ pfd.revents = 0;
+
+ So(nng_send(s1, "foo:kick", 8, 0) == 0);
+ So(poll(&pfd, 1, 100) == 1);
+ So((pfd.revents & POLLIN) != 0);
+ });
+ Convey("And if the topic doesn't match, it is not pollable", {
+ struct pollfd pfd;
+ pfd.fd = fd;
+ pfd.events = POLLIN;
+ pfd.revents = 0;
+
+ So(nng_send(s1, "bar:kick", 8, 100) == 0);
+ So(poll(&pfd, 1, 0) == 0);
+ });
+ });
+
+ Convey("We can get a send FD", {
+ int fd;
+ size_t sz;
+
+ sz = sizeof(fd);
+ So(nng_getopt(s1, NNG_OPT_SENDFD, &fd, &sz) == 0);
+ So(fd != (int) INVALID_SOCKET);
+ So(nng_send(s1, "oops", 4, 0) == 0);
+ });
+
+ Convey("Must have a big enough size", {
+ int fd;
+ size_t sz;
+ sz = 1;
+ So(nng_getopt(s2, NNG_OPT_RECVFD, &fd, &sz) ==
+ NNG_EINVAL);
+ sz = 128;
+ So(nng_getopt(s2, NNG_OPT_RECVFD, &fd, &sz) == 0);
+ So(sz == sizeof(fd));
+ });
+ });
+})