mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-02 01:18:26 +03:00
cd6e1d0475
Add slight delay for waiting until 'started' dmeventd is responsing to other 'dmeventd -i' command. TODO: race observed here is somewhat unclear, might need some more details
132 lines
3.8 KiB
Bash
132 lines
3.8 KiB
Bash
#!/usr/bin/env bash
|
|
|
|
# Copyright (C) 2008 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
|
|
SKIP_WITH_LVMPOLLD=1
|
|
|
|
. lib/inittest
|
|
|
|
_wait_for_dmeventd() {
|
|
local local=${1-}
|
|
local pid=
|
|
for i in {1..50}; do
|
|
if test -n "$local" ; then
|
|
pid=$(pgrep -o dmeventd) || break;
|
|
fi
|
|
# Check pid and dmeventd readiness to communicate
|
|
test "$pid" = "$local" && dmeventd -i && break
|
|
sleep .2
|
|
done
|
|
}
|
|
|
|
_restart_dmeventd() {
|
|
#rm -f debug.log*
|
|
|
|
dmeventd -R -fldddd -e "$PWD/test_nologin" > debug.log_DMEVENTD_$RANDOM 2>&1 &
|
|
local local=$!
|
|
echo "$local" >LOCAL_DMEVENTD
|
|
|
|
_wait_for_dmeventd "$local"
|
|
|
|
if [ "$i" -eq 50 ]; then
|
|
# Unexpected - we waited over 10 seconds and
|
|
# dmeventd has not managed to restart
|
|
cat /run/dmeventd.pid || true
|
|
pgrep dmeventd || true
|
|
die "dmeventd restart is too slow: $(ps aux)"
|
|
fi
|
|
}
|
|
|
|
aux prepare_dmeventd
|
|
|
|
aux prepare_vg 5
|
|
|
|
lvcreate -aey --type mirror -m 3 --nosync --ignoremonitoring -l1 -n 4way $vg
|
|
lvchange --monitor y $vg/4way
|
|
lvcreate -aey --type mirror -m 2 --nosync --ignoremonitoring -l1 -n 3way $vg
|
|
lvchange --monitor y $vg/3way
|
|
|
|
lvcreate -aey -l1 -n $lv1 $vg
|
|
lvcreate -s -l1 -n $lv2 $vg/$lv1
|
|
|
|
_wait_for_dmeventd
|
|
_restart_dmeventd
|
|
|
|
check lv_field $vg/3way seg_monitor "monitored"
|
|
check lv_field $vg/4way seg_monitor "monitored"
|
|
lvchange --monitor y --verbose $vg/3way 2>&1 | tee lvchange.out
|
|
# only non-cluster tests can check command result
|
|
test -e LOCAL_CLVMD || grep 'already monitored' lvchange.out
|
|
lvchange --monitor y --verbose $vg/4way 2>&1 | tee lvchange.out
|
|
test -e LOCAL_CLVMD || grep 'already monitored' lvchange.out
|
|
|
|
# now try what happens if no dmeventd is running
|
|
pid=$(< LOCAL_DMEVENTD)
|
|
kill -9 "$pid"
|
|
# TODO/FIXME: it would be surely better, if the wait loop bellow would
|
|
# not be need however ATM the API for communication is not welldetecting
|
|
# this highly unusual race case - and things will simply timeout on
|
|
# reading failure within 4 seconds.
|
|
# Fixing would require to add some handling for losing FIFO connection
|
|
for i in {1..10}; do
|
|
# wait here for a while until dmeventd dies....
|
|
# suprisingly it's not instant and we can actually
|
|
# obtain list of monitored devices...
|
|
test -z $(ps -p "$pid" -o comm=) && break
|
|
sleep .1
|
|
done
|
|
rm LOCAL_DMEVENTD debug.log*
|
|
|
|
_restart_dmeventd
|
|
|
|
# now dmeventd should not be running
|
|
not pgrep dmeventd
|
|
rm LOCAL_DMEVENTD
|
|
|
|
# First lvs restarts 'dmeventd' (initiate a socket connection to a daemon)
|
|
# used explicit 'lvs' avoid using forked 'check' function here as that
|
|
# would furher for 'get' and actualy would be waint till whole process group
|
|
# exits - which is not what we want here
|
|
#
|
|
# FIXME/TODO: lvs should probably not be the way to 'fork dmeventd'
|
|
#
|
|
lvs --noheadings -o seg_monitor $vg/3way
|
|
|
|
check lv_field $vg/3way seg_monitor "not monitored"
|
|
pgrep -o dmeventd >LOCAL_DMEVENTD
|
|
check lv_field $vg/4way seg_monitor "not monitored"
|
|
|
|
lvchange --monitor y --verbose $vg/3way 2>&1 | tee lvchange.out
|
|
test -e LOCAL_CLVMD || not grep 'already monitored' lvchange.out
|
|
|
|
lvchange --monitor y --verbose $vg/$lv2 2>&1 | tee lvchange.out
|
|
test -e LOCAL_CLVMD || not grep 'already monitored' lvchange.out
|
|
|
|
_restart_dmeventd
|
|
|
|
kill -INT "$(< LOCAL_DMEVENTD)"
|
|
sleep 1
|
|
|
|
# dmeventd should be still present (although in 'exit-mode')
|
|
pgrep -o dmeventd
|
|
|
|
# Create a file simulating 'shutdown in progress'
|
|
touch test_nologin
|
|
sleep 2
|
|
|
|
# Should be now dead (within ~1 second)
|
|
not pgrep -o dmeventd
|
|
rm -f LOCAL_DMEVENTD
|
|
|
|
# Do not run dmeventd here again
|
|
vgremove -ff --config 'activation/monitoring = 0' $vg
|