X-Git-Url: http://git.meshlink.io/?a=blobdiff_plain;f=test%2Fchannels-no-partial.c;h=43792be39ec7a671034995cdef47a94e61777457;hb=bc2e55e940e45748a49f1a7eb44b156917fca469;hp=c765456abff08e3de1b9c8a5151182e59c6ddd4d;hpb=fe5563f92021618b4a8b41e412c73d8364fcaf6e;p=meshlink diff --git a/test/channels-no-partial.c b/test/channels-no-partial.c index c765456a..43792be3 100644 --- a/test/channels-no-partial.c +++ b/test/channels-no-partial.c @@ -73,6 +73,19 @@ int main(int argc, char *argv[]) { 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);