Allow other device types for testing; this allows to test on a larger variety of devices. Option --dev=[loop|lvm|ram] selects loop device (default), lvm, and ram disk, respecively. To use RAM disks with DDF, the kernel parameter ramdisk_size=65536 must be used. For LVM, use --volgroup=<vg> to specify the name of the volume group in which the test LVs will be created. Signed-off-by: Martin Wilck <mwilck@xxxxxxxx> --- test | 69 +++++++++++++++++++++++++++++++++++++++++++++++++++++------------ 1 files changed, 56 insertions(+), 13 deletions(-) diff --git a/test b/test index 8e8d1df..1e89788 100755 --- a/test +++ b/test @@ -29,6 +29,8 @@ if grep -s 'Personalities : .*multipath' > /dev/null /proc/mdstat ; then MULTIPATH="yes" fi INTEGRITY=yes +DEVTYPE=loop +LVM_VOLGROUP=mdtest # make sure to test local mdmon, not system one export MDADM_NO_SYSTEMCTL=1 @@ -67,11 +69,21 @@ config=/tmp/mdadm.conf cleanup() { udevadm settle $mdadm -Ssq 2> /dev/null - for d in 0 1 2 3 4 5 6 7 8 9 10 11 12 13 - do + case $DEVTYPE in + loop) + for d in 0 1 2 3 4 5 6 7 8 9 10 11 12 13 + do losetup -d /dev/loop$d ; # rm -f $targetdir/mdtest$d rm -f /dev/disk/by-path/loop* - done + done + ;; + lvm) + for d in 0 1 2 3 4 5 6 7 8 9 10 11 12 13 + do + eval "lvremove --quiet -f \$dev$d" + done + ;; + esac } ctrl_c() { @@ -87,16 +99,33 @@ do_setup() { do sz=$size if [ $d -gt 7 ]; then sz=$ddfsize ; fi - [ -f $targetdir/mdtest$d ] || dd if=/dev/zero of=$targetdir/mdtest$d count=$sz bs=1K > /dev/null 2>&1 - [ -b /dev/loop$d ] || mknod /dev/loop$d b 7 $d - if [ $d -eq 7 ] - then - losetup /dev/loop$d $targetdir/mdtest6 # for multipath use - else - losetup /dev/loop$d $targetdir/mdtest$d - fi - eval dev$d=/dev/loop$d - eval file$d=$targetdir/mdtest$d + case $DEVTYPE in + loop) + [ -f $targetdir/mdtest$d ] || dd if=/dev/zero of=$targetdir/mdtest$d count=$sz bs=1K > /dev/null 2>&1 + [ -b /dev/loop$d ] || mknod /dev/loop$d b 7 $d + if [ $d -eq 7 ] + then + losetup /dev/loop$d $targetdir/mdtest6 # for multipath use + else + losetup /dev/loop$d $targetdir/mdtest$d + fi + eval dev$d=/dev/loop$d + eval file$d=$targetdir/mdtest$d + ;; + lvm) + unset MULTIPATH + eval dev$d=/dev/mapper/${LVM_VOLGROUP}-mdtest$d + if ! lvcreate --quiet -L ${sz}K -n mdtest$d $LVM_VOLGROUP; then + trap '' 0 # make sure lvremove is not called + eval echo error creating \$dev$d + exit 129 + fi + ;; + ram) + unset MULTIPATH + eval dev$d=/dev/ram$d + ;; + esac eval devlist=\"\$devlist \$dev$d\" eval devlist$d=\"\$devlist\" #" <-- add this quote to un-confuse vim syntax highlighting @@ -279,6 +308,8 @@ do_help() { echo " --logdir=<directory> Directory to save logfiles in" echo " --save-logs Save all logs in <logdir>" echo " --keep-going Don't stop on error, ie. run all tests" + echo " --dev=[loop|lvm|ram] Use loop devices (default), LVM, or RAM disk" + echo " --volgroup=<name> LVM volume group for LVM test" echo " setup Setup test environment and exit" echo " cleanup Cleanup test environment" echo " <prefix> Run tests with <prefix>" @@ -324,6 +355,18 @@ parse_args() { --disable-integrity) unset INTEGRITY ;; + --dev=loop) + DEVTYPE=loop + ;; + --dev=lvm) + DEVTYPE=lvm + ;; + --dev=ram) + DEVTYPE=ram + ;; + --volgroup=*) + LVM_VOLGROUP=`expr "x$i" : 'x[^=]*=\(.*\)'` + ;; --help) do_help exit 0; -- 1.7.1 -- To unsubscribe from this list: send the line "unsubscribe linux-raid" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html