2008-07-17 01:32:38 +04:00
#!/bin/sh
2008-10-06 20:47:07 +04:00
# Copyright (C) 2008 Red Hat, Inc. All rights reserved.
2008-07-17 01:32:38 +04: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,
# Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
test_description = 'Test pvcreate option values'
2009-06-06 20:40:39 +04:00
PAGESIZE = $( getconf PAGESIZE)
2008-07-17 01:32:38 +04:00
2008-10-06 20:47:07 +04:00
. ./test-utils.sh
2008-07-17 01:32:38 +04:00
2008-10-06 20:47:07 +04:00
aux prepare_devs 4
2008-07-17 01:32:38 +04:00
2008-10-06 20:47:07 +04:00
#COMM 'pvcreate rejects negative setphysicalvolumesize'
not pvcreate --setphysicalvolumesize -1024 $dev1
2008-07-17 01:32:38 +04:00
2008-10-06 20:47:07 +04:00
#COMM 'pvcreate rejects negative metadatasize'
not pvcreate --metadatasize -1024 $dev1
2008-07-17 01:32:38 +04:00
# x. metadatasize 0, defaults to 255
# FIXME: unable to check default value, not in reporting cmds
# should default to 255 according to code
2008-10-06 20:47:07 +04:00
# check_pv_field_ pv_mda_size 255
#COMM 'pvcreate accepts metadatasize 0'
pvcreate --metadatasize 0 $dev1
pvremove $dev1
2008-07-17 01:32:38 +04:00
2009-05-08 10:10:45 +04:00
#Verify vg_mda_size is smaller pv_mda_size
2009-09-30 20:13:53 +04:00
pvcreate --metadatasize 512k $dev1
pvcreate --metadatasize 96k $dev2
2009-05-08 10:10:45 +04:00
vgcreate $vg $dev1 $dev2
compare_two_fields_ vgs $vg vg_mda_size pvs $dev2 pv_mda_size
vgremove -ff $vg
2008-07-17 01:32:38 +04:00
# x. metadatasize too large
# For some reason we allow this, even though there's no room for data?
2008-10-06 20:47:07 +04:00
##COMM 'pvcreate rejects metadatasize too large'
#not pvcreate --metadatasize 100000000000000 $dev1
2008-07-17 01:32:38 +04:00
2008-10-06 20:47:07 +04:00
#COMM 'pvcreate rejects metadatacopies < 0'
not pvcreate --metadatacopies -1 $dev1
2008-07-17 01:32:38 +04:00
2008-10-06 20:47:07 +04:00
#COMM 'pvcreate accepts metadatacopies = 0, 1, 2'
2009-10-06 00:55:56 +04:00
for j in metadatacopies pvmetadatacopies
do
pvcreate --$j 0 $dev1
pvcreate --$j 1 $dev2
pvcreate --$j 2 $dev3
check_pv_field_ $dev1 pv_mda_count 0
check_pv_field_ $dev2 pv_mda_count 1
check_pv_field_ $dev3 pv_mda_count 2
2008-10-06 20:47:07 +04:00
pvremove $dev1
pvremove $dev2
pvremove $dev3
2009-10-06 00:55:56 +04:00
done
2008-07-17 01:32:38 +04:00
2008-10-06 20:47:07 +04:00
#COMM 'pvcreate rejects metadatacopies > 2'
not pvcreate --metadatacopies 3 $dev1
2008-07-17 01:32:38 +04:00
2008-10-06 20:47:07 +04:00
#COMM 'pvcreate rejects invalid device'
not pvcreate $dev1bogus
2008-07-17 01:32:38 +04:00
2008-10-06 20:47:07 +04:00
#COMM 'pvcreate rejects labelsector < 0'
not pvcreate --labelsector -1 $dev1
2008-07-17 01:32:38 +04:00
2008-10-06 20:47:07 +04:00
#COMM 'pvcreate rejects labelsector > 1000000000000'
not pvcreate --labelsector 1000000000000 $dev1
2008-07-17 01:32:38 +04:00
# other possibilites based on code inspection (not sure how hard)
# x. device too small (min of 512 * 1024 KB)
# x. device filtered out
# x. unable to open /dev/urandom RDONLY
# x. device too large (pe_count > UINT32_MAX)
# x. device read-only
# x. unable to open device readonly
# x. BLKGETSIZE64 fails
# x. set size to value inconsistent with device / PE size
2009-02-22 22:00:26 +03:00
#COMM 'pvcreate basic dataalignment sanity checks'
not pvcreate --dataalignment -1 $dev1
not pvcreate -M 1 --dataalignment 1 $dev1
2009-09-30 20:13:53 +04:00
not pvcreate --dataalignment 1e $dev1
2009-02-22 22:00:26 +03:00
#COMM 'pvcreate always rounded up to page size for start of device'
2009-02-22 22:32:28 +03:00
#pvcreate --metadatacopies 0 --dataalignment 1 $dev1
2009-02-22 22:00:26 +03:00
# amuse shell experts
2009-09-30 20:13:53 +04:00
#check_pv_field_ $dev1 pe_start $(($(getconf PAGESIZE)/1024))".00k"
2009-02-22 22:00:26 +03:00
#COMM 'pvcreate sets data offset directly'
pvcreate --dataalignment 512k $dev1
2009-09-30 20:13:53 +04:00
check_pv_field_ $dev1 pe_start 512.00k
2009-02-22 22:00:26 +03:00
#COMM 'vgcreate/vgremove do not modify data offset of existing PV'
vgcreate $vg $dev1 --config 'devices { data_alignment = 1024 }'
2009-09-30 20:13:53 +04:00
check_pv_field_ $dev1 pe_start 512.00k
2009-02-22 22:00:26 +03:00
vgremove $vg --config 'devices { data_alignment = 1024 }'
2009-09-30 20:13:53 +04:00
check_pv_field_ $dev1 pe_start 512.00k
2009-02-22 22:00:26 +03:00
#COMM 'pvcreate sets data offset next to mda area'
pvcreate --metadatasize 100k --dataalignment 100k $dev1
2009-09-30 20:13:53 +04:00
check_pv_field_ $dev1 pe_start 200.00k
2009-02-22 22:00:26 +03:00
2009-06-06 20:40:39 +04:00
# metadata area start is aligned according to pagesize
# pagesize should be 64k or 4k ...
if [ $PAGESIZE -eq 65536 ] ; then
2009-09-30 20:13:53 +04:00
pv_align = "192.50k"
2009-06-06 20:40:39 +04:00
else
2009-09-30 20:13:53 +04:00
pv_align = "133.00k"
2009-06-06 20:40:39 +04:00
fi
2009-05-07 16:11:50 +04:00
pvcreate --metadatasize 128k --dataalignment 3.5k $dev1
2009-06-06 20:40:39 +04:00
check_pv_field_ $dev1 pe_start $pv_align
2009-05-07 16:11:50 +04:00
pvcreate --metadatasize 128k --metadatacopies 2 --dataalignment 3.5k $dev1
2009-06-06 20:40:39 +04:00
check_pv_field_ $dev1 pe_start $pv_align
2009-05-07 16:11:50 +04:00
2009-08-04 20:02:39 +04:00
# data area is aligned to 64k by default,
# data area start is shifted by the specified alignment_offset
2009-09-30 20:13:53 +04:00
pv_align = "195.50k"
2009-08-04 20:02:39 +04:00
pvcreate --metadatasize 128k --dataalignmentoffset 7s $dev1
check_pv_field_ $dev1 pe_start $pv_align
# 2nd metadata area is created without problems when
# data area start is shifted by the specified alignment_offset
pvcreate --metadatasize 128k --metadatacopies 2 --dataalignmentoffset 7s $dev1
check_pv_field_ $dev1 pv_mda_count 2
# FIXME: compare start of 2nd mda with and without --dataalignmentoffset
2009-02-22 22:00:26 +03:00
#COMM 'pv with LVM1 compatible data alignment can be convereted'
#compatible == LVM1_PE_ALIGN == 64k
pvcreate --dataalignment 256k $dev1
2009-09-30 20:13:53 +04:00
vgcreate -s 1m $vg $dev1
2009-02-22 22:00:26 +03:00
vgconvert -M1 $vg
vgconvert -M2 $vg
2009-09-30 20:13:53 +04:00
check_pv_field_ $dev1 pe_start 256.00k
2009-02-22 22:00:26 +03:00
vgremove $vg
#COMM 'pv with LVM1 incompatible data alignment cannot be convereted'
pvcreate --dataalignment 10k $dev1
2009-09-30 20:13:53 +04:00
vgcreate -s 1m $vg $dev1
2009-02-22 22:00:26 +03:00
not vgconvert -M1 $vg
vgremove $vg
#COMM 'vgcfgrestore allows pe_start=0'
#basically it produces nonsense, but it tests vgcfgrestore,
#not that final cfg is usable...
pvcreate --metadatacopies 0 $dev1
pvcreate $dev2
vgcreate $vg $dev1 $dev2
vgcfgbackup -f " $( pwd ) /backup. $$ " $vg
sed 's/pe_start = [0-9]*/pe_start = 0/' " $( pwd ) /backup. $$ " > " $( pwd ) /backup. $$ 1 "
vgcfgrestore -f " $( pwd ) /backup. $$ 1 " $vg
2009-02-26 02:31:06 +03:00
check_pv_field_ $dev1 pe_start 0
check_pv_field_ $dev2 pe_start 0
2009-02-22 22:00:26 +03:00
vgremove $vg
2010-06-30 16:17:55 +04:00
echo test pvcreate --metadataignore
for pv_in_vg in 1 0; do
for mdacp in 1 2; do
for ignore in y n; do
echo pvcreate --metadataignore has proper mda_count and mda_used_count
pvcreate --metadatacopies $mdacp --metadataignore $ignore $dev1 $dev2
check_pv_field_ $dev1 pv_mda_count $mdacp
check_pv_field_ $dev2 pv_mda_count $mdacp
if [ $ignore = y ] ; then
check_pv_field_ $dev1 pv_mda_used_count 0
check_pv_field_ $dev2 pv_mda_used_count 0
else
check_pv_field_ $dev1 pv_mda_used_count $mdacp
check_pv_field_ $dev2 pv_mda_used_count $mdacp
fi
echo vgcreate has proper vg_mda_count and vg_mda_used_count
if [ $pv_in_vg = 1 ] ; then
vgcreate -c n " $vg " $dev1 $dev2
check_vg_field_ $vg vg_mda_count $(( $mdacp * 2 ))
if [ $ignore = y ] ; then
check_vg_field_ $vg vg_mda_used_count 1
else
check_vg_field_ $vg vg_mda_used_count $(( $mdacp * 2 ))
fi
check_vg_field_ $vg vg_mda_copies unmanaged
vgremove $vg
fi
done
done
done