ad8ebc35bb
exit so things are cleaned up properly - Use attach_md for attaching md(4) devices - Don't hardcode /tmp for temporary files, which violates the kyua sandbox MFC after: 3 weeks Sponsored by: EMC / Isilon Storage Division
44 lines
1.1 KiB
Bash
44 lines
1.1 KiB
Bash
#!/bin/sh
|
|
# $FreeBSD$
|
|
|
|
. `dirname $0`/conf.sh
|
|
|
|
echo "1..1"
|
|
|
|
ddbs=2048
|
|
nblocks1=1024
|
|
nblocks2=`expr $nblocks1 / \( $ddbs / 512 \)`
|
|
src=`mktemp $base.XXXXXX` || exit 1
|
|
dst=`mktemp $base.XXXXXX` || exit 1
|
|
|
|
us0=$(attach_md -t malloc -s $(expr $nblocks1 + 1)) || exit 1
|
|
us1=$(attach_md -t malloc -s $(expr $nblocks1 + 1)) || exit 1
|
|
us2=$(attach_md -t malloc -s $(expr $nblocks1 + 1)) || exit 1
|
|
|
|
dd if=/dev/random of=${src} bs=$ddbs count=$nblocks2 >/dev/null 2>&1
|
|
|
|
graid3 label $name /dev/${us0} /dev/${us1} /dev/${us2} || exit 1
|
|
devwait
|
|
|
|
dd if=${src} of=/dev/raid3/${name} bs=$ddbs count=$nblocks2 >/dev/null 2>&1
|
|
|
|
#
|
|
# Rebuild of PARITY component.
|
|
#
|
|
graid3 remove -n 2 $name
|
|
dd if=/dev/zero of=/dev/${us2} bs=512 count=`expr $nblocks1 + 1` >/dev/null 2>&1
|
|
graid3 insert -n 2 $name md${us2}
|
|
sleep 1
|
|
# Remove DATA component, so PARITY component can be used while reading.
|
|
graid3 remove -n 1 $name
|
|
dd if=/dev/zero of=/dev/${us1} bs=512 count=`expr $nblocks1 + 1` >/dev/null 2>&1
|
|
|
|
dd if=/dev/raid3/${name} of=${dst} bs=$ddbs count=$nblocks2 >/dev/null 2>&1
|
|
if [ `md5 -q ${src}` != `md5 -q ${dst}` ]; then
|
|
echo "not ok 1"
|
|
else
|
|
echo "ok 1"
|
|
fi
|
|
|
|
rm -f ${src} ${dst}
|