2019-01-24 14:16:18 +01:00
#!/usr/bin/env bash
# Copyright (C) 2019 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
# no automatic extensions, just umount
SKIP_WITH_LVMPOLLD = 1
. lib/inittest
mntdir = " ${ PREFIX } mnt with space "
PERCENT = 70
cleanup_mounted_and_teardown( )
{
test -z " $PID_SLEEP " || { kill " $PID_SLEEP " || true ; }
umount " $mntdir " 2>/dev/null || true
vgremove -ff $vg
aux teardown
}
is_lv_opened_( )
{
test " $( get lv_field " $1 " lv_device_open --binary) " = 1
}
#
# Main
#
which mkfs.ext4 || skip
export MKE2FS_CONFIG = " $TESTDIR /lib/mke2fs.conf "
aux have_vdo 6 2 0 || skip
# Simple implementation of umount when lvextend fails
2024-08-30 12:10:35 +02:00
# Script enforces failing exit, so dmeventd tries several times
2020-09-22 23:26:28 +02:00
# repeatedly to invoke this for given percentage
2019-01-24 14:16:18 +01:00
cat <<- EOF >testcmd.sh
#!/bin/sh
echo "VDO Pool: \$DMEVENTD_VDO_POOL"
" $TESTDIR /lib/lvextend " --use-policies \$ 1 || {
2020-09-22 23:26:28 +02:00
umount " $mntdir " && exit 0
touch $PWD /TRIED_UMOUNT
2019-01-24 14:16:18 +01:00
}
test " \$( $TESTDIR /lib/lvs -o selected -S " data_percent>= $PERCENT " --noheadings \$1)" -eq 0 || {
2020-09-22 23:26:28 +02:00
echo " Percentage still above $PERCENT "
2019-01-24 14:16:18 +01:00
}
2020-09-22 23:26:28 +02:00
exit 1
2019-01-24 14:16:18 +01:00
EOF
chmod +x testcmd.sh
# Show prepared script
cat testcmd.sh
# Use autoextend percent 0 - so extension fails and triggers umount...
aux lvmconf "activation/vdo_pool_autoextend_percent = 0" \
" activation/vdo_pool_autoextend_threshold = $PERCENT " \
2020-09-22 23:26:28 +02:00
" dmeventd/vdo_command = \" $PWD /testcmd.sh\" " \
2019-01-24 14:16:18 +01:00
"allocation/vdo_slab_size_mb = 128"
aux prepare_dmeventd
aux prepare_vg 1 9000
lvcreate --vdo -L4G -V2G -n $lv1 $vg /vpool
mkfs.ext4 -E nodiscard " $DM_DEV_DIR / $vg / $lv1 "
lvchange --monitor y $vg /vpool
mkdir " $mntdir "
trap 'cleanup_mounted_and_teardown' EXIT
mount " $DM_DEV_DIR / $vg / $lv1 " " $mntdir "
# Check both LV is opened (~mounted)
is_lv_opened_ " $vg / $lv1 "
touch " $mntdir /file $$ "
sync
# Running 'keeper' process sleep holds the block device still in use
sleep 60 < " $mntdir /file $$ " >/dev/null 2>& 1 &
PID_SLEEP = $!
lvs -a $vg
# Fill pool above 95% (to cause 'forced lazy umount)
2020-09-22 23:26:28 +02:00
dd if = /dev/urandom of = " $mntdir /file $$ " bs = 256K count = 200 oflag = direct
2019-01-24 14:16:18 +01:00
lvs -a $vg
# Could loop here for a few secs so dmeventd can do some work
# In the worst case check only happens every 10 seconds :(
for i in $( seq 1 12) ; do
is_lv_opened_ " $vg / $lv1 " || break
2020-09-22 23:26:28 +02:00
test ! -f "TRIED_UMOUNT" || continue # finish loop quickly
2019-01-24 14:16:18 +01:00
sleep 1
done
2020-09-22 23:26:28 +02:00
rm -f "TRIED_UMOUNT"
2019-01-24 14:16:18 +01:00
test " $i " -eq 12 || die " $mntdir should NOT have been unmounted by dmeventd! "
lvs -a $vg
# Kill device holding process - umount should work now
kill " $PID_SLEEP "
PID_SLEEP =
wait
# Could loop here for a few secs so dmeventd can do some work
# In the worst case check only happens every 10 seconds :(
for i in $( seq 1 12) ; do
is_lv_opened_ " $vg / $lv1 " || break
test " $i " -lt 12 || die " $mntdir should have been unmounted by dmeventd! "
sleep 1
done
2020-09-22 23:26:28 +02:00
# vgremove is managed through cleanup_mounted_and_teardown()