X-Git-Url: http://git.ipfire.org/?a=blobdiff_plain;f=test;h=a31ad40fd379470d15829c2d2bcb4a8f933698d0;hb=9b0502b879dc6308428bc2bce4f8e1b56fc93f6c;hp=9ceb531e7a3e3fe882f349931d75c7523655fa01;hpb=b01b06bda8dce132e6eb3c3826ad0f4b94ebdf43;p=thirdparty%2Fmdadm.git diff --git a/test b/test index 9ceb531e..a31ad40f 100644 --- a/test +++ b/test @@ -34,14 +34,24 @@ mdsize0=19904 mdsize00=19840 # super1.0 round down to multiple of 2, subtract 8 mdsize1=19992 +mdsize1a=19988 +mdsize12=19988 +# super1.2 for linear: round to multiple of 2, subtract 4 +mdsize1_l=18976 +mdsize2_l=18976 # subtract another 4 for bitmaps mdsize1b=19988 mdsize11=19992 +mdsize11a=18944 mdsize12=19988 +# ddf needs bigger devices as 32Meg is reserved! +ddfsize=65536 + cleanup() { - $mdadm -Ss - for d in 0 1 2 3 4 5 6 7 + udevadm settle + $mdadm -Ssq + for d in 0 1 2 3 4 5 6 7 8 9 10 11 12 do losetup -d /dev/loop$d ; # rm -f $targetdir/mdtest$d done @@ -50,9 +60,11 @@ cleanup() { trap cleanup 0 1 2 3 15 devlist= -for d in 0 1 2 3 4 5 6 7 +for d in 0 1 2 3 4 5 6 7 8 9 10 11 12 do - [ -f $targetdir/mdtest$d ] || dd if=/dev/zero of=$targetdir/mdtest$d count=$size bs=1K > /dev/null 2>&1 + 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 @@ -63,10 +75,13 @@ do eval dev$d=/dev/loop$d eval file$d=$targetdir/mdtest$d eval devlist=\"\$devlist \$dev$d\" + #" <-- add this quote to un-confuse vim syntax highlighting done path0=$dev6 path1=$dev7 +ulimit -c unlimited +[ -f /proc/mdstat ] || modprobe md_mod echo 2000 > /proc/sys/dev/raid/speed_limit_max echo 0 > /sys/module/md_mod/parameters/start_ro @@ -77,11 +92,16 @@ fi # mdadm always adds --quiet, and we want to see any unexpected messages mdadm() { rm -f $targetdir/stderr + case $* in + *-S* ) udevadm settle;; + esac case $* in *-C* ) $mdadm 2> $targetdir/stderr --quiet "$@" --auto=yes;; * ) $mdadm 2> $targetdir/stderr --quiet "$@" esac + rv=$? cat >&2 $targetdir/stderr + return $rv } # check various things @@ -147,14 +167,22 @@ no_errors() { # basic device test testdev() { + udevadm settle dev=$1 cnt=$2 dvsize=$3 chunk=$4 - mkfs -j $dev > /dev/null 2>&1 && fsck -fn $dev >&2 + if [ -z "$5" ]; then + mkfs -j $dev > /dev/null 2>&1 && fsck -fn $dev >&2 + fi dsize=$[dvsize/chunk] dsize=$[dsize*chunk] rasize=$[dsize*2*cnt] + # rasize is in sectors + if [ -n "$DEV_ROUND_K" ]; then + rasize=$[rasize/DEV_ROUND_K/2] + rasize=$[rasize*DEV_ROUND_K*2] + fi if [ `/sbin/blockdev --getsize $dev` -eq 0 ]; then sleep 2 ; fi if [ $rasize -ne `/sbin/blockdev --getsize $dev` ] then @@ -168,7 +196,20 @@ rotest() { fsck -fn $dev >&2 } +setup_environment() { + if [ -f $1 ]; then + . $environment + setup_env + fi +} +reset_environment() { + if [ -f $1 ]; then + reset_env + unset setup_env + unset reset_env + fi +} for script in tests/$prefix tests/$prefix*[^~] do @@ -177,14 +218,20 @@ do rm -f $targetdir/stderr # stop all arrays, just incase some script left an array active. mdadm -Ssq + mdadm --zero $devlist 2> /dev/null + mdadm --zero $devlist 2> /dev/null + environment="tests/env-`basename $script`" + setup_environment $environment # source script in a subshell, so it has access to our # namespace, but cannot change it. if ( set -ex ; . $script ) 2> $targetdir/log then echo "$script succeeded" else cat $targetdir/log ; cat $targetdir/stderr echo "$script failed" + reset_environment $environment exit 1 fi + reset_environment $environment fi done exit 0