xref: /freebsd/tests/sys/geom/class/mirror/10_test.sh (revision 96950419f15510287080c557174e0d8409f06956)
1ca623e07SMark Johnston#!/bin/sh
2ca623e07SMark Johnston
3ca623e07SMark Johnston# Test handling of read errors.
4ca623e07SMark Johnston
5ca623e07SMark Johnston. $(dirname $0)/conf.sh
6ca623e07SMark Johnston
7ca623e07SMark Johnstonecho 1..3
8ca623e07SMark Johnston
9ca623e07SMark Johnstonset -e
10ca623e07SMark Johnston
11ca623e07SMark Johnstonddbs=2048
12ca623e07SMark Johnstonregreadfp="debug.fail_point.g_mirror_regular_request_read"
13ca623e07SMark Johnstonm1=$(mktemp $base.XXXXXX)
14ca623e07SMark Johnstonm2=$(mktemp $base.XXXXXX)
15ca623e07SMark Johnston
16ca623e07SMark Johnstondd if=/dev/random of=$m1 bs=$ddbs count=1024 >/dev/null 2>&1
17ca623e07SMark Johnstondd if=/dev/zero of=$m2 bs=$ddbs count=1024 >/dev/null 2>&1
18ca623e07SMark Johnston
19*96950419SGleb Smirnoffattach_md us0 -t vnode -f $m1
20*96950419SGleb Smirnoffattach_md us1 -t vnode -f $m2
21ca623e07SMark Johnston
22ca623e07SMark Johnstongmirror label $name /dev/$us0
23ca623e07SMark Johnstongmirror insert $name /dev/$us1
24ca623e07SMark Johnstondevwait
25ca623e07SMark Johnstonsyncwait
26ca623e07SMark Johnston
27ca623e07SMark Johnstontmp1=$(mktemp $base.XXXXXX)
28ca623e07SMark Johnstontmp2=$(mktemp $base.XXXXXX)
29ca623e07SMark Johnston
30ca623e07SMark JohnstonEIO=5
31ca623e07SMark Johnston# gmirror should retry a failed read from the other mirror.
323cee7cb2SBryan Drewerysysctl ${regreadfp}="1*return(${EIO})[pid $(gmirror_worker_pid)]"
33ca623e07SMark Johnstondd if=/dev/mirror/$name of=$tmp1 iseek=256 bs=$ddbs count=1 >/dev/null 2>&1
34ca623e07SMark Johnstondd if=/dev/$us1 of=$tmp2 iseek=256 bs=$ddbs count=1 >/dev/null 2>&1
35ca623e07SMark Johnstonsysctl ${regreadfp}='off'
36ca623e07SMark Johnston
37ca623e07SMark Johnstonif cmp -s $tmp1 $tmp2; then
38ca623e07SMark Johnston	echo "ok 1"
39ca623e07SMark Johnstonelse
40ca623e07SMark Johnston	echo "not ok 1"
41ca623e07SMark Johnstonfi
42ca623e07SMark Johnston
43ca623e07SMark Johnston# Make sure that one of the mirrors was marked broken.
44ca623e07SMark Johnstongenid1=$(gmirror dump /dev/$us0 | awk '/^[[:space:]]*genid: /{print $2}')
45ca623e07SMark Johnstongenid2=$(gmirror dump /dev/$us1 | awk '/^[[:space:]]*genid: /{print $2}')
46ca623e07SMark Johnstonif [ $genid1 -eq $(($genid2 + 1)) -o $genid2 -eq $(($genid1 + 1)) ]; then
47ca623e07SMark Johnston	echo "ok 2"
48ca623e07SMark Johnstonelse
49ca623e07SMark Johnston	echo "not ok 2"
50ca623e07SMark Johnstonfi
51ca623e07SMark Johnston
52ca623e07SMark Johnston# Force a retaste of the disconnected component.
53ca623e07SMark Johnstonif [ $(gmirror status -s $name | awk '{print $3}') = $us0 ]; then
54ca623e07SMark Johnston	detach_md $us1
55*96950419SGleb Smirnoff	attach_md us1 -t vnode -f $m2
56ca623e07SMark Johnstonelse
57ca623e07SMark Johnston	detach_md $us0
58*96950419SGleb Smirnoff	attach_md us0 -t vnode -f $m1
59ca623e07SMark Johnstonfi
60ca623e07SMark Johnston
61ca623e07SMark Johnston# Make sure that the component wasn't re-added to the gmirror.
62ca623e07SMark Johnstonif [ $(gmirror status -s $name | wc -l) -eq 1 ]; then
63ca623e07SMark Johnston	echo "ok 3"
64ca623e07SMark Johnstonelse
65ca623e07SMark Johnston	echo "not ok 3"
66ca623e07SMark Johnstonfi
67ca623e07SMark Johnston
68ca623e07SMark Johnstonrm -f $m1 $m2 $tmp1 $tmp2
69