]> git.ipfire.org Git - thirdparty/mdadm.git/blame - test
Allow --update=name to update the name during assembly.
[thirdparty/mdadm.git] / test
CommitLineData
5e7519fa
NB
1#!/bin/sh
2#
3# run test suite for mdadm
4user=`id -un`
5if [ " $user" != " root" ]
6then echo >&2 "test: testing can only be done as 'root'."
7 exit 1;
8fi
9
10prefix='[0-9][0-9]'
11if [ -n "$1" ]
12then prefix=$1
13fi
14
15dir=`pwd`
16mdadm=$dir/mdadm
5e7519fa
NB
17if [ \! -x $mdadm ]
18then
19 echo >&2 "test: $mdadm isn't usable."
20fi
21
5e7519fa 22# assume md0, md1, md2 exist in /dev
dab6685f 23md0=/dev/md0 md1=/dev/md1 md2=/dev/md2
5e7519fa
NB
24
25# We test mdadm on loop-back block devices.
26# dir for storing files should be settable by command line maybe
1bf4e2d9 27targetdir=/var/tmp
5e7519fa
NB
28size=20000
29mdsize0=19904
1bf4e2d9
NB
30mdsize1=19992
31mdsize11=19996
32mdsize12=19992
5e7519fa
NB
33
34cleanup() {
35 $mdadm -Ss
36 for d in 0 1 2 3 4 5 6 7
37 do losetup -d /dev/loop$d ; # rm -f $targetdir/mdtest$d
38 done
39}
40
41trap cleanup 0 1 2 3 15
42
43devlist=
44for d in 0 1 2 3 4 5 6 7
45do
46 [ -f $targetdir/mdtest$d ] || dd if=/dev/zero of=$targetdir/mdtest$d count=$size bs=1K > /dev/null 2>&1
c13c45e9
NB
47 if [ $d -eq 7 ]
48 then
49 losetup /dev/loop$d $targetdir/mdtest6 # for multipath use
50 else
51 losetup /dev/loop$d $targetdir/mdtest$d
52 fi
dab6685f 53 eval dev$d=/dev/loop$d
fe80f49b 54 eval file$d=$targetdir/mdtest$d
5e7519fa
NB
55 eval devlist=\"\$devlist \$dev$d\"
56done
c13c45e9
NB
57path0=$dev6
58path1=$dev7
59
5a6d7f45
NB
60if [ " $1" = " setup" ]
61then trap 0 ; exit 0
62fi
dab6685f
NB
63
64# mdadm always adds --quiet, and we want to see any unexpected messages
65mdadm() {
9860f271
NB
66 case $* in
67 *-C* ) $mdadm --quiet "$@" --auto=yes;;
68 * ) $mdadm --quiet "$@"
69 esac
dab6685f
NB
70}
71
72# check various things
73check() {
74 case $1 in
308e1801
NB
75 spares )
76 spares=`tr '] ' '\012\012' < /proc/mdstat | grep -c '(S)' || exit 0`
77 if [ $spares -ne $2 ]
78 then
79 echo >&2 "ERROR expected $2 spares, found $spares"; exit 1;
80 fi
81 ;;
dab6685f
NB
82 raid* | linear )
83 grep -s "active $1 " /proc/mdstat > /dev/null || {
84 echo >&2 "ERROR active $1 not found" ; cat /proc/mdstat ; exit 1;}
85 ;;
86 resync | recovery )
0ba1565f 87 sleep 0.5
dab6685f
NB
88 grep -s $1 /proc/mdstat > /dev/null || {
89 echo >&2 ERROR no $1 happening; cat /proc/mdstat; exit 1; }
90 ;;
91
92 nosync )
93 sleep 0.5
94 if grep -s 're[synccovery]* =' > /dev/null /proc/mdstat ; then
95 echo >&2 "ERROR resync or recovery is happening!"; cat /proc/mdstat ; exit 1;
96 fi
97 ;;
98
99 wait )
100 sleep 0.1
101 while grep 're[synccovery]* =' > /dev/null /proc/mdstat
102 do sleep 2;
103 done
104 ;;
105
106 state )
107 grep -s "blocks.*\[$2\]\$" /proc/mdstat > /dev/null || {
108 echo >&2 "ERROR state $2 not found!"; cat /proc/mdstat ; exit 1; }
109 sleep 0.5
110 ;;
fe80f49b
NB
111
112 bitmap )
113 grep -s bitmap > /dev/null /proc/mdstat || {
34163fc7 114 echo >&2 ERROR no bitmap ; cat /proc/mdstat ; exit 1; }
fe80f49b
NB
115 ;;
116 nobitmap )
117 if grep -s "bitmap" > /dev/null /proc/mdstat
118 then
119 echo >&2 ERROR bitmap present ; cat /proc/mdstat ; exit 1;
120 fi
121 ;;
dab6685f
NB
122
123 * ) echo >&2 ERROR unknown check $1 ; exit 1;
124 esac
125}
126
127# basic device test
128
129testdev() {
130 dev=$1
131 cnt=$2
132 dvsize=$3
133 chunk=$4
134 mkfs -j $dev > /dev/null 2>&1 && fsck -fn $dev >&2
135 dsize=$[dvsize/chunk]
136 dsize=$[dsize*chunk]
137 rasize=$[dsize*1024*cnt]
138 if [ $rasize -ne `/sbin/blockdev --getsize64 $dev` ]
139 then
140 echo "ERROR: size is wrong for $dev: $cnt * $dvsize (chunk=$chunk) = $rasize, not `/sbin/blockdev --getsize64 $dev`"
141 exit 1
142 fi
143}
144
c13c45e9
NB
145rotest() {
146 dev=$1
147 fsck -fn $dev >&2
148}
149
5e7519fa
NB
150
151
34163fc7 152for script in tests/$prefix tests/$prefix*[^~]
5e7519fa 153do
34163fc7
NB
154 if [ -f "$script" ]
155 then
dab6685f
NB
156 # source script in a subshell, so it has access to our
157 # namespace, but cannot change it.
158 if ( set -ex ; . $script ) 2> $targetdir/log
159 then echo "$script succeeded"
5e7519fa
NB
160 else cat $targetdir/log
161 echo "$script failed"
162 exit 1
163 fi
34163fc7 164 fi
5e7519fa
NB
165done
166exit 0