From: Yu Watanabe Date: Wed, 2 Feb 2022 06:08:18 +0000 (+0900) Subject: test: add a test for mkdir_p() X-Git-Tag: v251-rc1~376^2 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=refs%2Fpull%2F22359%2Fhead;p=thirdparty%2Fsystemd.git test: add a test for mkdir_p() --- diff --git a/src/test/meson.build b/src/test/meson.build index e245e0b7b2c..88164f1262e 100644 --- a/src/test/meson.build +++ b/src/test/meson.build @@ -193,6 +193,8 @@ tests += [ [files('test-macro.c')], + [files('test-mkdir.c')], + [files('test-json.c')], [files('test-modhex.c')], diff --git a/src/test/test-mkdir.c b/src/test/test-mkdir.c new file mode 100644 index 00000000000..c715d5f0964 --- /dev/null +++ b/src/test/test-mkdir.c @@ -0,0 +1,30 @@ +/* SPDX-License-Identifier: LGPL-2.1-or-later */ + +#include + +#include "mkdir.h" +#include "path-util.h" +#include "rm-rf.h" +#include "tests.h" +#include "tmpfile-util.h" + +TEST(mkdir_p) { + _cleanup_(rm_rf_physical_and_freep) char *tmp = NULL; + _cleanup_free_ char *p = NULL; + + assert_se(mkdtemp_malloc("/tmp/test-mkdir-XXXXXX", &tmp) >= 0); + + assert_se(p = path_join(tmp, "run")); + assert_se(mkdir_p(p, 0755) >= 0); + + p = mfree(p); + assert_se(p = path_join(tmp, "var/run")); + assert_se(mkdir_parents(p, 0755) >= 0); + assert_se(symlink("../run", p) >= 0); + + p = mfree(p); + assert_se(p = path_join(tmp, "var/run/hoge/foo/baz")); + assert_se(mkdir_p(p, 0755) >= 0); +} + +DEFINE_TEST_MAIN(LOG_DEBUG);