diff options
author | Karel Zak | 2013-02-26 14:59:07 +0100 |
---|---|---|
committer | Karel Zak | 2013-02-26 14:59:07 +0100 |
commit | e0688353db8884f2ebbdabe764d7e9234841f49f (patch) | |
tree | 621d881299d0427fe0a3a7f3712ef7615e422238 | |
parent | umount: add --all-targets (diff) | |
download | kernel-qcow2-util-linux-e0688353db8884f2ebbdabe764d7e9234841f49f.tar.gz kernel-qcow2-util-linux-e0688353db8884f2ebbdabe764d7e9234841f49f.tar.xz kernel-qcow2-util-linux-e0688353db8884f2ebbdabe764d7e9234841f49f.zip |
tests: add umount --all-targets tests
Signed-off-by: Karel Zak <kzak@redhat.com>
-rw-r--r-- | tests/expected/mount/umount-alltargets | 7 | ||||
-rw-r--r-- | tests/expected/mount/umount-alltargets-all-targets-dev | 3 | ||||
-rw-r--r-- | tests/expected/mount/umount-alltargets-all-targets-mnt | 3 | ||||
-rw-r--r-- | tests/expected/mount/umount-alltargets-all-targets-recursive | 3 | ||||
-rwxr-xr-x | tests/ts/mount/umount-alltargets | 121 |
5 files changed, 137 insertions, 0 deletions
diff --git a/tests/expected/mount/umount-alltargets b/tests/expected/mount/umount-alltargets new file mode 100644 index 000000000..53514d1c0 --- /dev/null +++ b/tests/expected/mount/umount-alltargets @@ -0,0 +1,7 @@ +Init device +Create partitions +Create filesystem A +Create filesystem B +Create filesystem C +Create filesystem D +Success diff --git a/tests/expected/mount/umount-alltargets-all-targets-dev b/tests/expected/mount/umount-alltargets-all-targets-dev new file mode 100644 index 000000000..7d6f88861 --- /dev/null +++ b/tests/expected/mount/umount-alltargets-all-targets-dev @@ -0,0 +1,3 @@ +prepare: Mount dev to mnt1 +prepare: Mount dev to mnt2 +prepare: Mount /dev/xxx1 to mnt3 diff --git a/tests/expected/mount/umount-alltargets-all-targets-mnt b/tests/expected/mount/umount-alltargets-all-targets-mnt new file mode 100644 index 000000000..7d6f88861 --- /dev/null +++ b/tests/expected/mount/umount-alltargets-all-targets-mnt @@ -0,0 +1,3 @@ +prepare: Mount dev to mnt1 +prepare: Mount dev to mnt2 +prepare: Mount /dev/xxx1 to mnt3 diff --git a/tests/expected/mount/umount-alltargets-all-targets-recursive b/tests/expected/mount/umount-alltargets-all-targets-recursive new file mode 100644 index 000000000..7d6f88861 --- /dev/null +++ b/tests/expected/mount/umount-alltargets-all-targets-recursive @@ -0,0 +1,3 @@ +prepare: Mount dev to mnt1 +prepare: Mount dev to mnt2 +prepare: Mount /dev/xxx1 to mnt3 diff --git a/tests/ts/mount/umount-alltargets b/tests/ts/mount/umount-alltargets new file mode 100755 index 000000000..071372bca --- /dev/null +++ b/tests/ts/mount/umount-alltargets @@ -0,0 +1,121 @@ +#!/bin/bash + +# Copyright (C) 2013 Karel Zak <kzak@redhat.com> + +TS_TOPDIR="$(dirname $0)/../.." +TS_DESC="umount-all-targets" + +. $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 + +function multi_mount() { + local DEV=$1 + local MNT=$2 + + ts_log "prepare: Mount dev to mnt1" + [ -d "${MNT}1" ] || mkdir -p ${MNT}1 + $TS_CMD_MOUNT $DEV ${MNT}1 >> $TS_OUTPUT 2>&1 + + ts_log "prepare: Mount dev to mnt2" + [ -d "${MNT}2" ] || mkdir -p ${MNT}2 + $TS_CMD_MOUNT $DEV ${MNT}2 >> $TS_OUTPUT 2>&1 + + ts_log "prepare: Mount /dev/xxx1 to mnt3" + [ -d "${MNT}3" ] || mkdir -p ${MNT}3 + $TS_CMD_MOUNT $DEV ${MNT}3 >> $TS_OUTPUT 2>&1 +} + +# use the same top-level mountpoint for all sub-tests +MOUNTPOINT=$TS_MOUNTPOINT + +# +# The same device mounted on more places, umount all by mountpoint name +# +ts_init_subtest "all-targets-mnt" +multi_mount ${DEVICE}1 $MOUNTPOINT +$TS_CMD_UMOUNT --all-targets ${MOUNTPOINT}1 >> $TS_OUTPUT 2>&1 +[ $? == 0 ] || ts_log "umount failed" +ts_finalize_subtest + +# +# The same device mounted on more places, umount all by device name +# +ts_init_subtest "all-targets-dev" +multi_mount ${DEVICE}1 $MOUNTPOINT +$TS_CMD_UMOUNT --all-targets ${DEVICE}1 >> $TS_OUTPUT 2>&1 +[ $? == 0 ] || ts_log "umount failed" +ts_finalize_subtest + +# +# The same device mounted on more places, one of the mountpoints also contains +# sub-mounts. Umount all by one umount all by top-level device name. +# +ts_init_subtest "all-targets-recursive" +multi_mount ${DEVICE}1 $MOUNTPOINT +[ -d "${MOUNTPOINT}1/subA" ] || mkdir -p ${MOUNTPOINT}1/subA +$TS_CMD_MOUNT ${DEVICE}2 ${MOUNTPOINT}1/subA +[ -d "${MOUNTPOINT}1/subA/subAB" ] || mkdir -p ${MOUNTPOINT}1/subA/subAB +$TS_CMD_MOUNT ${DEVICE}3 ${MOUNTPOINT}1/subA/subAB +[ -d "${MOUNTPOINT}1/subB" ] || mkdir -p ${MOUNTPOINT}1/subB +$TS_CMD_MOUNT ${DEVICE}4 ${MOUNTPOINT}1/subB +$TS_CMD_UMOUNT --recursive --all-targets ${DEVICE}1 >> $TS_OUTPUT 2>&1 +[ $? == 0 ] || ts_log "umount failed" +ts_finalize_subtest + +sleep 3 +rmmod scsi_debug >> $TS_OUTPUT 2>&1 +[ $? == 0 ] || ts_die "device busy (umount failed?)" + +ts_log "Success" +ts_finalize |