2017-07-02 21:38:32 +02:00
#!/usr/bin/env bash
2010-10-27 09:16:31 +00: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 11:49:46 +01:00
# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
2010-10-27 09:16:31 +00:00
2018-05-24 09:49:48 -05:00
2015-10-27 15:10:06 +01:00
SKIP_WITH_LVMPOLLD = 1
2010-10-27 09:16:31 +00:00
2015-10-27 15:10:06 +01:00
. lib/inittest
2015-05-09 00:59:18 +01:00
2012-03-16 13:00:05 +00:00
aux prepare_dmeventd
2012-03-16 19:11:29 +00:00
2012-03-16 13:00:05 +00:00
aux prepare_vg 5
2010-10-27 09:16:31 +00:00
2013-08-07 15:48:31 -05:00
lvcreate -aey --type mirror -m 3 --nosync --ignoremonitoring -l1 -n 4way $vg
2010-10-27 09:16:31 +00:00
lvchange --monitor y $vg /4way
2013-08-07 15:48:31 -05:00
lvcreate -aey --type mirror -m 2 --nosync --ignoremonitoring -l1 -n 3way $vg
2010-10-27 09:16:31 +00:00
lvchange --monitor y $vg /3way
2018-04-28 22:18:00 +02:00
lvcreate -aey -l1 -n $lv1 $vg
lvcreate -s -l1 -n $lv2 $vg /$lv1
2010-10-27 09:16:31 +00:00
dmeventd -R -f &
2012-03-20 10:48:59 +00:00
echo $! >LOCAL_DMEVENTD
sleep 2 # wait a bit, so we talk to the new dmeventd later
2010-10-27 09:16:31 +00:00
2019-11-01 15:46:16 +01:00
check lv_field $vg /3way seg_monitor "monitored"
check lv_field $vg /4way seg_monitor "monitored"
2010-10-27 09:16:31 +00:00
lvchange --monitor y --verbose $vg /3way 2>& 1 | tee lvchange.out
2019-11-01 15:46:16 +01:00
# only non-cluster tests can check command result
test -e LOCAL_CLVMD || grep 'already monitored' lvchange.out
2010-10-27 09:16:31 +00:00
lvchange --monitor y --verbose $vg /4way 2>& 1 | tee lvchange.out
2019-11-01 15:46:16 +01:00
test -e LOCAL_CLVMD || grep 'already monitored' lvchange.out
2011-03-02 12:49:13 +00:00
# now try what happens if no dmeventd is running
2017-07-10 10:40:09 +02:00
kill -9 " $( < LOCAL_DMEVENTD) "
2021-03-26 11:16:32 +01:00
rm LOCAL_DMEVENTD debug.log*
2012-03-20 13:35:46 +00:00
2011-03-02 12:49:13 +00:00
dmeventd -R -f &
2012-03-20 13:35:46 +00:00
echo $! >LOCAL_DMEVENTD
2023-09-26 01:21:41 +02:00
# wait longer as tries 5s to communicate with killed daemon
sleep 7
2012-03-20 10:48:59 +00:00
# now dmeventd should not be running
2012-03-20 13:35:46 +00:00
not pgrep dmeventd
2012-03-20 10:48:59 +00:00
rm LOCAL_DMEVENTD
2021-03-26 11:16:32 +01:00
# First lvs restarts 'dmeventd' (initiate a socket connection to a daemon)
2019-11-01 15:46:16 +01:00
check lv_field $vg /3way seg_monitor "not monitored"
2021-03-26 11:16:32 +01:00
pgrep -o dmeventd >LOCAL_DMEVENTD
2019-11-01 15:46:16 +01:00
check lv_field $vg /4way seg_monitor "not monitored"
2011-03-02 12:49:13 +00:00
lvchange --monitor y --verbose $vg /3way 2>& 1 | tee lvchange.out
2019-11-01 15:46:16 +01:00
test -e LOCAL_CLVMD || not grep 'already monitored' lvchange.out
2011-09-19 12:49:14 +00:00
2018-04-28 22:18:00 +02:00
lvchange --monitor y --verbose $vg /$lv2 2>& 1 | tee lvchange.out
2019-11-01 15:46:16 +01:00
test -e LOCAL_CLVMD || not grep 'already monitored' lvchange.out
2018-04-28 22:18:00 +02:00
2023-09-26 01:21:41 +02:00
rm -f debug.log*
dmeventd -R -f -e " $PWD /test_nologin " -ldddd > debug.log_DMEVENTD_$RANDOM 2>& 1 &
echo $! >LOCAL_DMEVENTD
2023-10-03 01:51:29 +02:00
for i in $( seq 1 10) ; do
test " $( pgrep -o dmeventd) " = " $( < LOCAL_DMEVENTD) " && break
sleep .1
done
2023-10-05 22:58:05 +02:00
sleep 1 # wait a bit, so we talk to the new dmeventd later
2023-09-26 01:21:41 +02: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 12:43:21 +02:00
sleep 2
2023-09-26 01:21:41 +02:00
2023-10-03 12:43:21 +02:00
# Should be now dead (within ~1 second)
2023-09-26 01:21:41 +02:00
not pgrep -o dmeventd
rm -f LOCAL_DMEVENTD
# Do not run dmeventd here again
vgremove -ff --config 'activation/monitoring = 0' $vg