mirror of
git://sourceware.org/git/lvm2.git
synced 2024-12-21 13:34:40 +03:00
tests: add separate test file for bootloader area support and enhance tests
Enahnce bootloader area test to check whether restoring values from backup works correctly.
This commit is contained in:
parent
6c79556f4f
commit
05eb6a167e
@ -1536,11 +1536,11 @@ static int _text_pv_initialise(const struct format_type *fmt,
|
|||||||
/*
|
/*
|
||||||
* Calculate new PE start and bootloader area start value.
|
* Calculate new PE start and bootloader area start value.
|
||||||
* Make sure both are properly aligned!
|
* Make sure both are properly aligned!
|
||||||
* If PE start can't be aligned because EA is taking
|
* If PE start can't be aligned because BA is taking
|
||||||
* the whole space, make PE start equal to the PV size
|
* the whole space, make PE start equal to the PV size
|
||||||
* which effectively disables DA - it will have zero size.
|
* which effectively disables DA - it will have zero size.
|
||||||
* This needs to be done as we can't have a PV without any DA.
|
* This needs to be done as we can't have a PV without any DA.
|
||||||
* But we still want to support a PV with EA only!
|
* But we still want to support a PV with BA only!
|
||||||
*/
|
*/
|
||||||
if (rp->ba_size) {
|
if (rp->ba_size) {
|
||||||
pv->ba_start = final_alignment;
|
pv->ba_start = final_alignment;
|
||||||
@ -1556,7 +1556,7 @@ static int _text_pv_initialise(const struct format_type *fmt,
|
|||||||
/*
|
/*
|
||||||
* Try to keep the value of PE start set to a firm value if
|
* Try to keep the value of PE start set to a firm value if
|
||||||
* requested. This is useful when restoring existing PE start
|
* requested. This is useful when restoring existing PE start
|
||||||
* value (e.g. backups). Also, if creating an EA, try to place
|
* value (e.g. backups). Also, if creating a BA, try to place
|
||||||
* it in between the final alignment and existing PE start
|
* it in between the final alignment and existing PE start
|
||||||
* if possible.
|
* if possible.
|
||||||
*/
|
*/
|
||||||
|
59
test/shell/pvcreate-bootloaderarea.sh
Normal file
59
test/shell/pvcreate-bootloaderarea.sh
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Copyright (C) 2014 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
|
||||||
|
|
||||||
|
test_description='Test pvcreate bootloader area support'
|
||||||
|
|
||||||
|
. lib/test
|
||||||
|
|
||||||
|
aux prepare_devs 1
|
||||||
|
aux lvmconf 'global/suffix=0'
|
||||||
|
aux lvmconf 'global/units="b"'
|
||||||
|
|
||||||
|
#COMM 'pvcreate sets/aligns bootloader area correctly'
|
||||||
|
pvcreate --dataalignment 262144b --bootloaderareasize 614400b "$dev1"
|
||||||
|
# ba_start must be aligned based on dataalignment
|
||||||
|
# pe_start starts at next dataalignment multiple
|
||||||
|
# ba_size is the whole space in between ba_start and pe_start
|
||||||
|
check pv_field "$dev1" ba_start "262144"
|
||||||
|
check pv_field "$dev1" ba_size "786432"
|
||||||
|
check pv_field "$dev1" pe_start "1048576"
|
||||||
|
|
||||||
|
#COMM 'pvcreate with booloader area size - test corner cases'
|
||||||
|
dev_size=$(pvs -o pv_size --noheadings $dev1)
|
||||||
|
pv_size=$[dev_size - 1048576] # device size - 1m pe_start = area for data
|
||||||
|
|
||||||
|
# try to use the whole data area for bootloader area, remaining data area is zero then (pe_start = pv_size)
|
||||||
|
pvcreate --bootloaderareasize ${pv_size}b --dataalignment 1048576b "$dev1"
|
||||||
|
check pv_field "$dev1" pe_start $dev_size
|
||||||
|
check pv_field "$dev1" ba_start 1048576
|
||||||
|
check pv_field "$dev1" ba_size $pv_size
|
||||||
|
|
||||||
|
# try to use the whole data area for bootloader area only and add one more byte - this must error out
|
||||||
|
not pvcreate --bootloaderareasize $[pv_size + 1] --dataalignment 1048576b "$dev1" 2>err
|
||||||
|
grep "Bootloader area with data-aligned start must not exceed device size" err
|
||||||
|
|
||||||
|
# restoring the PV should also restore the bootloader area correctly
|
||||||
|
pvremove -ff "$dev1"
|
||||||
|
pvcreate --dataalignment 256k --bootloaderareasize 600k "$dev1"
|
||||||
|
vgcreate $vg "$dev1"
|
||||||
|
vgcfgbackup -f $TESTDIR/vg_with_ba_backup $vg
|
||||||
|
pv_uuid=$(get pv_field "$dev1" pv_uuid)
|
||||||
|
vgremove -ff $vg
|
||||||
|
pvremove -ff "$dev1"
|
||||||
|
pvcreate --dataalignment 256k --restorefile $TESTDIR/vg_with_ba_backup --uuid "$pv_uuid" "$dev1"
|
||||||
|
check pv_field "$dev1" ba_start "262144"
|
||||||
|
check pv_field "$dev1" ba_size "786432"
|
||||||
|
check pv_field "$dev1" pe_start "1048576"
|
||||||
|
|
||||||
|
# error out when restoring the PV and trying to use overlapping bootloader area
|
||||||
|
pvremove -ff "$dev1"
|
||||||
|
not pvcreate --restorefile $TESTDIR/vg_with_ba_backup --uuid "$pv_uuid" --bootloaderareasize 1m "$dev1" 2>err
|
||||||
|
grep "Bootloader area would overlap data area" err
|
@ -187,25 +187,3 @@ for ignore in y n; do
|
|||||||
done
|
done
|
||||||
done
|
done
|
||||||
done
|
done
|
||||||
|
|
||||||
#COMM 'pvcreate sets/aligns bootloader area correctly'
|
|
||||||
pvcreate --dataalignment 256k --bootloaderareasize 600k "$dev1"
|
|
||||||
# ba_start must be aligned based on dataalignment
|
|
||||||
# pe_start starts at next dataalignment multiple
|
|
||||||
# ba_size is the whole space in between ba_start and pe_start
|
|
||||||
check pv_field "$dev1" ba_start "256.00k"
|
|
||||||
check pv_field "$dev1" ba_size "768.00k"
|
|
||||||
check pv_field "$dev1" pe_start "1.00m"
|
|
||||||
|
|
||||||
aux lvmconf 'global/suffix=0'
|
|
||||||
aux lvmconf 'global/units="b"'
|
|
||||||
#COMM 'pvcreate with booloader area size - test corner cases
|
|
||||||
dev_size=$(pvs -o pv_size --noheadings $dev1)
|
|
||||||
pv_size=$[dev_size - 1048576] # device size - 1m pe_start = area for data
|
|
||||||
# try to use the whole data area for bootloader area
|
|
||||||
pvcreate --bootloaderareasize ${pv_size}b --dataalignment 1048576b "$dev1"
|
|
||||||
check pv_field "$dev1" pe_start $dev_size
|
|
||||||
check pv_field "$dev1" ba_start 1048576
|
|
||||||
check pv_field "$dev1" ba_size ${pv_size}
|
|
||||||
not pvcreate --bootloaderareasize $[pv_size + 1] --dataalignment 1048576b "$dev1" 2>err
|
|
||||||
grep "Bootloader area with data-aligned start must not exceed device size" err
|
|
||||||
|
Loading…
Reference in New Issue
Block a user