aboutsummaryrefslogtreecommitdiff
path: root/src/core/reconnect_test.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/core/reconnect_test.c')
-rw-r--r--src/core/reconnect_test.c159
1 files changed, 77 insertions, 82 deletions
diff --git a/src/core/reconnect_test.c b/src/core/reconnect_test.c
index 669261c9..308a3f78 100644
--- a/src/core/reconnect_test.c
+++ b/src/core/reconnect_test.c
@@ -10,101 +10,95 @@
#include <string.h>
-#include <nng/nng.h>
-#include <nng/protocol/pipeline0/pull.h>
-#include <nng/protocol/pipeline0/push.h>
-#include <nng/supplemental/util/platform.h>
-
-#include "acutest.h"
-#include "testutil.h"
+#include <nuts.h>
void
test_dial_before_listen(void)
{
- nng_socket push;
- nng_socket pull;
- char addr[64];
+ nng_socket s1;
+ nng_socket s2;
+ char *addr;
- testutil_scratch_addr("inproc", sizeof(addr), addr);
+ NUTS_OPEN(s1);
+ NUTS_OPEN(s2);
- TEST_NNG_PASS(nng_push0_open(&push));
- TEST_NNG_PASS(nng_pull0_open(&pull));
+ NUTS_ADDR(addr, "inproc");
- TEST_NNG_PASS(nng_socket_set_ms(pull, NNG_OPT_RECONNMINT, 10));
- TEST_NNG_PASS(nng_socket_set_ms(pull, NNG_OPT_RECONNMAXT, 10));
+ NUTS_PASS(nng_socket_set_ms(s2, NNG_OPT_RECONNMINT, 10));
+ NUTS_PASS(nng_socket_set_ms(s2, NNG_OPT_RECONNMAXT, 10));
- TEST_NNG_PASS(nng_dial(pull, addr, NULL, NNG_FLAG_NONBLOCK));
- testutil_sleep(100);
- TEST_NNG_PASS(nng_listen(push, addr, NULL, 0));
+ NUTS_PASS(nng_dial(s2, addr, NULL, NNG_FLAG_NONBLOCK));
+ NUTS_SLEEP(100);
+ NUTS_PASS(nng_listen(s1, addr, NULL, 0));
- TEST_NNG_SEND_STR(push, "hello");
- TEST_NNG_RECV_STR(pull, "hello");
+ NUTS_SEND(s1, "hello");
+ NUTS_RECV(s2, "hello");
- TEST_NNG_PASS(nng_close(push));
- TEST_NNG_PASS(nng_close(pull));
+ NUTS_CLOSE(s1);
+ NUTS_CLOSE(s2);
}
void
test_reconnect(void)
{
- nng_socket push;
- nng_socket pull;
+ nng_socket s1;
+ nng_socket s2;
nng_listener l;
- char addr[64];
+ char *addr;
- testutil_scratch_addr("inproc", sizeof(addr), addr);
+ NUTS_OPEN(s1);
+ NUTS_OPEN(s2);
- TEST_NNG_PASS(nng_push0_open(&push));
- TEST_NNG_PASS(nng_pull0_open(&pull));
+ NUTS_ADDR(addr, "inproc");
- TEST_NNG_PASS(nng_socket_set_ms(pull, NNG_OPT_RECONNMINT, 10));
- TEST_NNG_PASS(nng_socket_set_ms(pull, NNG_OPT_RECONNMAXT, 10));
+ NUTS_PASS(nng_socket_set_ms(s2, NNG_OPT_RECONNMINT, 10));
+ NUTS_PASS(nng_socket_set_ms(s2, NNG_OPT_RECONNMAXT, 10));
- TEST_NNG_PASS(nng_dial(pull, addr, NULL, NNG_FLAG_NONBLOCK));
- testutil_sleep(100);
- TEST_NNG_PASS(nng_listen(push, addr, &l, 0));
+ NUTS_PASS(nng_dial(s2, addr, NULL, NNG_FLAG_NONBLOCK));
+ NUTS_SLEEP(100);
+ NUTS_PASS(nng_listen(s1, addr, &l, 0));
- TEST_NNG_SEND_STR(push, "hello");
- TEST_NNG_RECV_STR(pull, "hello");
+ NUTS_SEND(s1, "hello");
+ NUTS_RECV(s2, "hello");
// Close the listener
- TEST_NNG_PASS(nng_listener_close(l));
+ NUTS_PASS(nng_listener_close(l));
- TEST_NNG_PASS(nng_listen(push, addr, &l, 0));
- TEST_NNG_SEND_STR(push, "again");
- TEST_NNG_RECV_STR(pull, "again");
+ NUTS_PASS(nng_listen(s1, addr, &l, 0));
+ NUTS_SEND(s1, "again");
+ NUTS_RECV(s2, "again");
- TEST_NNG_PASS(nng_close(push));
- TEST_NNG_PASS(nng_close(pull));
+ NUTS_CLOSE(s1);
+ NUTS_CLOSE(s2);
}
void
test_reconnect_pipe(void)
{
- nng_socket push;
- nng_socket pull;
+ nng_socket s1;
+ nng_socket s2;
nng_listener l;
nng_msg * msg;
- char addr[64];
+ char * addr;
- testutil_scratch_addr("inproc", sizeof(addr), addr);
+ NUTS_OPEN(s1);
+ NUTS_OPEN(s2);
- TEST_NNG_PASS(nng_push0_open(&push));
- TEST_NNG_PASS(nng_pull0_open(&pull));
+ NUTS_ADDR(addr, "inproc");
- TEST_NNG_PASS(nng_socket_set_ms(pull, NNG_OPT_RECONNMINT, 10));
- TEST_NNG_PASS(nng_socket_set_ms(pull, NNG_OPT_RECONNMAXT, 10));
+ NUTS_PASS(nng_socket_set_ms(s1, NNG_OPT_RECONNMINT, 10));
+ NUTS_PASS(nng_socket_set_ms(s1, NNG_OPT_RECONNMAXT, 10));
- TEST_NNG_PASS(nng_dial(pull, addr, NULL, NNG_FLAG_NONBLOCK));
- testutil_sleep(100);
- TEST_NNG_PASS(nng_listen(push, addr, &l, 0));
+ NUTS_PASS(nng_dial(s1, addr, NULL, NNG_FLAG_NONBLOCK));
+ NUTS_SLEEP(100);
+ NUTS_PASS(nng_listen(s2, addr, &l, 0));
- TEST_NNG_SEND_STR(push, "hello");
+ NUTS_SEND(s2, "hello");
- TEST_NNG_PASS(nng_recvmsg(pull, &msg, 0));
- TEST_CHECK(msg != NULL);
- TEST_CHECK(nng_msg_len(msg) == 6);
- TEST_CHECK(strcmp(nng_msg_body(msg), "hello") == 0);
+ NUTS_PASS(nng_recvmsg(s1, &msg, 0));
+ NUTS_TRUE(msg != NULL);
+ NUTS_TRUE(nng_msg_len(msg) == 6);
+ NUTS_MATCH(nng_msg_body(msg), "hello");
nng_pipe_close(nng_msg_get_pipe(msg));
nng_msg_free(msg);
@@ -112,53 +106,54 @@ test_reconnect_pipe(void)
// receiver, the receiver might not have got the update. If we
// send too soon, then the message gets routed to the sender pipe
// that is about to close.
- testutil_sleep(100);
+ NUTS_SLEEP(100);
- // Reconnect should happen more ore less immediately.
- TEST_NNG_SEND_STR(push, "again");
- TEST_NNG_RECV_STR(pull, "again");
+ // Reconnect should happen more or less immediately.
+ NUTS_SEND(s2, "again");
+ NUTS_RECV(s1, "again");
- TEST_NNG_PASS(nng_close(push));
- TEST_NNG_PASS(nng_close(pull));
+ NUTS_CLOSE(s1);
+ NUTS_CLOSE(s2);
}
void
test_reconnect_back_off_zero(void)
{
- nng_socket push;
- nng_socket pull;
- nng_time start;
- char addr[64];
- testutil_scratch_addr("inproc", sizeof(addr), addr);
+ nng_socket s1;
+ nng_socket s2;
+ uint64_t start;
+ char * addr;
+
+ NUTS_OPEN(s1);
+ NUTS_OPEN(s2);
- TEST_NNG_PASS(nng_push0_open(&push));
- TEST_NNG_PASS(nng_pull0_open(&pull));
+ NUTS_ADDR(addr, "inproc");
// redial every 10 ms.
- TEST_NNG_PASS(nng_socket_set_ms(push, NNG_OPT_RECONNMAXT, 0));
- TEST_NNG_PASS(nng_socket_set_ms(push, NNG_OPT_RECONNMINT, 10));
- TEST_NNG_PASS(nng_dial(push, addr, NULL, NNG_FLAG_NONBLOCK));
+ NUTS_PASS(nng_socket_set_ms(s1, NNG_OPT_RECONNMAXT, 0));
+ NUTS_PASS(nng_socket_set_ms(s1, NNG_OPT_RECONNMINT, 10));
+ NUTS_PASS(nng_dial(s1, addr, NULL, NNG_FLAG_NONBLOCK));
// Start up the dialer first. It should keep retrying every 10 ms.
// Wait 500 milliseconds. This gives a chance for an exponential
// back-off to increase to a longer time. It should by this point
// be well over 100 and probably closer to 200 ms.
- nng_msleep(500);
+ NUTS_SLEEP(500);
- start = nng_clock();
- TEST_NNG_PASS(nng_listen(pull, addr, NULL, 0));
+ NUTS_CLOCK(start);
+ NUTS_PASS(nng_listen(s2, addr, NULL, 0));
- TEST_NNG_SEND_STR(push, "hello");
- TEST_NNG_RECV_STR(pull, "hello");
+ NUTS_SEND(s1, "hello");
+ NUTS_RECV(s2, "hello");
- TEST_CHECK(nng_clock() - start < 100);
+ NUTS_BEFORE(start + 100);
- TEST_NNG_PASS(nng_close(push));
- TEST_NNG_PASS(nng_close(pull));
+ NUTS_CLOSE(s1);
+ NUTS_CLOSE(s2);
}
-TEST_LIST = {
+NUTS_TESTS = {
{ "dial before listen", test_dial_before_listen },
{ "reconnect", test_reconnect },
{ "reconnect back-off zero", test_reconnect_back_off_zero },