mirror of
git://sourceware.org/git/lvm2.git
synced 2025-03-11 20:58:50 +03:00
tests: enhance mdadm_create
For older mdadm its hard to support new names - to simplify things keep using /dev/mdXXX name which is automatically selected.
This commit is contained in:
parent
7575c7ae5c
commit
370749a4b8
@ -710,26 +710,22 @@ cleanup_scsi_debug_dev() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
mdadm_create() {
|
mdadm_create() {
|
||||||
|
local devid
|
||||||
local mddev
|
local mddev
|
||||||
local maj=
|
|
||||||
local mdname="md_lvm_test0"
|
|
||||||
local mddir="md/"
|
|
||||||
local mddevdir="$DM_DEV_DIR/$mddir"
|
|
||||||
|
|
||||||
maj=$(mdadm --version 2>&1) || skip "mdadm tool is missing!"
|
which mdadm >/dev/null || skip "mdadm tool is missing!"
|
||||||
|
|
||||||
cleanup_md_dev
|
cleanup_md_dev
|
||||||
rm -f debug.log strace.log
|
rm -f debug.log strace.log
|
||||||
|
|
||||||
# Have MD use a non-standard name to avoid colliding with an existing MD device
|
# try to find free MD node
|
||||||
# - mdadm >= 3.0 requires that non-standard device names be in /dev/md/
|
# using the old naming /dev/mdXXX
|
||||||
# - newer mdadm _completely_ defers to udev to create the associated device node
|
# if we need more MD arrays test suite more likely leaked them
|
||||||
maj=${maj##*- v}
|
for devid in {127..150} ; do
|
||||||
maj=${maj%%.*}
|
test -b /dev/md${devid} || break
|
||||||
[ "$maj" -ge 3 ] || mddir=""
|
done
|
||||||
|
test "$devid" -lt "150" || skip "Cannot find free /dev/mdXXX node!"
|
||||||
mddev="/dev/${mddir}$mdname"
|
mddev=/dev/md${devid}
|
||||||
name=$1
|
|
||||||
|
|
||||||
mdadm --create "$mddev" "$@" || {
|
mdadm --create "$mddev" "$@" || {
|
||||||
# Some older 'mdadm' version managed to open and close devices internaly
|
# Some older 'mdadm' version managed to open and close devices internaly
|
||||||
@ -756,18 +752,17 @@ mdadm_create() {
|
|||||||
sleep .5
|
sleep .5
|
||||||
done
|
done
|
||||||
|
|
||||||
# LVM/DM will see this device
|
|
||||||
case "$DM_DEV_DIR" in
|
|
||||||
"/dev") readlink -f "$mddev" > MD_DEV_PV ;;
|
|
||||||
*) mkdir -p "$mddevdir"
|
|
||||||
rm -f "$mddevdir/$mdname"
|
|
||||||
cp -LR "$mddev" "$mddevdir"
|
|
||||||
echo "${mddevdir}${mdname}" > MD_DEV_PV ;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
mddev=$(readlink -f "$mddev")
|
|
||||||
test -b "$mddev" || skip "mdadm has not created device!"
|
test -b "$mddev" || skip "mdadm has not created device!"
|
||||||
echo "$mddev" > MD_DEV
|
echo "$mddev" > MD_DEV
|
||||||
|
|
||||||
|
# LVM/DM will see this device
|
||||||
|
case "$DM_DEV_DIR" in
|
||||||
|
"/dev") echo "$mddev" > MD_DEV_PV ;;
|
||||||
|
*) rm -f "$DM_DEV_DIR/md${devid}"
|
||||||
|
cp -LR "$mddev" "$DM_DEV_DIR"
|
||||||
|
echo "${DM_DEV_DIR}/md${devid}" > MD_DEV_PV ;;
|
||||||
|
esac
|
||||||
|
|
||||||
rm -f MD_DEVICES
|
rm -f MD_DEVICES
|
||||||
while [ "$#" -ne 0 ] ; do
|
while [ "$#" -ne 0 ] ; do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
@ -778,28 +773,28 @@ mdadm_create() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
cleanup_md_dev() {
|
cleanup_md_dev() {
|
||||||
test -f MD_DEV || return 0
|
|
||||||
grep -q "$(basename $(< MD_DEV) )" /proc/mdstat || {
|
|
||||||
rm -f MD_DEV
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
|
|
||||||
local IFS=$IFS_NL
|
local IFS=$IFS_NL
|
||||||
|
local i
|
||||||
local dev
|
local dev
|
||||||
|
local base
|
||||||
local mddev
|
local mddev
|
||||||
local mddev_pv
|
|
||||||
mddev=$(< MD_DEV)
|
|
||||||
mddev_pv=$(< MD_DEV_PV)
|
|
||||||
|
|
||||||
for i in {10..0} ; do
|
test -f MD_DEV || return 0
|
||||||
udev_wait
|
mddev=$(< MD_DEV)
|
||||||
mdadm --stop "$mddev" || true
|
base=$(basename "$mddev")
|
||||||
udev_wait # wait till events are process, not zeroing to early
|
|
||||||
grep -q "$(basename $(< MD_DEV) )" /proc/mdstat || break
|
for i in {0..10} ; do
|
||||||
|
grep -q "$base" /proc/mdstat || break
|
||||||
|
test "$i" = 0 || {
|
||||||
sleep .1
|
sleep .1
|
||||||
echo "$mddev is still present, stopping again"
|
echo "$mddev is still present, stopping again"
|
||||||
|
}
|
||||||
|
mdadm --stop "$mddev" || true
|
||||||
|
udev_wait # wait till events are process, not zeroing to early
|
||||||
done
|
done
|
||||||
test "$DM_DEV_DIR" != "/dev" && rm -rf "${mddev_pv%/*}"
|
|
||||||
|
test "$DM_DEV_DIR" != "/dev" && rm -f "$(< MD_DEV_PV)"
|
||||||
|
|
||||||
for dev in $(< MD_DEVICES); do
|
for dev in $(< MD_DEVICES); do
|
||||||
mdadm --zero-superblock "$dev" || true
|
mdadm --zero-superblock "$dev" || true
|
||||||
done
|
done
|
||||||
|
Loading…
x
Reference in New Issue
Block a user