]> git.meshlink.io Git - meshlink/blobdiff - test/channels-failure.c
Don't use assert() to check the results of pthread_*() calls.
[meshlink] / test / channels-failure.c
index 34018e1124e472162cea5ec103068c5aa0da8d32..defdca9676bdcd664f3c66cbe8645f9fe16ff20f 100644 (file)
@@ -1,3 +1,7 @@
+#ifdef NDEBUG
+#undef NDEBUG
+#endif
+
 #include <stdio.h>
 #include <unistd.h>
 #include <stdlib.h>
@@ -39,7 +43,10 @@ static void receive_cb(meshlink_handle_t *mesh, meshlink_channel_t *channel, con
        set_sync_flag(&receive_flag, true);
 }
 
-int main() {
+int main(void) {
+       init_sync_flag(&poll_flag);
+       init_sync_flag(&receive_flag);
+
        meshlink_set_log_cb(NULL, MESHLINK_DEBUG, log_cb);
 
        // Open two meshlink instances.
@@ -72,28 +79,59 @@ int main() {
 
        sleep(1);
 
+       // Set a very small timeout for channels to b.
+
+       meshlink_set_node_channel_timeout(mesh_a, b, 1);
+
        // Stop mesh_b. We should get a notification that the channel has closed after a while.
 
        meshlink_stop(mesh_b);
 
-       assert(wait_sync_flag(&receive_flag, 70));
+       assert(wait_sync_flag(&receive_flag, 5));
        assert(receive_len == 0);
 
        meshlink_channel_close(mesh_a, channel);
 
        // Try setting up a new channel while b is still down.
 
-       poll_flag.flag = false;
-       receive_flag.flag = false;
+       set_sync_flag(&poll_flag, false);
+       set_sync_flag(&receive_flag, false);
 
        channel = meshlink_channel_open(mesh_a, b, 7, NULL, NULL, 0);
        assert(channel);
 
        meshlink_set_channel_poll_cb(mesh_a, channel, poll_cb);
 
-       assert(wait_sync_flag(&poll_flag, 70));
+       assert(wait_sync_flag(&poll_flag, 5));
        assert(poll_len == 0);
 
+       meshlink_channel_close(mesh_a, channel);
+
+       // Restart b and create a new channel
+
+       set_sync_flag(&poll_flag, false);
+       set_sync_flag(&receive_flag, false);
+
+       meshlink_set_node_channel_timeout(mesh_a, b, 60);
+
+       assert(meshlink_start(mesh_b));
+
+       channel = meshlink_channel_open(mesh_a, b, 7, receive_cb, NULL, 0);
+       meshlink_set_channel_poll_cb(mesh_a, channel, poll_cb);
+       assert(channel);
+       assert(wait_sync_flag(&poll_flag, 10));
+       assert(poll_len != 0);
+
+       // Close and reopen b, we should get a fast notification that the channel has been closed.
+
+       meshlink_close(mesh_b);
+       mesh_b = meshlink_open("channels_failure_conf.2", "b", "channels_failure", DEV_CLASS_BACKBONE);
+       assert(mesh_b);
+       assert(meshlink_start(mesh_b));
+
+       assert(wait_sync_flag(&receive_flag, 10));
+       assert(receive_len == 0);
+
        // Clean up.
 
        close_meshlink_pair(mesh_a, mesh_b);