X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Ftest%2Ftest-path-util.c;h=127e17803f8003d33cd948c3a49eee87e34962ce;hp=2bca5ef60480e5f53b226dbd0fdedb0448b0ffee;hb=d7bd3de0654669e65b9642c248c5fa6d1d9a9f61;hpb=76877b46b652fbfcf8618458556178717b815cd8 diff --git a/src/test/test-path-util.c b/src/test/test-path-util.c index 2bca5ef60..127e17803 100644 --- a/src/test/test-path-util.c +++ b/src/test/test-path-util.c @@ -19,6 +19,8 @@ along with systemd; If not, see . ***/ +#include + #include "path-util.h" #include "util.h" #include "macro.h" @@ -51,19 +53,21 @@ static void test_path(void) { assert_se(streq(path_get_file_name("./aa/bb/../file.da."), "file.da.")); assert_se(streq(path_get_file_name("/aa///.file"), ".file")); assert_se(streq(path_get_file_name("/aa///file..."), "file...")); - assert_se(streq(path_get_file_name("file.../"), ".")); - -#define test_parent(x, y) { \ - char *z; \ - int r = path_get_parent(x, &z); \ - assert_se(r==0); \ - assert_se(streq(z, y)); \ + assert_se(streq(path_get_file_name("file.../"), "")); + +#define test_parent(x, y) { \ + char *z; \ + int r = path_get_parent(x, &z); \ + printf("expected: %s\n", y ? y : "error"); \ + printf("actual: %s\n", r<0 ? "error" : z); \ + assert_se((y==NULL) ^ (r==0)); \ + assert_se(y==NULL || path_equal(z, y)); \ } test_parent("./aa/bb/../file.da.", "./aa/bb/.."); test_parent("/aa///.file", "/aa///"); test_parent("/aa///file...", "/aa///"); - test_parent("file.../", "file..."); + test_parent("file.../", NULL); assert_se(path_is_mount_point("/", true)); assert_se(path_is_mount_point("/", false));