X-Git-Url: http://git.meshlink.io/?a=blobdiff_plain;f=test%2Fimport-export.c;h=8bc41c1b3c06fad7ac11b7fba4956f41abfe5dac;hb=HEAD;hp=5d37146fd09502d8711f70a592033124462c8879;hpb=3febbb4453f5c6b0286e7e3c68a5dbcec975b6fd;p=meshlink diff --git a/test/import-export.c b/test/import-export.c index 5d37146f..15981ed9 100644 --- a/test/import-export.c +++ b/test/import-export.c @@ -12,9 +12,10 @@ #include "meshlink.h" #include "utils.h" -struct sync_flag bar_reachable; +static struct sync_flag bar_reachable; +static struct sync_flag pmtu_flag; -void status_cb(meshlink_handle_t *mesh, meshlink_node_t *node, bool reachable) { +static void status_cb(meshlink_handle_t *mesh, meshlink_node_t *node, bool reachable) { (void)mesh; if(reachable && !strcmp(node->name, "bar")) { @@ -22,7 +23,18 @@ void status_cb(meshlink_handle_t *mesh, meshlink_node_t *node, bool reachable) { } } -int main() { +static void pmtu_cb(meshlink_handle_t *mesh, meshlink_node_t *node, uint16_t pmtu) { + (void)mesh; + + if(pmtu && !strcmp(node->name, "bar")) { + set_sync_flag(&pmtu_flag, true); + } +} + +int main(void) { + init_sync_flag(&bar_reachable); + init_sync_flag(&pmtu_flag); + meshlink_set_log_cb(NULL, MESHLINK_DEBUG, log_cb); // Open two new meshlink instance. @@ -77,30 +89,23 @@ int main() { // Start both instances meshlink_set_node_status_cb(mesh1, status_cb); + meshlink_set_node_pmtu_cb(mesh1, pmtu_cb); assert(meshlink_start(mesh1)); assert(meshlink_start(mesh2)); // Wait for the two to connect. - assert(wait_sync_flag(&bar_reachable, 20)); + assert(wait_sync_flag(&bar_reachable, 10)); // Wait for UDP communication to become possible. - int pmtu = meshlink_get_pmtu(mesh2, meshlink_get_node(mesh2, "bar")); - - for(int i = 0; i < 10 && !pmtu; i++) { - sleep(1); - pmtu = meshlink_get_pmtu(mesh2, meshlink_get_node(mesh2, "bar")); - } - - assert(pmtu); + assert(wait_sync_flag(&pmtu_flag, 10)); // Check that we now have reachability information assert(meshlink_get_node_reachability(mesh1, bar, &last_reachable, &last_unreachable)); assert(last_reachable); - assert(!last_unreachable); // Stop the meshes.