X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Ftest%2Ftest-path-util.c;h=19462c357183cd3563916a63d997aea18fb341e5;hb=c9fdc26e96493175668fbde61a04fc70abff300d;hp=527b27565693959b89405da5c3d36115aed9b577;hpb=b972115c97b9ec1bb17ee4897da6b85d82727ca8;p=elogind.git diff --git a/src/test/test-path-util.c b/src/test/test-path-util.c index 527b27565..19462c357 100644 --- a/src/test/test-path-util.c +++ b/src/test/test-path-util.c @@ -20,10 +20,12 @@ ***/ #include +#include #include "path-util.h" #include "util.h" #include "macro.h" +#include "strv.h" static void test_path(void) { @@ -56,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); \ @@ -83,7 +85,7 @@ static void test_path(void) { } } -static void test_find_binary(void) { +static void test_find_binary(const char *self) { char *p; assert(find_binary("/bin/sh", &p) == 0); @@ -91,7 +93,7 @@ static void test_find_binary(void) { assert(streq(p, "/bin/sh")); free(p); - assert(find_binary("./test-path-util", &p) == 0); + assert(find_binary(self, &p) == 0); puts(p); assert(endswith(p, "/test-path-util")); assert(path_is_absolute(p)); @@ -170,10 +172,61 @@ static void test_fsck_exists(void) { assert_se(fsck_exists("AbCdE") == -ENOENT); } -int main(void) { +static void test_make_relative(void) { + char *result; + + assert_se(path_make_relative("some/relative/path", "/some/path", &result) < 0); + assert_se(path_make_relative("/some/path", "some/relative/path", &result) < 0); + +#define test(from_dir, to_path, expected) { \ + path_make_relative(from_dir, to_path, &result); \ + assert_se(streq(result, expected)); \ + free(result); \ + } + + test("/", "/", "."); + test("/", "/some/path", "some/path"); + test("/some/path", "/some/path", "."); + test("/some/path", "/some/path/in/subdir", "in/subdir"); + test("/some/path", "/", "../.."); + test("/some/path", "/some/other/path", "../other/path"); + test("//extra/////slashes///won't////fool///anybody//", "////extra///slashes////are/just///fine///", "../../../are/just/fine"); +} + +static void test_strv_resolve(void) { + char tmp_dir[] = "/tmp/test-path-util-XXXXXX"; + _cleanup_strv_free_ char **search_dirs = NULL; + _cleanup_strv_free_ char **absolute_dirs = NULL; + char **d; + + assert_se(mkdtemp(tmp_dir) != NULL); + + search_dirs = strv_new("/dir1", "/dir2", "/dir3", NULL); + assert_se(search_dirs); + STRV_FOREACH(d, search_dirs) { + char *p = strappend(tmp_dir, *d); + assert_se(p); + assert_se(strv_push(&absolute_dirs, p) == 0); + } + + assert_se(mkdir(absolute_dirs[0], 0700) == 0); + assert_se(mkdir(absolute_dirs[1], 0700) == 0); + assert_se(symlink("dir2", absolute_dirs[2]) == 0); + + path_strv_resolve(search_dirs, tmp_dir); + assert_se(streq(search_dirs[0], "/dir1")); + assert_se(streq(search_dirs[1], "/dir2")); + assert_se(streq(search_dirs[2], "/dir2")); + + assert_se(rm_rf_dangerous(tmp_dir, false, true, false) == 0); +} + +int main(int argc, char **argv) { test_path(); - test_find_binary(); + test_find_binary(argv[0]); test_prefixes(); test_fsck_exists(); + test_make_relative(); + test_strv_resolve(); return 0; }