mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-03 05:18:29 +03:00
Convert t-vgsplit-usage.sh to use the new test-utils.sh. Original conversion by
jstava. Lvm1 testing restored by mornfall.
This commit is contained in:
parent
45911e4588
commit
e011f1770c
@ -9,228 +9,171 @@
|
|||||||
# along with this program; if not, write to the Free Software Foundation,
|
# along with this program; if not, write to the Free Software Foundation,
|
||||||
# Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
# Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
|
||||||
test_description='Test vgsplit command options for validity'
|
# Test vgsplit command options for validity
|
||||||
privileges_required_=1
|
|
||||||
|
|
||||||
. ./test-lib.sh
|
. ./test-utils.sh
|
||||||
|
|
||||||
cleanup_()
|
aux prepare_devs 5
|
||||||
{
|
|
||||||
test -n "$d1" && losetup -d "$d1"
|
|
||||||
test -n "$d2" && losetup -d "$d2"
|
|
||||||
test -n "$d3" && losetup -d "$d3"
|
|
||||||
test -n "$d4" && losetup -d "$d4"
|
|
||||||
test -n "$d5" && losetup -d "$d5"
|
|
||||||
rm -f "$f1" "$f2" "$f3" "$f4" "$f5"
|
|
||||||
}
|
|
||||||
|
|
||||||
# FIXME: paramaterize lvm1 vs lvm2 metadata; most of these tests should run
|
# FIXME: paramaterize lvm1 vs lvm2 metadata; most of these tests should run
|
||||||
# fine with lvm1 metadata as well; for now, just add disks 5 and 6 as lvm1
|
# fine with lvm1 metadata as well; for now, just add disks 5 and 6 as lvm1
|
||||||
# metadata
|
# metadata
|
||||||
test_expect_success \
|
|
||||||
'set up temp files, loopback devices, PVs, vgnames' \
|
|
||||||
'f1=$(pwd)/1 && d1=$(loop_setup_ "$f1") &&
|
|
||||||
f2=$(pwd)/2 && d2=$(loop_setup_ "$f2") &&
|
|
||||||
f3=$(pwd)/3 && d3=$(loop_setup_ "$f3") &&
|
|
||||||
f4=$(pwd)/4 && d4=$(loop_setup_ "$f4") &&
|
|
||||||
f5=$(pwd)/5 && d5=$(loop_setup_ "$f5") &&
|
|
||||||
vg1=$(this_test_)-test-vg1-$$ &&
|
|
||||||
vg2=$(this_test_)-test-vg2-$$ &&
|
|
||||||
lv1=$(this_test_)-test-lv1-$$ &&
|
|
||||||
lv2=$(this_test_)-test-lv2-$$ &&
|
|
||||||
lv3=$(this_test_)-test-lv3-$$'
|
|
||||||
|
|
||||||
for mdatype in 1 2
|
for mdatype in 1 2
|
||||||
do
|
do
|
||||||
test_expect_success \
|
|
||||||
"(lvm$mdatype) setup PVs" \
|
|
||||||
'pvcreate -M$mdatype $d1 $d2 $d3 $d4'
|
|
||||||
|
|
||||||
test_expect_success \
|
pvcreate -M$mdatype $devs
|
||||||
"(lvm$mdatype) vgsplit accepts new vg as destination of split" \
|
|
||||||
'vgcreate -M$mdatype $vg1 $d1 $d2 &&
|
|
||||||
vgsplit $vg1 $vg2 $d1 1>err;
|
|
||||||
status=$?; echo status=$status; test $status = 0 &&
|
|
||||||
grep "New volume group \"$vg2\" successfully split from \"$vg1\"" err &&
|
|
||||||
vgremove $vg1 &&
|
|
||||||
vgremove $vg2'
|
|
||||||
|
|
||||||
test_expect_success \
|
# vgsplit accepts new vg as destination of split
|
||||||
"(lvm$mdatype) vgsplit accepts existing vg as destination of split" \
|
vgcreate -M$mdatype $vg1 $devs
|
||||||
'vgcreate -M$mdatype $vg1 $d1 $d2 &&
|
vgsplit $vg1 $vg2 $dev1 1>err
|
||||||
vgcreate -M$mdatype $vg2 $d3 $d4 &&
|
grep "New volume group \"$vg2\" successfully split from \"$vg1\"" err
|
||||||
vgsplit $vg1 $vg2 $d1 1>err;
|
vgremove $vg1
|
||||||
status=$?; echo status=$status; test $status = 0 &&
|
vgremove $vg2
|
||||||
grep "Existing volume group \"$vg2\" successfully split from \"$vg1\"" err &&
|
|
||||||
vgremove $vg1 &&
|
|
||||||
vgremove $vg2'
|
|
||||||
|
|
||||||
test_expect_success \
|
# vgsplit accepts existing vg as destination of split
|
||||||
"(lvm$mdatype) vgsplit accepts --maxphysicalvolumes 128 on new VG" \
|
vgcreate -M$mdatype $vg1 $dev1 $dev2
|
||||||
'vgcreate -M$mdatype $vg1 $d1 $d2 &&
|
vgcreate -M$mdatype $vg2 $dev3 $dev4
|
||||||
vgsplit --maxphysicalvolumes 128 $vg1 $vg2 $d1 &&
|
vgsplit $vg1 $vg2 $dev1 1>err
|
||||||
check_vg_field_ $vg2 max_pv 128 &&
|
grep "Existing volume group \"$vg2\" successfully split from \"$vg1\"" err
|
||||||
vgremove $vg1 &&
|
vgremove $vg1
|
||||||
vgremove $vg2'
|
vgremove $vg2
|
||||||
|
|
||||||
test_expect_success \
|
# vgsplit accepts --maxphysicalvolumes 128 on new VG
|
||||||
"(lvm$mdatype) vgsplit accepts --maxlogicalvolumes 128 on new VG" \
|
vgcreate -M$mdatype $vg1 $dev1 $dev2
|
||||||
'vgcreate -M$mdatype $vg1 $d1 $d2 &&
|
vgsplit --maxphysicalvolumes 128 $vg1 $vg2 $dev1
|
||||||
vgsplit --maxlogicalvolumes 128 $vg1 $vg2 $d1 &&
|
check_vg_field_ $vg2 max_pv 128
|
||||||
check_vg_field_ $vg2 max_lv 128 &&
|
vgremove $vg1
|
||||||
vgremove $vg1 &&
|
vgremove $vg2
|
||||||
vgremove $vg2'
|
|
||||||
|
|
||||||
test_expect_success \
|
# vgsplit accepts --maxlogicalvolumes 128 on new VG
|
||||||
"(lvm$mdatype) vgsplit rejects split because max_pv of destination would be exceeded" \
|
vgcreate -M$mdatype $vg1 $dev1 $dev2
|
||||||
'vgcreate -M$mdatype --maxphysicalvolumes 2 $vg1 $d1 $d2 &&
|
vgsplit --maxlogicalvolumes 128 $vg1 $vg2 $dev1
|
||||||
vgcreate -M$mdatype --maxphysicalvolumes 2 $vg2 $d3 $d4 &&
|
check_vg_field_ $vg2 max_lv 128
|
||||||
vgsplit $vg1 $vg2 $d1 2>err;
|
vgremove $vg1
|
||||||
status=$?; echo status=$status; test $status = 5 &&
|
vgremove $vg2
|
||||||
grep "^ Maximum number of physical volumes (2) exceeded" err &&
|
|
||||||
vgremove $vg2 &&
|
|
||||||
vgremove $vg1'
|
|
||||||
|
|
||||||
test_expect_success \
|
# vgsplit rejects split because max_pv of destination would be exceeded
|
||||||
"(lvm$mdatype) vgsplit rejects split because maxphysicalvolumes given with existing vg" \
|
vgcreate -M$mdatype --maxphysicalvolumes 2 $vg1 $dev1 $dev2
|
||||||
'vgcreate -M$mdatype --maxphysicalvolumes 2 $vg1 $d1 $d2 &&
|
vgcreate -M$mdatype --maxphysicalvolumes 2 $vg2 $dev3 $dev4
|
||||||
vgcreate -M$mdatype --maxphysicalvolumes 2 $vg2 $d3 $d4 &&
|
not vgsplit $vg1 $vg2 $dev1 2>err;
|
||||||
vgsplit --maxphysicalvolumes 2 $vg1 $vg2 $d1 2>err;
|
grep "^ Maximum number of physical volumes (2) exceeded" err
|
||||||
status=$?; echo status=$status; test $status = 5 &&
|
vgremove $vg2
|
||||||
grep "^ Volume group \"$vg2\" exists, but new VG option specified" err &&
|
vgremove $vg1
|
||||||
vgremove $vg2 &&
|
|
||||||
vgremove $vg1'
|
|
||||||
|
|
||||||
test_expect_success \
|
# vgsplit rejects split because maxphysicalvolumes given with existing vg
|
||||||
"(lvm$mdatype) vgsplit rejects split because maxlogicalvolumes given with existing vg" \
|
vgcreate -M$mdatype --maxphysicalvolumes 2 $vg1 $dev1 $dev2
|
||||||
'vgcreate -M$mdatype --maxlogicalvolumes 2 $vg1 $d1 $d2 &&
|
vgcreate -M$mdatype --maxphysicalvolumes 2 $vg2 $dev3 $dev4
|
||||||
vgcreate -M$mdatype --maxlogicalvolumes 2 $vg2 $d3 $d4 &&
|
not vgsplit --maxphysicalvolumes 2 $vg1 $vg2 $dev1 2>err;
|
||||||
vgsplit --maxlogicalvolumes 2 $vg1 $vg2 $d1 2>err;
|
grep "^ Volume group \"$vg2\" exists, but new VG option specified" err
|
||||||
status=$?; echo status=$status; test $status = 5 &&
|
vgremove $vg2
|
||||||
grep "^ Volume group \"$vg2\" exists, but new VG option specified" err &&
|
vgremove $vg1
|
||||||
vgremove $vg2 &&
|
|
||||||
vgremove $vg1'
|
|
||||||
|
|
||||||
test_expect_success \
|
# vgsplit rejects split because maxlogicalvolumes given with existing vg
|
||||||
"(lvm$mdatype) vgsplit rejects split because alloc given with existing vg" \
|
vgcreate -M$mdatype --maxlogicalvolumes 2 $vg1 $dev1 $dev2
|
||||||
'vgcreate -M$mdatype --alloc cling $vg1 $d1 $d2 &&
|
vgcreate -M$mdatype --maxlogicalvolumes 2 $vg2 $dev3 $dev4
|
||||||
vgcreate -M$mdatype --alloc cling $vg2 $d3 $d4 &&
|
not vgsplit --maxlogicalvolumes 2 $vg1 $vg2 $dev1 2>err
|
||||||
vgsplit --alloc cling $vg1 $vg2 $d1 2>err;
|
grep "^ Volume group \"$vg2\" exists, but new VG option specified" err
|
||||||
status=$?; echo status=$status; test $status = 5 &&
|
vgremove $vg2
|
||||||
grep "^ Volume group \"$vg2\" exists, but new VG option specified" err &&
|
vgremove $vg1
|
||||||
vgremove $vg2 &&
|
|
||||||
vgremove $vg1'
|
|
||||||
|
|
||||||
test_expect_success \
|
# vgsplit rejects split because alloc given with existing vg" \
|
||||||
"(lvm$mdatype) vgsplit rejects split because clustered given with existing vg" \
|
vgcreate -M$mdatype --alloc cling $vg1 $dev1 $dev2
|
||||||
'vgcreate -M$mdatype --clustered n $vg1 $d1 $d2 &&
|
vgcreate -M$mdatype --alloc cling $vg2 $dev3 $dev4
|
||||||
vgcreate -M$mdatype --clustered n $vg2 $d3 $d4 &&
|
not vgsplit --alloc cling $vg1 $vg2 $dev1 2>err;
|
||||||
vgsplit --clustered n $vg1 $vg2 $d1 2>err;
|
grep "^ Volume group \"$vg2\" exists, but new VG option specified" err
|
||||||
status=$?; echo status=$status; test $status = 5 &&
|
vgremove $vg2
|
||||||
grep "^ Volume group \"$vg2\" exists, but new VG option specified" err &&
|
vgremove $vg1
|
||||||
vgremove $vg2 &&
|
|
||||||
vgremove $vg1'
|
|
||||||
|
|
||||||
test_expect_success \
|
# vgsplit rejects split because clustered given with existing vg" \
|
||||||
"(lvm$mdatype) vgsplit rejects vg with active lv" \
|
vgcreate -M$mdatype --clustered n $vg1 $dev1 $dev2
|
||||||
'pvcreate -ff -M$mdatype $d3 $d4 &&
|
vgcreate -M$mdatype --clustered n $vg2 $dev3 $dev4
|
||||||
vgcreate -M$mdatype $vg1 $d1 $d2 &&
|
not vgsplit --clustered n $vg1 $vg2 $dev1 2>err
|
||||||
vgcreate -M$mdatype $vg2 $d3 $d4 &&
|
grep "^ Volume group \"$vg2\" exists, but new VG option specified" err
|
||||||
lvcreate -l 4 -n $lv1 $vg1 &&
|
vgremove $vg2
|
||||||
vgsplit $vg1 $vg2 $d1 2>err;
|
vgremove $vg1
|
||||||
status=$?; echo status=$status; test $status = 5 &&
|
|
||||||
grep "^ Logical volumes in \"$vg1\" must be inactive\$" err &&
|
|
||||||
vgremove -f $vg2 &&
|
|
||||||
vgremove -f $vg1'
|
|
||||||
|
|
||||||
test_expect_success \
|
# vgsplit rejects vg with active lv" \
|
||||||
"(lvm$mdatype) vgsplit rejects split because max_lv is exceeded" \
|
pvcreate -M$mdatype -ff $dev3 $dev4
|
||||||
'vgcreate -M$mdatype --maxlogicalvolumes 2 $vg1 $d1 $d2 &&
|
vgcreate -M$mdatype $vg1 $dev1 $dev2
|
||||||
vgcreate -M$mdatype --maxlogicalvolumes 2 $vg2 $d3 $d4 &&
|
vgcreate -M$mdatype $vg2 $dev3 $dev4
|
||||||
lvcreate -l 4 -n $lv1 $vg1 &&
|
lvcreate -l 4 -n $lv1 $vg1
|
||||||
lvcreate -l 4 -n $lv2 $vg1 &&
|
not vgsplit $vg1 $vg2 $dev1 2>err;
|
||||||
lvcreate -l 4 -n $lv3 $vg2 &&
|
grep "^ Logical volumes in \"$vg1\" must be inactive\$" err
|
||||||
vgchange -an $vg1 &&
|
vgremove -f $vg2
|
||||||
vgchange -an $vg2 &&
|
vgremove -f $vg1
|
||||||
vgsplit $vg1 $vg2 $d1 2>err;
|
|
||||||
status=$?; echo status=$status; test $status = 5 &&
|
|
||||||
grep "^ Maximum number of logical volumes (2) exceeded" err &&
|
|
||||||
vgremove -f $vg2 &&
|
|
||||||
vgremove -f $vg1'
|
|
||||||
|
|
||||||
test_expect_success \
|
# vgsplit rejects split because max_lv is exceeded" \
|
||||||
"(lvm$mdatype) vgsplit verify default - max_lv attribute from new VG is same as source VG" \
|
vgcreate -M$mdatype --maxlogicalvolumes 2 $vg1 $dev1 $dev2
|
||||||
'vgcreate -M$mdatype $vg1 $d1 $d2 &&
|
vgcreate -M$mdatype --maxlogicalvolumes 2 $vg2 $dev3 $dev4
|
||||||
lvcreate -l 4 -n $lv1 $vg1 &&
|
lvcreate -l 4 -n $lv1 $vg1
|
||||||
vgchange -an $vg1 &&
|
lvcreate -l 4 -n $lv2 $vg1
|
||||||
vgsplit $vg1 $vg2 $d1 &&
|
lvcreate -l 4 -n $lv3 $vg2
|
||||||
compare_vg_field_ $vg1 $vg2 max_lv &&
|
vgchange -an $vg1
|
||||||
vgremove -f $vg2 &&
|
vgchange -an $vg2
|
||||||
vgremove -f $vg1'
|
not vgsplit $vg1 $vg2 $dev1 2>err;
|
||||||
|
grep "^ Maximum number of logical volumes (2) exceeded" err
|
||||||
|
vgremove -f $vg2
|
||||||
|
vgremove -f $vg1
|
||||||
|
|
||||||
test_expect_success \
|
# vgsplit verify default - max_lv attribute from new VG is same as source VG" \
|
||||||
"(lvm$mdatype) vgsplit verify default - max_pv attribute from new VG is same as source VG" \
|
vgcreate -M$mdatype $vg1 $dev1 $dev2
|
||||||
'vgcreate -M$mdatype $vg1 $d1 $d2 &&
|
lvcreate -l 4 -n $lv1 $vg1
|
||||||
lvcreate -l 4 -n $lv1 $vg1 &&
|
vgchange -an $vg1
|
||||||
vgchange -an $vg1 &&
|
vgsplit $vg1 $vg2 $dev1
|
||||||
vgsplit $vg1 $vg2 $d1 &&
|
compare_vg_field_ $vg1 $vg2 max_lv
|
||||||
compare_vg_field_ $vg1 $vg2 max_pv &&
|
vgremove -f $vg2
|
||||||
vgremove -f $vg2 &&
|
vgremove -f $vg1
|
||||||
vgremove -f $vg1'
|
|
||||||
|
|
||||||
test_expect_success \
|
# vgsplit verify default - max_pv attribute from new VG is same as source VG" \
|
||||||
"(lvm$mdatype) vgsplit verify default - vg_fmt attribute from new VG is same as source VG" \
|
vgcreate -M$mdatype $vg1 $dev1 $dev2
|
||||||
'vgcreate -M$mdatype $vg1 $d1 $d2 &&
|
lvcreate -l 4 -n $lv1 $vg1
|
||||||
lvcreate -l 4 -n $lv1 $vg1 &&
|
vgchange -an $vg1
|
||||||
vgchange -an $vg1 &&
|
vgsplit $vg1 $vg2 $dev1
|
||||||
vgsplit $vg1 $vg2 $d1 &&
|
compare_vg_field_ $vg1 $vg2 max_pv
|
||||||
compare_vg_field_ $vg1 $vg2 vg_fmt &&
|
vgremove -f $vg2
|
||||||
vgremove -f $vg2 &&
|
vgremove -f $vg1
|
||||||
vgremove -f $vg1'
|
|
||||||
|
|
||||||
test_expect_success \
|
# vgsplit verify default - vg_fmt attribute from new VG is same as source VG" \
|
||||||
"(lvm$mdatype) vgsplit rejects split because PV not in VG" \
|
vgcreate -M$mdatype $vg1 $dev1 $dev2
|
||||||
'vgcreate -M$mdatype $vg1 $d1 $d2 &&
|
lvcreate -l 4 -n $lv1 $vg1
|
||||||
vgcreate -M$mdatype $vg2 $d3 $d4 &&
|
vgchange -an $vg1
|
||||||
lvcreate -l 4 -n $lv1 $vg1 &&
|
vgsplit $vg1 $vg2 $dev1
|
||||||
lvcreate -l 4 -n $lv2 $vg1 &&
|
compare_vg_field_ $vg1 $vg2 vg_fmt
|
||||||
vgchange -an $vg1 &&
|
vgremove -f $vg2
|
||||||
vgsplit $vg1 $vg2 $d3 2>err;
|
vgremove -f $vg1
|
||||||
status=$?; echo status=$status; test $status = 5 &&
|
|
||||||
vgremove -f $vg2 &&
|
# vgsplit rejects split because PV not in VG" \
|
||||||
vgremove -f $vg1'
|
vgcreate -M$mdatype $vg1 $dev1 $dev2
|
||||||
|
vgcreate -M$mdatype $vg2 $dev3 $dev4
|
||||||
|
lvcreate -l 4 -n $lv1 $vg1
|
||||||
|
lvcreate -l 4 -n $lv2 $vg1
|
||||||
|
vgchange -an $vg1
|
||||||
|
not vgsplit $vg1 $vg2 $dev3 2>err;
|
||||||
|
vgremove -f $vg2
|
||||||
|
vgremove -f $vg1
|
||||||
done
|
done
|
||||||
|
|
||||||
test_expect_success \
|
# ONLY LVM2 metadata
|
||||||
"(lvm2) setup PVs" '
|
# setup PVs" '
|
||||||
pvcreate -M$mdatype --metadatacopies 0 $d5'
|
pvcreate --metadatacopies 0 $dev5
|
||||||
|
|
||||||
test_expect_success \
|
# vgsplit rejects to give away pv with the last mda copy
|
||||||
"(lvm2) vgsplit rejects to give away pv with the last mda copy" '
|
vgcreate $vg1 $dev5 $dev2
|
||||||
vgcreate -M2 $vg1 $d5 $d2 &&
|
lvcreate -l 10 -n $lv1 $vg1
|
||||||
lvcreate -l 10 -n $lv1 $vg1 &&
|
lvchange -an $vg1/$lv1
|
||||||
lvchange -an $vg1/$lv1 &&
|
vg_validate_pvlv_counts_ $vg1 2 1 0
|
||||||
vg_validate_pvlv_counts_ $vg1 2 1 0 &&
|
not vgsplit $vg1 $vg2 $dev5;
|
||||||
{ vgsplit $vg1 $vg2 $d5;
|
vg_validate_pvlv_counts_ $vg1 2 1 0
|
||||||
status=$?; echo status=$status; test $status != 0 &&
|
vgremove -ff $vg1
|
||||||
vg_validate_pvlv_counts_ $vg1 2 1 0 &&
|
|
||||||
vgremove -ff $vg1
|
|
||||||
}
|
|
||||||
'
|
|
||||||
|
|
||||||
test_expect_success \
|
# vgsplit rejects split because metadata types differ
|
||||||
'(lvm2) vgsplit rejects split because metadata types differ' \
|
pvcreate -ff -M1 $dev3 $dev4
|
||||||
'pvcreate -ff -M1 $d3 $d4 &&
|
pvcreate -ff $dev1 $dev2
|
||||||
pvcreate -ff -M2 $d1 $d2 &&
|
vgcreate -M1 $vg1 $dev3 $dev4
|
||||||
vgcreate -M1 $vg1 $d3 $d4 &&
|
vgcreate $vg2 $dev1 $dev2
|
||||||
vgcreate -M2 $vg2 $d1 $d2 &&
|
not vgsplit $vg1 $vg2 $dev3 2>err;
|
||||||
vgsplit $vg1 $vg2 $d3 2>err;
|
grep "^ Metadata types differ" err
|
||||||
status=$?; echo status=$status; test $status = 5 &&
|
vgremove $vg2
|
||||||
grep "^ Metadata types differ" err &&
|
vgremove $vg1
|
||||||
vgremove $vg2 &&
|
|
||||||
vgremove $vg1'
|
|
||||||
|
|
||||||
test_done
|
|
||||||
# Local Variables:
|
|
||||||
# indent-tabs-mode: nil
|
|
||||||
# End:
|
|
||||||
|
@ -87,6 +87,7 @@ prepare_devs() {
|
|||||||
lv=LV
|
lv=LV
|
||||||
lv1=LV1
|
lv1=LV1
|
||||||
lv2=LV2
|
lv2=LV2
|
||||||
|
lv3=LV3
|
||||||
}
|
}
|
||||||
|
|
||||||
disable_dev() {
|
disable_dev() {
|
||||||
|
Loading…
Reference in New Issue
Block a user