2017-07-02 21:38:32 +02:00
#!/usr/bin/env bash
2020-09-11 13:35:30 +02:00
# Copyright (C) 2014-2020 Red Hat, Inc. All rights reserved.
2014-01-21 10:04:23 +01:00
#
# 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
2014-01-21 10:04:23 +01:00
# Test autoextension of thin metadata volume
2015-05-17 17:22:18 +02:00
2016-02-22 16:13:42 -06:00
SKIP_WITH_LVMLOCKD = 1
2015-10-27 15:10:06 +01:00
SKIP_WITH_LVMPOLLD = 1
2015-05-17 17:22:18 +02:00
export LVM_TEST_THIN_REPAIR_CMD = ${ LVM_TEST_THIN_REPAIR_CMD -/bin/false }
2014-06-06 17:40:04 +02:00
. lib/inittest
2014-01-21 10:04:23 +01:00
2020-09-12 19:06:05 +02:00
2014-01-21 10:04:23 +01:00
meta_percent_( ) {
get lv_field $vg /pool metadata_percent | cut -d. -f1
}
wait_for_change_( ) {
# dmeventd only checks every 10 seconds :(
2015-10-29 15:11:16 +01:00
for i in $( seq 1 12) ; do
test " $( meta_percent_) " -lt " $1 " && return
2014-01-21 10:04:23 +01:00
sleep 1
done
return 1 # timeout
}
#
# Temporary solution to create some occupied thin metadata
# This heavily depends on thin metadata output format to stay as is.
# Currently it expects 2MB thin metadata and 200MB data volume size
# Argument specifies how many devices should be created.
fake_metadata_( ) {
2015-10-13 14:33:24 +02:00
echo '<superblock uuid="" time="0" transaction="' $2 '" data_block_size="128" nr_data_blocks="3200">'
echo ' <device dev_id="1" mapped_blocks="0" transaction="0" creation_time="0" snap_time="0">'
echo ' </device>'
echo ' <device dev_id="2" mapped_blocks="0" transaction="0" creation_time="0" snap_time="0">'
echo ' </device>'
for i in $( seq 10 $1 )
2014-01-21 10:04:23 +01:00
do
2015-10-13 14:33:24 +02:00
echo ' <device dev_id="' $i '" mapped_blocks="30" transaction="0" creation_time="0" snap_time="0">'
2023-06-24 22:34:38 +02:00
echo ' <range_mapping origin_begin="0" data_begin="0" length="30" time="0"/>'
2014-01-21 10:04:23 +01:00
echo ' </device>'
2015-10-13 14:33:24 +02:00
set +x
2014-01-21 10:04:23 +01:00
done
echo "</superblock>"
2015-10-13 14:33:24 +02:00
set -x
2014-01-21 10:04:23 +01:00
}
2014-05-26 23:28:03 +02:00
test -n " $LVM_TEST_THIN_RESTORE_CMD " || LVM_TEST_THIN_RESTORE_CMD = $( which thin_restore) || skip
2014-06-16 17:46:54 +02:00
" $LVM_TEST_THIN_RESTORE_CMD " -V || skip
2014-01-21 10:04:23 +01:00
aux have_thin 1 10 0 || skip
2020-09-14 21:25:04 +02:00
BIG_DATA = ""
2020-09-22 23:37:50 +02:00
aux thin_restore_needs_more_volumes && BIG_DATA = "generate_more_metadata"
2020-09-14 21:25:04 +02:00
2014-01-21 10:04:23 +01:00
aux prepare_dmeventd
aux prepare_pvs 3 256
2017-07-06 19:41:25 +02:00
get_devs
2014-01-21 10:04:23 +01:00
2017-07-06 19:41:25 +02:00
vgcreate -s 1M " $vg " " ${ DEVICES [@] } "
2014-01-21 10:04:23 +01:00
2016-09-16 21:55:04 +02:00
# Testing dmeventd does NOT autoresize when default threshold 100% is left
lvcreate -L200M -V50M -n thin -T $vg /pool
lvcreate -V2M -n thin2 $vg /pool
lvcreate -L2M -n $lv1 $vg
lvcreate -L32M -n $lv2 $vg
lvcreate -L32M -n $lv3 $vg
lvchange -an $vg /thin $vg /thin2 $vg /pool
# Filling 2M metadata volume
2018-05-16 17:53:38 -04:00
# (Test for less than 25% free space in metadata)
2016-09-16 21:55:04 +02:00
fake_metadata_ 400 2 >data
" $LVM_TEST_THIN_RESTORE_CMD " -i data -o " $DM_DEV_DIR /mapper/ $vg - $lv1 "
# Swap volume with restored fake metadata
2017-04-03 15:57:32 +02:00
lvconvert -y --chunksize 64k --thinpool $vg /pool --poolmetadata $vg /$lv1
2016-09-16 21:55:04 +02:00
2024-08-30 12:10:35 +02:00
# Not allowed when thin-pool metadata free space is <75% for 2M meta
2016-09-16 21:55:04 +02:00
fail lvcreate -V20 $vg /pool
lvchange -an $vg /pool
# Consume more then (100% - 4MiB) out of 32MiB metadata volume (>87.5%)
2018-05-16 17:53:38 -04:00
# (Test for less than 4MiB free space in metadata, which is less than 25%)
2018-11-18 22:04:00 +01:00
DATA = 7200 # Newer version of thin-pool have hidden reserve, so use lower value
2020-09-12 19:06:05 +02:00
test -z " $BIG_DATA " || DATA = 7400
2018-11-18 22:04:00 +01:00
fake_metadata_ " $DATA " 2 >data
2016-09-16 21:55:04 +02:00
" $LVM_TEST_THIN_RESTORE_CMD " -i data -o " $DM_DEV_DIR /mapper/ $vg - $lv2 "
2023-06-24 22:34:38 +02:00
2024-08-30 12:10:35 +02:00
# Check the restored metadata are OK for thin_check
2023-06-24 22:34:38 +02:00
" $LVM_TEST_THIN_CHECK_CMD " " $DM_DEV_DIR /mapper/ $vg - $lv2 "
2016-09-16 21:55:04 +02:00
# Swap volume with restored fake metadata
2017-04-03 15:57:32 +02:00
lvconvert -y --chunksize 64k --thinpool $vg /pool --poolmetadata $vg /$lv2
2016-09-16 21:55:04 +02:00
lvchange -ay $vg /pool
# Check generated metadata consume more then 88%
test " $( meta_percent_) " -gt "88"
lvchange -an $vg /pool
# Creation of thin LV is prohibited when metadata are above this value
fail lvcreate -V20 $vg /pool 2>& 1 | tee out
grep "free space" out
lvs -a $vg
# Check that even with 99% threshold policy - metadata will go below 88%
lvextend --use-policies --config " \
activation/thin_pool_autoextend_percent= 1 \
activation/thin_pool_autoextend_threshold= 99" $vg /pool
2024-08-30 12:10:35 +02:00
# Originally wanted to test <88% -
2019-11-01 16:21:52 +01:00
# however some older kernels consume a bit more space, so be happy
# when it's <90%
test " $( meta_percent_) " -lt "90"
2016-09-16 21:55:04 +02:00
# After such operatoin creation of thin LV has to pass
lvcreate -V20 $vg /pool
# Let's revalidate pool metadata (thin_check upon deactivation/activation)
lvchange -an $vg
lvchange -ay $vg /pool
lvremove -f $vg
#########################################################
# Test automatic resize with help of dmeventd DOES work #
#########################################################
aux lvmconf "activation/thin_pool_autoextend_percent = 10" \
"activation/thin_pool_autoextend_threshold = 70"
2014-01-21 10:04:23 +01:00
# Testing dmeventd autoresize
2015-07-13 11:08:49 +02:00
lvcreate -L200M -V500M -n thin -T $vg /pool 2>& 1 | tee out
not grep "WARNING: Sum" out
2015-08-17 17:07:09 +02:00
lvcreate -V2M -n thin2 $vg /pool
2014-01-21 10:04:23 +01:00
lvcreate -L2M -n $lv1 $vg
2015-08-17 17:07:09 +02:00
lvchange -an $vg /thin $vg /thin2 $vg /pool
2014-01-21 10:04:23 +01:00
2014-02-24 09:46:09 +01:00
# Prepare some fake metadata with unmatching id
2015-09-03 23:05:33 +02:00
# Transaction_id is lower by 1 and there are no messages -> ERROR
2014-02-24 09:46:09 +01:00
fake_metadata_ 10 0 >data
2014-06-16 17:46:54 +02:00
" $LVM_TEST_THIN_RESTORE_CMD " -i data -o " $DM_DEV_DIR /mapper/ $vg - $lv1 "
2017-04-03 15:57:32 +02:00
lvconvert -y --thinpool $vg /pool --poolmetadata $vg /$lv1
2014-02-24 09:46:09 +01:00
not vgchange -ay $vg 2>& 1 | tee out
grep expected out
2014-01-21 10:04:23 +01:00
2014-02-24 09:46:09 +01:00
check inactive $vg pool_tmeta
# Transaction_id is higher by 1
2015-08-17 17:07:09 +02:00
fake_metadata_ 10 3 >data
2014-06-16 17:46:54 +02:00
" $LVM_TEST_THIN_RESTORE_CMD " -i data -o " $DM_DEV_DIR /mapper/ $vg - $lv1 "
2017-04-03 15:57:32 +02:00
lvconvert -y --thinpool $vg /pool --poolmetadata $vg /$lv1
2014-02-24 09:46:09 +01:00
not vgchange -ay $vg 2>& 1 | tee out
grep expected out
check inactive $vg pool_tmeta
# Prepare some fake metadata prefilled to ~81% (>70%)
2015-08-17 17:07:09 +02:00
fake_metadata_ 400 2 >data
2014-06-16 17:46:54 +02:00
" $LVM_TEST_THIN_RESTORE_CMD " -i data -o " $DM_DEV_DIR /mapper/ $vg - $lv1 "
2014-02-24 09:46:09 +01:00
2014-01-21 10:04:23 +01:00
# Swap volume with restored fake metadata
2017-04-03 15:57:32 +02:00
lvconvert -y --chunksize 64k --thinpool $vg /pool --poolmetadata $vg /$lv1
2014-01-21 10:04:23 +01:00
vgchange -ay $vg
2015-10-29 15:11:16 +01:00
# Check dmeventd resizes metadata via timeout (nothing is written to pool)
2014-01-21 10:04:23 +01:00
pre = $( meta_percent_)
wait_for_change_ $pre
2014-02-24 09:46:09 +01:00
2015-10-13 14:33:24 +02:00
lvchange -an $vg
#
2018-11-16 16:01:39 +01:00
DATA = 300 # Newer version of thin-pool have hidden reserve, so use lower value
2020-09-12 19:06:05 +02:00
test -z " $BIG_DATA " || DATA = 350
2018-11-16 16:01:39 +01:00
fake_metadata_ $DATA 2 >data
2015-10-13 14:33:24 +02:00
lvchange -ay $vg /$lv1
" $LVM_TEST_THIN_RESTORE_CMD " -i data -o " $DM_DEV_DIR /mapper/ $vg - $lv1 "
2017-04-03 15:57:32 +02:00
lvconvert -y --chunksize 64k --thinpool $vg /pool --poolmetadata $vg /$lv1
2015-10-13 14:33:24 +02:00
lvchange -ay $vg /pool $vg /$lv1
lvs -a $vg
lvcreate -s -Ky -n $lv2 $vg /thin
2015-10-29 15:11:16 +01:00
pre = $( meta_percent_)
2015-10-13 14:33:24 +02:00
2015-10-29 15:11:16 +01:00
# go over thin metadata threshold
echo 2 >" $DM_DEV_DIR /mapper/ $vg - $lv2 "
2015-10-13 14:33:24 +02:00
wait_for_change_ $pre
lvs -a $vg
2014-02-24 09:46:09 +01:00
vgremove -f $vg