Commit 8fdacca5 authored by Pavel Tikhomirov's avatar Pavel Tikhomirov Committed by Andrei Vagin

zdtm: improve tempfs_overmounted test

Unchanged test provided by Andrew.
Signed-off-by: 's avatarAndrei Vagin <avagin@virtuozzo.com>
Signed-off-by: 's avatarPavel Tikhomirov <ptikhomirov@virtuozzo.com>
Signed-off-by: 's avatarAndrei Vagin <avagin@virtuozzo.com>
parent 0709e3ce
......@@ -19,11 +19,38 @@ int main(int argc, char **argv)
test_init(argc, argv);
mkdir(dirname, 0700);
if (mount("none", dirname, "tmpfs", 0, "") < 0) {
if (chdir(dirname)) {
pr_perror("chdir");
return 1;
}
mkdir("a", 0777);
mkdir("a/b", 0777);
mount(NULL, "/", NULL, MS_PRIVATE, "");
if (mount("none", "a/b", "tmpfs", 0, "") < 0) {
fail("Can't mount tmpfs");
return 1;
}
if (mount("none", "a/b", "tmpfs", 0, "") < 0) {
fail("Can't mount tmpfs");
return 1;
}
mkdir("a/b/c", 0777);
if (mount("none", "a/b/c", "tmpfs", 0, "") < 0) {
fail("Can't mount tmpfs");
return 1;
}
if (mount("none", dirname, "tmpfs", 0, "") < 0) {
if (mount("none", "a", "tmpfs", 0, "") < 0) {
fail("Can't mount tmpfs");
return 1;
}
if (mount("none", "a", "tmpfs", 0, "") < 0) {
fail("Can't mount tmpfs");
return 1;
}
mkdir("a/b", 0777);
if (mount("none", "a/b", "tmpfs", 0, "") < 0) {
fail("Can't mount tmpfs");
return 1;
}
......@@ -31,6 +58,11 @@ int main(int argc, char **argv)
test_daemon();
test_waitsig();
if (umount("a/b") || umount("a") || umount("a") || umount("a/b/c") || umount("a/b") || umount("a/b")) {
pr_err("umount");
return 1;
}
pass();
return 0;
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment