2015-04-03 10:41:33 +02:00
#!/bin/sh
# Copyright (C) 2015 Red Hat, Inc. All rights reserved.
#
# This copyrighted material is made available to anyone wishing to use,
# modify, copy, or redistribute it subject to the terms and conditions
# of the GNU General Public License v.2.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software Foundation,
# Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
# Check whether all available pvmove resume methods works as expected.
# lvchange is able to resume pvmoves in progress.
# Moving 2 LVs in VG variant
. lib/inittest
2015-04-28 15:31:47 +02:00
aux prepare_pvs 2 30
2015-04-03 10:41:33 +02:00
vgcreate -s 128k $vg " $dev1 "
pvcreate --metadatacopies 0 " $dev2 "
vgextend $vg " $dev2 "
test_pvmove_resume( ) {
# 2 LVs on same device
lvcreate -an -Zn -l15 -n $lv1 $vg " $dev1 "
lvcreate -an -Zn -l15 -n $lv2 $vg " $dev1 "
aux delay_dev " $dev2 " 0 1000 $( get first_extent_sector " $dev2 " ) :
pvmove -i5 " $dev1 " &
PVMOVE = $!
aux wait_pvmove_lv_ready " $vg -pvmove0 " 300
kill -9 $PVMOVE
if test -e LOCAL_LVMPOLLD ; then
aux prepare_lvmpolld
fi
wait
while dmsetup status " $vg - $lv1 " ; do dmsetup remove " $vg - $lv1 " || true; done
while dmsetup status " $vg - $lv2 " ; do dmsetup remove " $vg - $lv2 " || true; done
while dmsetup status " $vg -pvmove0 " ; do dmsetup remove " $vg -pvmove0 " || true; done
check lv_attr_bit type $vg /pvmove0 "p"
if test -e LOCAL_CLVMD ; then
# giveup all clvmd locks (faster then restarting clvmd)
# no deactivation happen, nodes are already removed
#vgchange -an $vg
# FIXME: However above solution has one big problem
# as clvmd starts to abort on internal errors on various
# errors, based on the fact pvmove is killed -9
# Restart clvmd
kill $( < LOCAL_CLVMD)
for i in $( seq 1 100) ; do
test $i -eq 100 && die "Shutdown of clvmd is too slow."
test -e " $CLVMD_PIDFILE " || break
sleep .1
done # wait for the pid removal
aux prepare_clvmd
fi
2015-04-28 15:31:47 +02:00
aux notify_lvmetad " $dev1 " " $dev2 "
2015-04-03 10:41:33 +02:00
# call resume function (see below)
# with expected number of spawned
# bg polling as parameter
$1 1
aux enable_dev " $dev2 "
i = 0
while get lv_field $vg name -a | grep "^\[pvmove" ; do
# wait for 30 secs at max
test $i -ge 300 && die "Pvmove is too slow or does not progress."
sleep .1
i = $(( i + 1 ))
done
2015-04-28 15:31:47 +02:00
aux kill_listed_processes
2015-04-03 10:41:33 +02:00
lvremove -ff $vg
}
lvchange_single( ) {
2015-04-28 15:31:47 +02:00
LVM_TEST_TAG = " kill_me_ $PREFIX " lvchange -aey $vg /$lv1
LVM_TEST_TAG = " kill_me_ $PREFIX " lvchange -aey $vg /$lv2
2015-04-03 10:41:33 +02:00
}
lvchange_all( ) {
2015-04-28 15:31:47 +02:00
# remove -vvvv
LVM_TEST_TAG = " kill_me_ $PREFIX " lvchange -vvvv -aey $vg /$lv1 $vg /$lv2
2015-04-03 10:41:33 +02:00
# we don't want to spawn more than $1 background pollings
2015-04-28 15:31:47 +02:00
test $( aux count_processes_with_tag) -eq $1 || should false
2015-04-03 10:41:33 +02:00
}
vgchange_single( ) {
2015-04-28 15:31:47 +02:00
LVM_TEST_TAG = " kill_me_ $PREFIX " vgchange -aey $vg
2015-04-03 10:41:33 +02:00
2015-04-28 15:31:47 +02:00
test $( aux count_processes_with_tag) -eq $1
2015-04-03 10:41:33 +02:00
}
pvmove_fg( ) {
2015-04-28 15:31:47 +02:00
# pvmove resume requires LVs active...
LVM_TEST_TAG = " kill_me_ $PREFIX " vgchange --config 'activation{polling_interval=10}' -aey --poll n $vg
2015-04-03 10:41:33 +02:00
2015-04-28 15:31:47 +02:00
# ...also vgchange --poll n must not spawn any bg processes
test $( aux count_processes_with_tag) -eq 0
2015-04-03 10:41:33 +02:00
2015-04-28 15:31:47 +02:00
# ...thus finish polling
2015-04-03 10:41:33 +02:00
get lv_field $vg name -a | grep "^\[pvmove0\]"
aux enable_dev " $dev2 "
2015-04-28 15:31:47 +02:00
pvmove
2015-04-03 10:41:33 +02:00
}
pvmove_bg( ) {
2015-04-28 15:31:47 +02:00
# pvmove resume requires LVs active...
LVM_TEST_TAG = " kill_me_ $PREFIX " vgchange --config 'activation{polling_interval=10}' -aey --poll n $vg
2015-04-03 10:41:33 +02:00
2015-04-28 15:31:47 +02:00
# ...also vgchange --poll n must not spawn any bg processes
test $( aux count_processes_with_tag) -eq 0
2015-04-03 10:41:33 +02:00
2015-04-28 15:31:47 +02:00
# ...thus finish polling
2015-04-03 10:41:33 +02:00
get lv_field $vg name -a | grep "^\[pvmove0\]"
2015-04-28 15:31:47 +02:00
LVM_TEST_TAG = " kill_me_ $PREFIX " pvmove -b
2015-04-03 10:41:33 +02:00
}
pvmove_fg_single( ) {
2015-04-28 15:31:47 +02:00
# pvmove resume requires LVs active...
LVM_TEST_TAG = " kill_me_ $PREFIX " vgchange --config 'activation{polling_interval=10}' -aey --poll n $vg
2015-04-03 10:41:33 +02:00
2015-04-28 15:31:47 +02:00
# ...also vgchange --poll n must not spawn any bg processes
test $( aux count_processes_with_tag) -eq 0
2015-04-03 10:41:33 +02:00
2015-04-28 15:31:47 +02:00
# ...thus finish polling
2015-04-03 10:41:33 +02:00
get lv_field $vg name -a | grep "^\[pvmove0\]"
aux enable_dev " $dev2 "
2015-04-28 15:31:47 +02:00
pvmove " $dev1 "
2015-04-03 10:41:33 +02:00
}
pvmove_bg_single( ) {
2015-04-28 15:31:47 +02:00
# pvmove resume requires LVs active...
LVM_TEST_TAG = " kill_me_ $PREFIX " vgchange --config 'activation{polling_interval=10}' -aey --poll n $vg
2015-04-03 10:41:33 +02:00
2015-04-28 15:31:47 +02:00
# ...also vgchange --poll n must not spawn any bg processes...
test $( aux count_processes_with_tag) -eq 0
2015-04-03 10:41:33 +02:00
2015-04-28 15:31:47 +02:00
# ...thus finish polling
2015-04-03 10:41:33 +02:00
get lv_field $vg name -a | grep "^\[pvmove0\]"
2015-04-28 15:31:47 +02:00
LVM_TEST_TAG = " kill_me_ $PREFIX " pvmove -b " $dev1 "
2015-04-03 10:41:33 +02:00
}
test -e LOCAL_CLVMD && skip
test_pvmove_resume lvchange_single
test_pvmove_resume lvchange_all
test_pvmove_resume vgchange_single
test_pvmove_resume pvmove_fg
test_pvmove_resume pvmove_fg_single
test_pvmove_resume pvmove_bg
test_pvmove_resume pvmove_bg_single
vgremove -ff $vg