summaryrefslogtreecommitdiffstats
path: root/tests/10ddf-fail-readd-readonly
blob: 3936394c5e71c24cd2ad137f09d10f637efd57a3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
# Simple fail / re-add test
. tests/env-ddf-template

tmp=$(mktemp /tmp/mdtest-XXXXXX)
rm -f $tmp

mdadm --zero-superblock $dev8 $dev9
mdadm -CR $container -e ddf -l container -n 2 $dev8 $dev9

mdadm -CR $member0 -l raid1 -n 2 $container
#$dir/mdadm -CR $member0 -l raid1 -n 2 $container >/tmp/mdmon.txt 2>&1

check wait

set -- $(get_raiddisks $member0)
fail0=$1
mdadm $member0 --fail $fail0

sleep 2
set -- $(get_raiddisks $member0)
case $1 in MISSING) shift;; esac
good0=$1

# Check that the meta data now show one disk as failed
ret=0
for x in $@; do
    mdadm -E $x  >$tmp
    if ! grep -q 'state\[0\] : Degraded, Consistent' $tmp; then
	echo ERROR: member 0 should be degraded in meta data on $x
	ret=1
    fi
    phys=$(grep $x $tmp)
    case $x:$phys in
    $fail0:*active/Offline,\ Failed);;
    $good0:*active/Online);;
    *) echo ERROR: wrong phys disk state for $x
       ret=1
       ;;
    esac
done

mdadm $container --remove $fail0

# We re-add the disk now
mdadm $container --add $fail0

sleep 2
mdadm --wait $member0 || true

set -- $(get_raiddisks $member0)
case $1:$2 in
    $dev8:$dev9|$dev9:$dev8);;
    *) echo ERROR: bad raid disks "$@"; ret=1;;
esac

mdadm -Ss
for x in $@; do
    mdadm -E $x  >$tmp
    if ! grep -q 'state\[0\] : Optimal, Consistent' $tmp; then
	echo ERROR: member 0 should be optimal in meta data on $x
	ret=1
    fi
done

rm -f $tmp
if [ $ret -ne 0 ]; then
    mdadm -E $dev8
    mdadm -E $dev9
fi

[ $ret -eq 0 ]