]> git.meshlink.io Git - meshlink/blobdiff - test/channels-no-partial.c
Never automatically try to bind to ports >= 32768.
[meshlink] / test / channels-no-partial.c
index d8a8bf1eb5262d1b3af29a63e6b3f677870b7294..43792be39ec7a671034995cdef47a94e61777457 100644 (file)
@@ -1,3 +1,7 @@
+#ifdef NDEBUG
+#undef NDEBUG
+#endif
+
 #include <assert.h>
 #include <stdio.h>
 #include <unistd.h>
@@ -64,11 +68,24 @@ int main(int argc, char *argv[]) {
 
        // Restart a to ensure it gets to flush the channel send queue.
 
-       meshlink_start(mesh_a);
+       assert(meshlink_start(mesh_a));
 
        assert_after(!meshlink_channel_get_sendq(mesh_a, channel), 30);
        assert(meshlink_channel_send(mesh_a, channel, buf, 512) == 512);
 
+       // Check that we can change the NO_PARTIAL flag
+
+       assert_after(!meshlink_channel_get_sendq(mesh_a, channel), 30);
+       meshlink_set_channel_sndbuf(mesh_a, channel, 256);
+       assert(meshlink_channel_send(mesh_a, channel, buf, 257) == -1);
+       meshlink_set_channel_flags(mesh_a, channel, 0);
+       assert(meshlink_channel_send(mesh_a, channel, buf, 257) == 256);
+
+       assert_after(!meshlink_channel_get_sendq(mesh_a, channel), 30);
+       meshlink_set_channel_flags(mesh_a, channel, MESHLINK_CHANNEL_NO_PARTIAL);
+       assert(meshlink_channel_send(mesh_a, channel, buf, 257) == -1);
+       assert(meshlink_channel_send(mesh_a, channel, buf, 256) == 256);
+
        // Clean up.
 
        close_meshlink_pair(mesh_a, mesh_b);