2008-03-04 22:48:32 +03:00
#!/bin/sh
2008-04-10 23:59:43 +04:00
# Copyright (C) 2007-2008 Red Hat, Inc. All rights reserved.
2008-03-04 22:48:32 +03: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 vgsplit command options for validity'
privileges_required_ = 1
. ./test-lib.sh
cleanup_( )
{
test -n " $d1 " && losetup -d " $d1 "
test -n " $d2 " && losetup -d " $d2 "
test -n " $d3 " && losetup -d " $d3 "
test -n " $d4 " && losetup -d " $d4 "
2008-08-12 14:01:56 +04:00
test -n " $d5 " && losetup -d " $d5 "
rm -f " $f1 " " $f2 " " $f3 " " $f4 " " $f5 "
2008-03-04 22:48:32 +03:00
}
# 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
# 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 " ) &&
2008-08-12 14:01:56 +04:00
f5 = $( pwd ) /5 && d5 = $( loop_setup_ " $f5 " ) &&
2008-03-04 22:48:32 +03:00
vg1 = $( this_test_) -test-vg1-$$ &&
vg2 = $( this_test_) -test-vg2-$$ &&
lv1 = $( this_test_) -test-lv1-$$ &&
lv2 = $( this_test_) -test-lv2-$$ &&
2008-07-17 07:17:01 +04:00
lv3 = $( this_test_) -test-lv3-$$ '
2008-03-04 22:48:32 +03:00
2008-07-17 08:03:04 +04:00
for mdatype in 2
2008-07-17 07:17:01 +04:00
do
2008-03-04 22:48:32 +03:00
test_expect_success \
2008-07-17 07:17:01 +04:00
" (lvm $mdatype ) setup PVs " \
2008-08-12 14:01:56 +04:00
' pvcreate -M$mdatype $d1 $d2 $d3 $d4 &&
pvcreate -M$mdatype --metadatacopies 0 $d5 '
2008-07-17 07:17:01 +04:00
test_expect_success \
" (lvm $mdatype ) vgsplit accepts new vg as destination of split " \
' vgcreate -M$mdatype $vg1 $d1 $d2 &&
2008-03-04 22:48:32 +03:00
vgsplit $vg1 $vg2 $d1 1>err;
2008-04-10 05:06:48 +04:00
status = $? ; echo status = $status ; test $status = 0 &&
2008-03-04 22:48:32 +03:00
grep " New volume group \" $vg2 \" successfully split from \" $vg1 \" " err &&
vgremove $vg1 &&
vgremove $vg2 '
test_expect_success \
2008-07-17 07:17:01 +04:00
" (lvm $mdatype ) vgsplit accepts existing vg as destination of split " \
' vgcreate -M$mdatype $vg1 $d1 $d2 &&
vgcreate -M$mdatype $vg2 $d3 $d4 &&
2008-03-04 22:48:32 +03:00
vgsplit $vg1 $vg2 $d1 1>err;
2008-04-10 05:06:48 +04:00
status = $? ; echo status = $status ; test $status = 0 &&
2008-03-04 22:48:32 +03:00
grep " Existing volume group \" $vg2 \" successfully split from \" $vg1 \" " err &&
vgremove $vg1 &&
vgremove $vg2 '
test_expect_success \
2008-07-17 07:17:01 +04:00
" (lvm $mdatype ) vgsplit accepts --maxphysicalvolumes 128 on new VG " \
' vgcreate -M$mdatype $vg1 $d1 $d2 &&
2008-03-04 22:48:32 +03:00
vgsplit --maxphysicalvolumes 128 $vg1 $vg2 $d1 &&
check_vg_field_ $vg2 max_pv 128 &&
vgremove $vg1 &&
vgremove $vg2 '
test_expect_success \
2008-07-17 07:17:01 +04:00
" (lvm $mdatype ) vgsplit accepts --maxlogicalvolumes 128 on new VG " \
' vgcreate -M$mdatype $vg1 $d1 $d2 &&
2008-03-04 22:48:32 +03:00
vgsplit --maxlogicalvolumes 128 $vg1 $vg2 $d1 &&
check_vg_field_ $vg2 max_lv 128 &&
vgremove $vg1 &&
vgremove $vg2 '
test_expect_success \
2008-07-17 07:17:01 +04:00
" (lvm $mdatype ) vgsplit rejects split because max_pv of destination would be exceeded " \
' vgcreate -M$mdatype --maxphysicalvolumes 2 $vg1 $d1 $d2 &&
vgcreate -M$mdatype --maxphysicalvolumes 2 $vg2 $d3 $d4 &&
2008-03-04 22:48:32 +03:00
vgsplit $vg1 $vg2 $d1 2>err;
2008-04-10 05:06:48 +04:00
status = $? ; echo status = $status ; test $status = 5 &&
2008-03-04 22:48:32 +03:00
grep "^ Maximum number of physical volumes (2) exceeded" err &&
vgremove $vg2 &&
vgremove $vg1 '
test_expect_success \
2008-07-17 07:17:01 +04:00
" (lvm $mdatype ) vgsplit rejects split because maxphysicalvolumes given with existing vg " \
' vgcreate -M$mdatype --maxphysicalvolumes 2 $vg1 $d1 $d2 &&
vgcreate -M$mdatype --maxphysicalvolumes 2 $vg2 $d3 $d4 &&
2008-03-04 22:48:32 +03:00
vgsplit --maxphysicalvolumes 2 $vg1 $vg2 $d1 2>err;
2008-04-10 05:06:48 +04:00
status = $? ; echo status = $status ; test $status = 5 &&
2008-03-04 22:48:32 +03:00
grep " ^ Volume group \" $vg2 \" exists, but new VG option specified " err &&
vgremove $vg2 &&
vgremove $vg1 '
test_expect_success \
2008-07-17 07:17:01 +04:00
" (lvm $mdatype ) vgsplit rejects split because maxlogicalvolumes given with existing vg " \
' vgcreate -M$mdatype --maxlogicalvolumes 2 $vg1 $d1 $d2 &&
vgcreate -M$mdatype --maxlogicalvolumes 2 $vg2 $d3 $d4 &&
2008-03-04 22:48:32 +03:00
vgsplit --maxlogicalvolumes 2 $vg1 $vg2 $d1 2>err;
2008-04-10 05:06:48 +04:00
status = $? ; echo status = $status ; test $status = 5 &&
2008-03-04 22:48:32 +03:00
grep " ^ Volume group \" $vg2 \" exists, but new VG option specified " err &&
vgremove $vg2 &&
vgremove $vg1 '
test_expect_success \
2008-07-17 07:17:01 +04:00
" (lvm $mdatype ) vgsplit rejects split because alloc given with existing vg " \
' vgcreate -M$mdatype --alloc cling $vg1 $d1 $d2 &&
vgcreate -M$mdatype --alloc cling $vg2 $d3 $d4 &&
2008-03-04 22:48:32 +03:00
vgsplit --alloc cling $vg1 $vg2 $d1 2>err;
2008-04-10 05:06:48 +04:00
status = $? ; echo status = $status ; test $status = 5 &&
2008-03-04 22:48:32 +03:00
grep " ^ Volume group \" $vg2 \" exists, but new VG option specified " err &&
vgremove $vg2 &&
vgremove $vg1 '
test_expect_success \
2008-07-17 07:17:01 +04:00
" (lvm $mdatype ) vgsplit rejects split because clustered given with existing vg " \
' vgcreate -M$mdatype --clustered n $vg1 $d1 $d2 &&
vgcreate -M$mdatype --clustered n $vg2 $d3 $d4 &&
2008-03-04 22:48:32 +03:00
vgsplit --clustered n $vg1 $vg2 $d1 2>err;
2008-04-10 05:06:48 +04:00
status = $? ; echo status = $status ; test $status = 5 &&
2008-03-04 22:48:32 +03:00
grep " ^ Volume group \" $vg2 \" exists, but new VG option specified " err &&
vgremove $vg2 &&
vgremove $vg1 '
test_expect_success \
2008-07-17 07:17:01 +04:00
" (lvm $mdatype ) vgsplit rejects vg with active lv " \
' pvcreate -ff -M$mdatype $d3 $d4 &&
vgcreate -M$mdatype $vg1 $d1 $d2 &&
vgcreate -M$mdatype $vg2 $d3 $d4 &&
2008-03-04 22:48:32 +03:00
lvcreate -l 4 -n $lv1 $vg1 &&
vgsplit $vg1 $vg2 $d1 2>err;
2008-04-10 05:06:48 +04:00
status = $? ; echo status = $status ; test $status = 5 &&
2008-03-04 22:48:32 +03:00
grep " ^ Logical volumes in \" $vg1 \" must be inactive\$ " err &&
vgremove -f $vg2 &&
vgremove -f $vg1 '
test_expect_success \
2008-07-17 07:17:01 +04:00
" (lvm $mdatype ) vgsplit rejects split because max_lv is exceeded " \
' vgcreate -M$mdatype --maxlogicalvolumes 2 $vg1 $d1 $d2 &&
vgcreate -M$mdatype --maxlogicalvolumes 2 $vg2 $d3 $d4 &&
2008-03-04 22:48:32 +03:00
lvcreate -l 4 -n $lv1 $vg1 &&
lvcreate -l 4 -n $lv2 $vg1 &&
lvcreate -l 4 -n $lv3 $vg2 &&
vgchange -an $vg1 &&
vgchange -an $vg2 &&
vgsplit $vg1 $vg2 $d1 2>err;
2008-04-10 05:06:48 +04:00
status = $? ; echo status = $status ; test $status = 5 &&
2008-03-04 22:48:32 +03:00
grep "^ Maximum number of logical volumes (2) exceeded" err &&
vgremove -f $vg2 &&
vgremove -f $vg1 '
2008-03-23 18:40:35 +03:00
test_expect_success \
2008-07-17 07:17:01 +04:00
" (lvm $mdatype ) vgsplit verify default - max_lv attribute from new VG is same as source VG " \
' vgcreate -M$mdatype $vg1 $d1 $d2 &&
2008-03-23 18:40:35 +03:00
lvcreate -l 4 -n $lv1 $vg1 &&
vgchange -an $vg1 &&
vgsplit $vg1 $vg2 $d1 &&
compare_vg_field_ $vg1 $vg2 max_lv &&
vgremove -f $vg2 &&
vgremove -f $vg1 '
test_expect_success \
2008-07-17 07:17:01 +04:00
" (lvm $mdatype ) vgsplit verify default - max_pv attribute from new VG is same as source VG " \
' vgcreate -M$mdatype $vg1 $d1 $d2 &&
2008-03-23 18:40:35 +03:00
lvcreate -l 4 -n $lv1 $vg1 &&
vgchange -an $vg1 &&
vgsplit $vg1 $vg2 $d1 &&
compare_vg_field_ $vg1 $vg2 max_pv &&
vgremove -f $vg2 &&
vgremove -f $vg1 '
test_expect_success \
2008-07-17 07:17:01 +04:00
" (lvm $mdatype ) vgsplit verify default - vg_fmt attribute from new VG is same as source VG " \
' vgcreate -M$mdatype $vg1 $d1 $d2 &&
2008-03-23 18:40:35 +03:00
lvcreate -l 4 -n $lv1 $vg1 &&
vgchange -an $vg1 &&
vgsplit $vg1 $vg2 $d1 &&
compare_vg_field_ $vg1 $vg2 vg_fmt &&
vgremove -f $vg2 &&
vgremove -f $vg1 '
2008-03-04 22:48:32 +03:00
test_expect_success \
2008-07-17 07:17:01 +04:00
" (lvm $mdatype ) vgsplit rejects split because PV not in VG " \
' vgcreate -M$mdatype $vg1 $d1 $d2 &&
vgcreate -M$mdatype $vg2 $d3 $d4 &&
2008-03-04 22:48:32 +03:00
lvcreate -l 4 -n $lv1 $vg1 &&
lvcreate -l 4 -n $lv2 $vg1 &&
vgchange -an $vg1 &&
vgsplit $vg1 $vg2 $d3 2>err;
2008-04-10 05:06:48 +04:00
status = $? ; echo status = $status ; test $status = 5 &&
2008-03-04 22:48:32 +03:00
vgremove -f $vg2 &&
vgremove -f $vg1 '
2008-08-12 14:01:56 +04:00
test_expect_success \
"(lvm2) vgsplit rejects to give away pv with the last mda copy" '
vgcreate -M$mdatype $vg1 $d5 $d2 &&
lvcreate -l 10 -n $lv1 $vg1 &&
lvchange -an $vg1 /$lv1 &&
vg_validate_pvlv_counts_ $vg1 2 1 0 &&
vgsplit $vg1 $vg2 $d5 ;
status = $? ; echo status = $status ; test $status != 0 &&
vg_validate_pvlv_counts_ $vg1 2 1 0 &&
vgremove -ff $vg1
'
2008-07-17 07:17:01 +04:00
done
test_expect_success \
'(lvm2) vgsplit rejects split because metadata types differ' \
' pvcreate -ff -M1 $d3 $d4 &&
pvcreate -ff -M2 $d1 $d2 &&
vgcreate -M1 $vg1 $d3 $d4 &&
vgcreate -M2 $vg2 $d1 $d2 &&
vgsplit $vg1 $vg2 $d3 2>err;
status = $? ; echo status = $status ; test $status = 5 &&
grep "^ Metadata types differ" err &&
vgremove $vg2 &&
vgremove $vg1 '
2008-03-04 22:48:32 +03:00
test_done
# Local Variables:
# indent-tabs-mode: nil
# End: