blob: 91c2e8b42aa03270842df6b63381e2d6c139968a [file] [log] [blame]
Denis Vlasenko5d624622008-07-08 02:57:40 +00001#!/bin/sh
Denis Vlasenko5d624622008-07-08 02:57:40 +00002# Copyright 2007 by Denys Vlasenko <vda.linux@googlemail.com>
Denys Vlasenko0ef64bd2010-08-16 20:14:46 +02003# Licensed under GPLv2, see file LICENSE in this source tree.
Denis Vlasenko5d624622008-07-08 02:57:40 +00004
Mike Frysingercaa79402009-11-04 18:41:22 -05005. ./testing.sh
Denys Vlasenkobfa1b2e2010-05-11 03:53:57 +02006test -f "$bindir/.config" && . "$bindir/.config"
7
Denis Vlasenko5d624622008-07-08 02:57:40 +00008test "`id -u`" = 0 || {
Denys Vlasenkobfa1b2e2010-05-11 03:53:57 +02009 echo "SKIPPED: mount (must be root to test this)"
Denis Vlasenko5d624622008-07-08 02:57:40 +000010 exit 0
11}
12
Denys Vlasenko33576662018-06-28 14:10:00 +020013# Without MOUNT_LOOP_CREATE, the test will fail if /dev/loopN's do not exist
Denys Vlasenkobfa1b2e2010-05-11 03:53:57 +020014if test x"$CONFIG_MKFS_MINIX" != x"y" \
15|| test x"$CONFIG_FEATURE_MINIX2" != x"y" \
Denys Vlasenkoc0211e92010-05-11 04:32:04 +020016|| test x"$CONFIG_FEATURE_MOUNT_LOOP" != x"y" \
Denys Vlasenko33576662018-06-28 14:10:00 +020017|| test x"$CONFIG_FEATURE_MOUNT_LOOP_CREATE" != x"y" \
Denys Vlasenkoda138242010-05-11 12:02:48 +020018|| test x"$CONFIG_FEATURE_MOUNT_FLAGS" != x"y" \
Denys Vlasenkobfa1b2e2010-05-11 03:53:57 +020019|| test x"$CONFIG_FEATURE_DEVFS" = x"y" \
20; then
21 echo "SKIPPED: mount"
22 exit 0
Chris Metcalf208d35d2010-04-02 09:57:27 +020023fi
24
Denys Vlasenkoc2fda862011-03-14 06:28:28 +010025testdir="$PWD/mount.testdir"
Denys Vlasenkoc1fc3d32009-07-18 17:22:03 +020026
Denys Vlasenko6ae64262009-07-18 16:22:26 +020027dd if=/dev/zero of=mount.image1m count=1 bs=1M 2>/dev/null || { echo "dd error"; exit 1; }
28mkfs.minix -v mount.image1m >/dev/null 2>&1 || { echo "mkfs.minix error"; exit 1; }
Denys Vlasenkoc1fc3d32009-07-18 17:22:03 +020029modprobe minix 2>/dev/null
30mkdir "$testdir" 2>/dev/null
31umount -d "$testdir" 2>/dev/null
Denis Vlasenko5d624622008-07-08 02:57:40 +000032
33# testing "test name" "command" "expected result" "file input" "stdin"
34# file input will be file called "input"
35# test can create a file "actual" instead of writing to stdout
36
37testing "mount -o remount,mand" \
Denis Vlasenkoabe49fa2008-07-11 21:41:14 +000038"mount -o loop mount.image1m $testdir "\
Denis Vlasenko5d624622008-07-08 02:57:40 +000039"&& grep -Fc $testdir </proc/mounts "\
40"&& mount -o remount,mand $testdir "\
Denys Vlasenkoc9a13112012-06-21 16:50:46 +020041"&& grep -F $testdir </proc/mounts | grep -c '[, ]mand[, ]'"\
42"|| grep -F $testdir </proc/mounts" \
Denis Vlasenko5d624622008-07-08 02:57:40 +000043 "1\n""1\n" \
44 "" ""
45
Denys Vlasenkoc1fc3d32009-07-18 17:22:03 +020046umount -d "$testdir"
47rmdir "$testdir"
Denis Vlasenkoabe49fa2008-07-11 21:41:14 +000048rm mount.image1m
Denis Vlasenko5d624622008-07-08 02:57:40 +000049
Denys Vlasenkoc2fda862011-03-14 06:28:28 +010050
51# Bug: mount.shared1 directory shows no files (has to show files a and b)
Denys Vlasenko47b03362011-08-10 10:45:48 +020052optional FEATURE_LS_RECURSIVE FEATURE_LS_SORTFILES
Denys Vlasenkoc2fda862011-03-14 06:28:28 +010053testing "mount bind+rshared" "\
54mkdir -p mount.dir mount.shared1 mount.shared2
55touch mount.dir/a mount.dir/b
56
57mount --bind mount.shared1 mount.shared1 2>&1
58mount --make-rshared mount.shared1 2>&1
59mount --bind mount.shared2 mount.shared2 2>&1
60mount --make-rshared mount.shared2 2>&1
61
62mount --bind mount.shared2 mount.shared1 2>&1
63mount --bind mount.dir mount.shared2 2>&1
64
65ls -R mount.dir mount.shared1 mount.shared2 2>&1
66
67umount mount.dir mount.shared1 mount.shared2 2>/dev/null
68umount mount.dir mount.shared1 mount.shared2 2>/dev/null
69umount mount.dir mount.shared1 mount.shared2 2>/dev/null
70rm -f mount.dir/a mount.dir/b mount.dir/c
71rmdir mount.dir mount.shared1 mount.shared2
72" \
73"\
74mount.dir:
75a
76b
77
78mount.shared1:
79a
80b
81
82mount.shared2:
83a
84b
85" \
86 "" ""
Denys Vlasenkob47b3ce2011-08-10 00:51:29 +020087SKIP=
Denys Vlasenkoc2fda862011-03-14 06:28:28 +010088
Denys Vlasenkoc9a13112012-06-21 16:50:46 +020089
90testing "mount RO loop" "\
91exec 2>&1
92umount -d mount.dir 2>/dev/null
93rmdir mount.dir 2>/dev/null
94mkdir -p mount.dir
95(
96cd mount.dir || { echo 'cd error'; exit 1; }
97mkdir z1 z2 || { echo 'mkdir error'; exit 1; }
98mount -t tmpfs tmpfs z1 || { echo 'mount tmpfs error'; exit 1; }
99dd if=/dev/zero of=z1/e2img count=10 bs=1M 2>/dev/null || { echo 'dd error'; exit 1; }
100mke2fs -F z1/e2img 2>/dev/null >&2 || { echo 'mke2fs error'; exit 1; }
101mount -r -o loop -t ext2 z1/e2img z2 || { echo 'mount -r -o loop error'; exit 1; }
102mount -o remount,ro z1 || { echo 'mount -o remount,ro error'; exit 1; }
103)
104umount -d mount.dir/z2
105##losetup -d /dev/loop*
106umount -d mount.dir/z1
107rm -rf mount.dir
108echo DONE
109" \
110"DONE\n" "" ""
111
112
Denis Vlasenko5d624622008-07-08 02:57:40 +0000113exit $FAILCOUNT