NetBSD-5.0.2/external/gpl2/lvm2tools/dist/test/t-vgsplit-usage.sh

#!/bin/sh
# Copyright (C) 2007-2008 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 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"
  rm -f "$f1" "$f2" "$f3" "$f4"
}

# 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") &&
   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-$$          &&
   pvcreate $d1 $d2 $d3 $d4'

test_expect_success \
  'vgsplit accepts new vg as destination of split' \
  'vgcreate $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 existing vg as destination of split' \
  'vgcreate $vg1 $d1 $d2 &&
   vgcreate $vg2 $d3 $d4 &&
   vgsplit $vg1 $vg2 $d1 1>err;
   status=$?; echo status=$status; test $status = 0 &&
   grep "Existing volume group \"$vg2\" successfully split from \"$vg1\"" err &&
   vgremove $vg1 &&
   vgremove $vg2'

test_expect_success \
  'vgsplit accepts --maxphysicalvolumes 128 on new VG' \
  'vgcreate $vg1 $d1 $d2 &&
   vgsplit --maxphysicalvolumes 128 $vg1 $vg2 $d1 &&
   check_vg_field_ $vg2 max_pv 128 &&
   vgremove $vg1 &&
   vgremove $vg2'

test_expect_success \
  'vgsplit accepts --maxlogicalvolumes 128 on new VG' \
  'vgcreate $vg1 $d1 $d2 &&
   vgsplit --maxlogicalvolumes 128 $vg1 $vg2 $d1 &&
   check_vg_field_ $vg2 max_lv 128 &&
   vgremove $vg1 &&
   vgremove $vg2'

test_expect_success \
  'vgsplit rejects split because max_pv of destination would be exceeded' \
  'vgcreate --maxphysicalvolumes 2 $vg1 $d1 $d2 &&
   vgcreate --maxphysicalvolumes 2 $vg2 $d3 $d4 &&
   vgsplit $vg1 $vg2 $d1 2>err;
   status=$?; echo status=$status; test $status = 5 &&
   grep "^  Maximum number of physical volumes (2) exceeded" err &&
   vgremove $vg2 &&
   vgremove $vg1'

test_expect_success \
  'vgsplit rejects split because maxphysicalvolumes given with existing vg' \
  'vgcreate --maxphysicalvolumes 2 $vg1 $d1 $d2 &&
   vgcreate --maxphysicalvolumes 2 $vg2 $d3 $d4 &&
   vgsplit --maxphysicalvolumes 2 $vg1 $vg2 $d1 2>err;
   status=$?; echo status=$status; test $status = 5 &&
   grep "^  Volume group \"$vg2\" exists, but new VG option specified" err &&
   vgremove $vg2 &&
   vgremove $vg1'

test_expect_success \
  'vgsplit rejects split because maxlogicalvolumes given with existing vg' \
  'vgcreate --maxlogicalvolumes 2 $vg1 $d1 $d2 &&
   vgcreate --maxlogicalvolumes 2 $vg2 $d3 $d4 &&
   vgsplit --maxlogicalvolumes 2 $vg1 $vg2 $d1 2>err;
   status=$?; echo status=$status; test $status = 5 &&
   grep "^  Volume group \"$vg2\" exists, but new VG option specified" err &&
   vgremove $vg2 &&
   vgremove $vg1'

test_expect_success \
  'vgsplit rejects split because alloc given with existing vg' \
  'vgcreate --alloc cling $vg1 $d1 $d2 &&
   vgcreate --alloc cling $vg2 $d3 $d4 &&
   vgsplit --alloc cling $vg1 $vg2 $d1 2>err;
   status=$?; echo status=$status; test $status = 5 &&
   grep "^  Volume group \"$vg2\" exists, but new VG option specified" err &&
   vgremove $vg2 &&
   vgremove $vg1'

test_expect_success \
  'vgsplit rejects split because clustered given with existing vg' \
  'vgcreate --clustered n $vg1 $d1 $d2 &&
   vgcreate --clustered n $vg2 $d3 $d4 &&
   vgsplit --clustered n $vg1 $vg2 $d1 2>err;
   status=$?; echo status=$status; test $status = 5 &&
   grep "^  Volume group \"$vg2\" exists, but new VG option specified" err &&
   vgremove $vg2 &&
   vgremove $vg1'

test_expect_success \
  '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'

test_expect_success \
  'vgsplit rejects vg with active lv' \
  'pvcreate -ff -M2 $d3 $d4 &&
   vgcreate $vg1 $d1 $d2 &&
   vgcreate $vg2 $d3 $d4 &&
   lvcreate -l 4 -n $lv1 $vg1 &&
   vgsplit $vg1 $vg2 $d1 2>err;
   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 split because max_lv is exceeded' \
  'vgcreate --maxlogicalvolumes 2 $vg1 $d1 $d2 &&
   vgcreate --maxlogicalvolumes 2 $vg2 $d3 $d4 &&
   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;
   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 \
  'verify default - max_lv attribute from new VG is same as source VG' \
  'vgcreate $vg1 $d1 $d2 &&
   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 \
  'verify default - max_pv attribute from new VG is same as source VG' \
  'vgcreate $vg1 $d1 $d2 &&
   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 \
  'verify default - vg_fmt attribute from new VG is same as source VG' \
  'vgcreate $vg1 $d1 $d2 &&
   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'

test_expect_success \
  'vgsplit rejects split because PV not in VG' \
  'vgcreate $vg1 $d1 $d2 &&
   vgcreate $vg2 $d3 $d4 &&
   lvcreate -l 4 -n $lv1 $vg1 &&
   lvcreate -l 4 -n $lv2 $vg1 &&
   vgchange -an $vg1 &&
   vgsplit $vg1 $vg2 $d3 2>err;
   status=$?; echo status=$status; test $status = 5 &&
   vgremove -f $vg2 &&
   vgremove -f $vg1'

test_done
# Local Variables:
# indent-tabs-mode: nil
# End: