2012-03-16 17:00:05 +04:00
#!/bin/sh
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,
# Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
2014-06-06 19:40:04 +04:00
. lib/inittest
2010-10-27 13:16:31 +04:00
2015-05-09 02:59:18 +03:00
test -e LOCAL_LVMPOLLD && skip
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
dmeventd -R -f &
2012-03-20 14:48:59 +04:00
echo $! >LOCAL_DMEVENTD
sleep 2 # wait a bit, so we talk to the new dmeventd later
2010-10-27 13:16:31 +04:00
lvchange --monitor y --verbose $vg /3way 2>& 1 | tee lvchange.out
grep 'already monitored' lvchange.out
lvchange --monitor y --verbose $vg /4way 2>& 1 | tee lvchange.out
grep 'already monitored' lvchange.out
2011-03-02 15:49:13 +03:00
# now try what happens if no dmeventd is running
2014-06-30 23:00:08 +04:00
kill -9 $( < LOCAL_DMEVENTD)
2012-03-20 17:35:46 +04:00
rm LOCAL_DMEVENTD
2011-03-02 15:49:13 +03:00
dmeventd -R -f &
2012-03-20 17:35:46 +04:00
echo $! >LOCAL_DMEVENTD
# wait longer as tries to communicate with killed daemon
sleep 7
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
# set dmeventd path
2014-09-15 02:19:53 +04:00
if test -n " $abs_top_builddir " ; then
aux lvmconf " dmeventd/executable=\" $abs_top_builddir /test/lib/dmeventd\" "
fi
2011-03-02 15:49:13 +03:00
lvchange --monitor y --verbose $vg /3way 2>& 1 | tee lvchange.out
2015-03-26 16:12:34 +03:00
pgrep -o dmeventd >LOCAL_DMEVENTD
2012-03-20 14:48:59 +04:00
not grep 'already monitored' lvchange.out
2011-09-19 16:49:14 +04:00
vgremove -ff $vg