]>
git.ipfire.org Git - thirdparty/mdadm.git/blob - test
3 # run test suite for mdadm
5 if [ " $user" != " root" ]
6 then echo >&2 "test: testing can only be done as 'root'."
19 echo >&2 "test: $mdadm isn't usable."
22 export check
="sh $dir/tests/check"
24 # assume md0, md1, md2 exist in /dev
25 md0
=/dev
/md0 md1
=/dev
/md1 md2
=/dev
/md2
27 # We test mdadm on loop-back block devices.
28 # dir for storing files should be settable by command line maybe
36 for d
in 0 1 2 3 4 5 6 7
37 do losetup
-d /dev
/loop
$d ; # rm -f $targetdir/mdtest$d
41 trap cleanup
0 1 2 3 15
44 for d
in 0 1 2 3 4 5 6 7
46 [ -f $targetdir/mdtest
$d ] ||
dd if=/dev
/zero of
=$targetdir/mdtest
$d count
=$size bs
=1K
> /dev
/null
2>&1
47 losetup
/dev
/loop
$d $targetdir/mdtest
$d
48 eval dev
$d=/dev
/loop
$d
49 eval devlist
=\"\
$devlist \
$dev$d\"
52 # mdadm always adds --quiet, and we want to see any unexpected messages
54 $mdadm 2>&1 --quiet "$@"
57 # check various things
61 grep -s "active $1 " /proc
/mdstat
> /dev
/null ||
{
62 echo >&2 "ERROR active $1 not found" ; cat /proc
/mdstat
; exit 1;}
66 grep -s $1 /proc
/mdstat
> /dev
/null ||
{
67 echo >&2 ERROR no
$1 happening
; cat /proc
/mdstat
; exit 1; }
72 if grep -s 're[synccovery]* =' > /dev
/null
/proc
/mdstat
; then
73 echo >&2 "ERROR resync or recovery is happening!"; cat /proc
/mdstat
; exit 1;
79 while grep 're[synccovery]* =' > /dev
/null
/proc
/mdstat
85 grep -s "blocks.*\[$2\]\$" /proc
/mdstat
> /dev
/null ||
{
86 echo >&2 "ERROR state $2 not found!"; cat /proc
/mdstat
; exit 1; }
90 * ) echo >&2 ERROR unknown check
$1 ; exit 1;
101 mkfs
-j $dev > /dev
/null
2>&1 && fsck
-fn $dev >&2
102 dsize
=$
[dvsize
/chunk
]
104 rasize
=$
[dsize
*1024*cnt
]
105 if [ $rasize -ne `/sbin/blockdev --getsize64 $dev` ]
107 echo "ERROR: size is wrong for $dev: $cnt * $dvsize (chunk=$chunk) = $rasize, not `/sbin/blockdev --getsize64 $dev`"
114 for script in tests
/$prefix*[^~
]
116 # source script in a subshell, so it has access to our
117 # namespace, but cannot change it.
118 if ( set -ex ; .
$script ) 2> $targetdir/log
119 then echo "$script succeeded"
120 else cat $targetdir/log
121 echo "$script failed"