summaryrefslogtreecommitdiffstats
path: root/tests/ts/mount
diff options
context:
space:
mode:
authorKarel Zak2012-11-15 13:34:14 +0100
committerKarel Zak2012-11-15 13:34:14 +0100
commitbec4e32bfba6fe44d7aa988a5722f38d5bc2f4cc (patch)
tree7e0da1061653618538bee52d079380cae7b01372 /tests/ts/mount
parentumount: clean --recursive (diff)
downloadkernel-qcow2-util-linux-bec4e32bfba6fe44d7aa988a5722f38d5bc2f4cc.tar.gz
kernel-qcow2-util-linux-bec4e32bfba6fe44d7aa988a5722f38d5bc2f4cc.tar.xz
kernel-qcow2-util-linux-bec4e32bfba6fe44d7aa988a5722f38d5bc2f4cc.zip
tests: add umount --recursive test
Signed-off-by: Karel Zak <kzak@redhat.com>
Diffstat (limited to 'tests/ts/mount')
-rwxr-xr-xtests/ts/mount/umount-recursive90
1 files changed, 90 insertions, 0 deletions
diff --git a/tests/ts/mount/umount-recursive b/tests/ts/mount/umount-recursive
new file mode 100755
index 000000000..c01cc6a11
--- /dev/null
+++ b/tests/ts/mount/umount-recursive
@@ -0,0 +1,90 @@
+#!/bin/bash
+
+# Copyright (C) 2012 Karel Zak <kzak@redhat.com>
+
+TS_TOPDIR="$(dirname $0)/../.."
+TS_DESC="umount-recursive"
+
+. $TS_TOPDIR/functions.sh
+ts_init "$*"
+ts_skip_nonroot
+
+modprobe --dry-run --quiet scsi_debug
+[ "$?" == 0 ] || ts_skip "missing scsi_debug module"
+
+ts_log "Init device"
+$TS_CMD_UMOUNT --recursive $MOUNTPOINT &> /dev/null
+rmmod scsi_debug &> /dev/null
+modprobe scsi_debug dev_size_mb=50
+[ "$?" == 0 ] || ts_die "Cannot init device"
+
+sleep 3
+
+DEVNAME=$(grep scsi_debug /sys/block/*/device/model | awk -F '/' '{print $4}')
+[ "x${DEVNAME}" == "x" ] && ts_die "Cannot find device"
+
+DEVICE="/dev/${DEVNAME}"
+
+ts_log "Create partitions"
+$TS_CMD_FDISK ${DEVICE} &> /dev/null <<EOF
+n
+p
+1
+
++10M
+n
+p
+2
+
++10M
+n
+p
+3
+
++10M
+n
+p
+
++10M
+w
+q
+EOF
+
+ts_log "Create filesystem A"
+mkfs.ext2 ${DEVICE}1 &> /dev/null
+ts_log "Create filesystem B"
+mkfs.ext2 ${DEVICE}2 &> /dev/null
+ts_log "Create filesystem C"
+mkfs.ext2 ${DEVICE}3 &> /dev/null
+ts_log "Create filesystem D"
+mkfs.ext2 ${DEVICE}4 &> /dev/null
+
+
+ts_log "Do tests..."
+
+[ -d "$TS_MOUNTPOINT" ] || mkdir -p $TS_MOUNTPOINT
+
+ts_log "A) Mount root"
+$TS_CMD_MOUNT ${DEVICE}1 $TS_MOUNTPOINT >> $TS_OUTPUT 2>&1
+
+ts_log "B) Mount child"
+mkdir -p $TS_MOUNTPOINT/mntB
+$TS_CMD_MOUNT ${DEVICE}2 $TS_MOUNTPOINT/mntB >> $TS_OUTPUT 2>&1
+
+ts_log "C) Mount child/child"
+mkdir -p $TS_MOUNTPOINT/mntB/mnt{C,D}
+$TS_CMD_MOUNT ${DEVICE}3 $TS_MOUNTPOINT/mntB/mntC >> $TS_OUTPUT 2>&1
+
+ts_log "D) Mount child/child"
+$TS_CMD_MOUNT ${DEVICE}3 $TS_MOUNTPOINT/mntB/mntD >> $TS_OUTPUT 2>&1
+
+$TS_CMD_UMOUNT --recursive $TS_MOUNTPOINT >> $TS_OUTPUT 2>&1
+[ $? == 0 ] || ts_die "umount failed"
+
+sleep 3
+rmmod scsi_debug >> $TS_OUTPUT 2>&1
+[ $? == 0 ] || ts_die "device busy (umount failed?)"
+
+ts_log "Success"
+ts_finalize
+