X-Git-Url: http://git.meshlink.io/?a=blobdiff_plain;f=test%2Fbasic.c;h=bf8ff772af73db120cadbc2d54403fb36b512d26;hb=0b6635bd9460ba2f9aeafddd2aef79929cd417a1;hp=f591df7b54df1e6271a9c868a80bcb78d6464e00;hpb=6c897377f68fc23ca9a8b23a6ca204517998b2e9;p=meshlink diff --git a/test/basic.c b/test/basic.c index f591df7b..bf8ff772 100644 --- a/test/basic.c +++ b/test/basic.c @@ -37,15 +37,38 @@ int main() { assert(self); assert(!strcmp(self->name, "foo")); + // Check that we are not reachable. + + time_t last_reachable; + time_t last_unreachable; + assert(!meshlink_get_node_reachability(mesh, self, &last_reachable, &last_unreachable)); + assert(!last_reachable); + assert(!last_unreachable); + // Start and stop the mesh. assert(meshlink_start(mesh)); + + // Check that we are now reachable + + assert(meshlink_get_node_reachability(mesh, self, &last_reachable, &last_unreachable)); + assert(last_reachable); + assert(!last_unreachable); + meshlink_stop(mesh); + // Check that we are no longer reachable. + + assert(!meshlink_get_node_reachability(mesh, self, &last_reachable, &last_unreachable)); + assert(last_reachable); + assert(last_unreachable); + // Make sure we can start and stop the mesh again. + assert(meshlink_start(mesh)); assert(meshlink_start(mesh)); meshlink_stop(mesh); + meshlink_stop(mesh); // Close the mesh and open it again, now with a different name parameter. @@ -53,6 +76,15 @@ int main() { mesh = meshlink_open("basic_conf", "bar", "basic", DEV_CLASS_BACKBONE); assert(mesh); + self = meshlink_get_self(mesh); + assert(self); + + // Check that we remembered we were reachable + + assert(!meshlink_get_node_reachability(mesh, self, &last_reachable, &last_unreachable)); + assert(last_reachable); + assert(last_unreachable); + // Check that the name is ignored now, and that we still are "foo". assert(!meshlink_get_node(mesh, "bar")); @@ -66,6 +98,28 @@ int main() { meshlink_stop(mesh); meshlink_close(mesh); + // Check that messing with the config directory will create a new instance. + + assert(unlink("basic_conf/current/meshlink.conf") == 0); + mesh = meshlink_open("basic_conf", "bar", "basic", DEV_CLASS_BACKBONE); + assert(mesh); + assert(!meshlink_get_node(mesh, "foo")); + self = meshlink_get_self(mesh); + assert(self); + assert(!strcmp(self->name, "bar")); + assert(access("basic_conf/new", X_OK) == -1 && errno == ENOENT); + meshlink_close(mesh); + + assert(rename("basic_conf/current", "basic_conf/new") == 0); + mesh = meshlink_open("basic_conf", "baz", "basic", DEV_CLASS_BACKBONE); + assert(mesh); + assert(!meshlink_get_node(mesh, "bar")); + self = meshlink_get_self(mesh); + assert(self); + assert(!strcmp(self->name, "baz")); + assert(access("basic_conf/new", X_OK) == -1 && errno == ENOENT); + meshlink_close(mesh); + // Destroy the mesh. assert(meshlink_destroy("basic_conf")); @@ -81,4 +135,8 @@ int main() { } closedir(dir); + + // Check that we can destroy it again. + + assert(meshlink_destroy("basic_conf")); }