X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Ftest%2Ftest-path-util.c;h=01afb3e6feed6c45aaabdb72b951524e7c496635;hb=080edb3484dc3ecf8d914526fdd3090b40fdf5b6;hp=4ee33a9543f46302b16a733acd5a5a244d8c176e;hpb=3e8a78c8dceedb001587cb6c1eaa31cb8aa56729;p=elogind.git diff --git a/src/test/test-path-util.c b/src/test/test-path-util.c index 4ee33a954..01afb3e6f 100644 --- a/src/test/test-path-util.c +++ b/src/test/test-path-util.c @@ -58,7 +58,7 @@ static void test_path(void) { assert_se(streq(basename("file.../"), "")); #define test_parent(x, y) { \ - char _cleanup_free_ *z = NULL; \ + _cleanup_free_ char *z = NULL; \ int r = path_get_parent(x, &z); \ printf("expected: %s\n", y ? y : "error"); \ printf("actual: %s\n", r<0 ? "error" : z); \ @@ -79,35 +79,35 @@ static void test_path(void) { char p2[] = "//aaa/.////ccc"; char p3[] = "/./"; - assert(path_equal(path_kill_slashes(p1), "aaa/bbb/ccc")); - assert(path_equal(path_kill_slashes(p2), "/aaa/./ccc")); - assert(path_equal(path_kill_slashes(p3), "/./")); + assert_se(path_equal(path_kill_slashes(p1), "aaa/bbb/ccc")); + assert_se(path_equal(path_kill_slashes(p2), "/aaa/./ccc")); + assert_se(path_equal(path_kill_slashes(p3), "/./")); } } static void test_find_binary(const char *self) { char *p; - assert(find_binary("/bin/sh", &p) == 0); + assert_se(find_binary("/bin/sh", &p) == 0); puts(p); - assert(streq(p, "/bin/sh")); + assert_se(streq(p, "/bin/sh")); free(p); - assert(find_binary(self, &p) == 0); + assert_se(find_binary(self, &p) == 0); puts(p); - assert(endswith(p, "/test-path-util")); - assert(path_is_absolute(p)); + assert_se(endswith(p, "/test-path-util")); + assert_se(path_is_absolute(p)); free(p); - assert(find_binary("sh", &p) == 0); + assert_se(find_binary("sh", &p) == 0); puts(p); - assert(endswith(p, "/sh")); - assert(path_is_absolute(p)); + assert_se(endswith(p, "/sh")); + assert_se(path_is_absolute(p)); free(p); - assert(find_binary("xxxx-xxxx", &p) == -ENOENT); + assert_se(find_binary("xxxx-xxxx", &p) == -ENOENT); - assert(find_binary("/some/dir/xxxx-xxxx", &p) == -ENOENT); + assert_se(find_binary("/some/dir/xxxx-xxxx", &p) == -ENOENT); } static void test_prefixes(void) { @@ -156,12 +156,26 @@ static void test_prefixes(void) { b = false; PATH_FOREACH_PREFIX_MORE(s, "") { - assert(!b); - assert(streq(s, "")); + assert_se(!b); + assert_se(streq(s, "")); b = true; } } +static void test_path_join(void) { + assert_se(streq(path_join("/root", "/a/b", "/c"), "/root/a/b/c")); + assert_se(streq(path_join("/root", "a/b", "c"), "/root/a/b/c")); + assert_se(streq(path_join("/root", "/a/b", "c"), "/root/a/b/c")); + assert_se(streq(path_join("/root", "/", "c"), "/root//c")); + assert_se(streq(path_join("/root", "/", NULL), "/root/")); + + assert_se(streq(path_join(NULL, "/a/b", "/c"), "/a/b/c")); + assert_se(streq(path_join(NULL, "a/b", "c"), "a/b/c")); + assert_se(streq(path_join(NULL, "/a/b", "c"), "/a/b/c")); + assert_se(streq(path_join(NULL, "/", "c"), "//c")); + assert_se(streq(path_join(NULL, "/", NULL), "/")); +} + static void test_fsck_exists(void) { /* Ensure we use a sane default for PATH. */ unsetenv("PATH"); @@ -225,6 +239,7 @@ int main(int argc, char **argv) { test_path(); test_find_binary(argv[0]); test_prefixes(); + test_path_join(); test_fsck_exists(); test_make_relative(); test_strv_resolve();