2017-07-02 22:38:32 +03:00
#!/usr/bin/env bash
2010-10-27 13:16:31 +04:00
# 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,
2016-01-21 13:49:46 +03:00
# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
2010-10-27 13:16:31 +04:00
2018-05-24 17:49:48 +03:00
2015-10-27 17:10:06 +03:00
SKIP_WITH_LVMPOLLD = 1
2010-10-27 13:16:31 +04:00
2015-10-27 17:10:06 +03:00
. lib/inittest
2015-05-09 02:59:18 +03:00
2024-05-10 18:48:47 +03:00
_wait_for_dmeventd( ) {
local local = ${ 1 - }
2024-04-10 00:29:15 +03:00
local pid =
2024-05-10 18:48:47 +03:00
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( ) {
2023-10-07 11:39:56 +03:00
#rm -f debug.log*
dmeventd -R -fldddd -e " $PWD /test_nologin " > debug.log_DMEVENTD_$RANDOM 2>& 1 &
2024-04-12 00:43:27 +03:00
local local = $!
echo " $local " >LOCAL_DMEVENTD
2023-10-07 11:39:56 +03:00
2024-05-10 18:48:47 +03:00
_wait_for_dmeventd " $local "
2024-04-10 00:29:15 +03:00
2024-04-12 00:43:27 +03:00
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
2024-05-10 18:48:47 +03:00
die " dmeventd restart is too slow: $( ps aux) "
2024-04-10 00:29:15 +03:00
fi
2023-10-07 11:39:56 +03:00
}
2012-03-16 17:00:05 +04:00
aux prepare_dmeventd
2012-03-16 23:11:29 +04:00
2012-03-16 17:00:05 +04:00
aux prepare_vg 5
2010-10-27 13:16:31 +04:00
2013-08-08 00:48:31 +04:00
lvcreate -aey --type mirror -m 3 --nosync --ignoremonitoring -l1 -n 4way $vg
2010-10-27 13:16:31 +04:00
lvchange --monitor y $vg /4way
2013-08-08 00:48:31 +04:00
lvcreate -aey --type mirror -m 2 --nosync --ignoremonitoring -l1 -n 3way $vg
2010-10-27 13:16:31 +04:00
lvchange --monitor y $vg /3way
2018-04-28 23:18:00 +03:00
lvcreate -aey -l1 -n $lv1 $vg
lvcreate -s -l1 -n $lv2 $vg /$lv1
2024-05-10 18:48:47 +03:00
_wait_for_dmeventd
2023-10-07 11:39:56 +03:00
_restart_dmeventd
2010-10-27 13:16:31 +04:00
2019-11-01 17:46:16 +03:00
check lv_field $vg /3way seg_monitor "monitored"
check lv_field $vg /4way seg_monitor "monitored"
2010-10-27 13:16:31 +04:00
lvchange --monitor y --verbose $vg /3way 2>& 1 | tee lvchange.out
2019-11-01 17:46:16 +03:00
# only non-cluster tests can check command result
test -e LOCAL_CLVMD || grep 'already monitored' lvchange.out
2010-10-27 13:16:31 +04:00
lvchange --monitor y --verbose $vg /4way 2>& 1 | tee lvchange.out
2019-11-01 17:46:16 +03:00
test -e LOCAL_CLVMD || grep 'already monitored' lvchange.out
2011-03-02 15:49:13 +03:00
# now try what happens if no dmeventd is running
2024-04-12 00:43:27 +03:00
pid = $( < LOCAL_DMEVENTD)
kill -9 " $pid "
2024-08-30 13:10:35 +03:00
# TODO/FIXME: it would be surely better, if the wait loop below would
2024-04-12 00:43:27 +03:00
# 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....
2024-08-30 13:10:35 +03:00
# surprisingly it's not instant and we can actually
2024-04-12 00:43:27 +03:00
# obtain list of monitored devices...
2024-11-14 19:49:36 +03:00
test -z " $( ps -p " $pid " -o comm = ) " && break
2024-04-12 00:43:27 +03:00
sleep .1
done
2021-03-26 13:16:32 +03:00
rm LOCAL_DMEVENTD debug.log*
2012-03-20 17:35:46 +04:00
2023-10-07 11:39:56 +03:00
_restart_dmeventd
2012-03-20 17:35:46 +04:00
2012-03-20 14:48:59 +04:00
# now dmeventd should not be running
2012-03-20 17:35:46 +04:00
not pgrep dmeventd
2012-03-20 14:48:59 +04:00
rm LOCAL_DMEVENTD
2021-03-26 13:16:32 +03:00
# First lvs restarts 'dmeventd' (initiate a socket connection to a daemon)
2024-04-20 00:08:11 +03:00
# used explicit 'lvs' avoid using forked 'check' function here as that
2024-08-30 13:10:35 +03:00
# would further for 'get' and actually would be waint till whole process group
2024-04-20 00:08:11 +03:00
# 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
2019-11-01 17:46:16 +03:00
check lv_field $vg /3way seg_monitor "not monitored"
2021-03-26 13:16:32 +03:00
pgrep -o dmeventd >LOCAL_DMEVENTD
2019-11-01 17:46:16 +03:00
check lv_field $vg /4way seg_monitor "not monitored"
2011-03-02 15:49:13 +03:00
lvchange --monitor y --verbose $vg /3way 2>& 1 | tee lvchange.out
2019-11-01 17:46:16 +03:00
test -e LOCAL_CLVMD || not grep 'already monitored' lvchange.out
2011-09-19 16:49:14 +04:00
2018-04-28 23:18:00 +03:00
lvchange --monitor y --verbose $vg /$lv2 2>& 1 | tee lvchange.out
2019-11-01 17:46:16 +03:00
test -e LOCAL_CLVMD || not grep 'already monitored' lvchange.out
2018-04-28 23:18:00 +03:00
2023-10-07 11:39:56 +03:00
_restart_dmeventd
2023-10-03 02:51:29 +03:00
2023-09-26 02:21:41 +03:00
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
2023-10-03 13:43:21 +03:00
sleep 2
2023-09-26 02:21:41 +03:00
2023-10-03 13:43:21 +03:00
# Should be now dead (within ~1 second)
2023-09-26 02:21:41 +03:00
not pgrep -o dmeventd
rm -f LOCAL_DMEVENTD
# Do not run dmeventd here again
vgremove -ff --config 'activation/monitoring = 0' $vg