mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-21 22:04:19 +03:00
a59c3731c3
Add make help target. Add LVM_TEST_PARALLEL to support parallel runs of tests Work around the problem the dmsetup table/info may return error by using dmtable and dminfo function that will use 'should'. (Error happens when some concurently running process removes table entry while dmsetup command resolves table entries inside the loop.)
100 lines
2.5 KiB
Bash
100 lines
2.5 KiB
Bash
#!/bin/sh
|
|
# Copyright (C) 2011-2012 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
|
|
|
|
. lib/test
|
|
|
|
aux prepare_vg 3
|
|
|
|
# fail multiple devices
|
|
for i in "$dev1" "$dev2" "$dev3" ; do
|
|
for j in "$dev2" "$dev3" ; do
|
|
if test "$i" = "$j" ; then continue ; fi
|
|
|
|
vgremove -ff $vg
|
|
vgcreate $vg "$dev1" "$dev2" "$dev3"
|
|
# exit 1
|
|
|
|
lvcreate -l1 -n $lv1 $vg "$dev1"
|
|
|
|
aux disable_dev "$i" "$j"
|
|
|
|
vgreduce --removemissing --force $vg
|
|
|
|
# check if reduced device was removed
|
|
test "$i" = "$dev1" && dm_table | not egrep "$vg-$lv1: *[^ ]+"
|
|
|
|
lvcreate -l1 -n $lv2 $vg
|
|
|
|
test "$i" != "$dev1" && check lv_exists $vg $lv1
|
|
check lv_exists $vg $lv2
|
|
|
|
aux enable_dev "$i" "$j"
|
|
vgscan
|
|
|
|
test "$i" != "$dev1" && check lv_exists $vg $lv1
|
|
check lv_exists $vg $lv2
|
|
done
|
|
done
|
|
|
|
vgremove -ff $vg
|
|
vgcreate $vg "$dev1" "$dev2" "$dev3"
|
|
|
|
# use tricky 'dd'
|
|
for i in "$dev1" "$dev2" "$dev3" ; do
|
|
for j in "$dev2" "$dev3" ; do
|
|
|
|
if test "$i" = "$j" ; then continue ; fi
|
|
|
|
dd if="$i" of=backup_i bs=256K count=1
|
|
dd if="$j" of=backup_j bs=256K count=1
|
|
|
|
lvcreate -l1 -n $lv1 $vg "$dev1"
|
|
|
|
dd if=backup_j of="$j" bs=256K count=1
|
|
dd if=backup_i of="$i" bs=256K count=1
|
|
|
|
check lv_exists $vg $lv1
|
|
# mda should be now consistent
|
|
lvremove -f $vg/$lv1
|
|
done
|
|
done
|
|
|
|
|
|
# confuse lvm with active LV left behind
|
|
dd if="$dev1" of=backup_i bs=256K count=1
|
|
dd if="$dev2" of=backup_j bs=256K count=1
|
|
|
|
lvcreate -l1 $vg "$dev1"
|
|
|
|
dd if=backup_j of="$dev2" bs=256K count=1
|
|
dd if=backup_i of="$dev1" bs=256K count=1
|
|
|
|
# CHECKME: following command writes here:
|
|
# vgreduce --removemissing --force $vg
|
|
#
|
|
# WARNING: Inconsistent metadata found for VG LVMTESTvg - updating to use version 2
|
|
# Volume group "LVMTESTvg" is already consistent
|
|
|
|
# dirty game
|
|
dd if=/dev/zero of="$dev3" bs=256K count=1
|
|
aux notify_lvmetad "$dev3" # udev be watching you
|
|
|
|
vgreduce --removemissing --force $vg
|
|
|
|
# FIXME: here is LV1 left active - but metadata does not know about it
|
|
# and lvcreate does not check whether such device exists in the table
|
|
# so it ends with:
|
|
#
|
|
# device-mapper: create ioctl failed: Device or resource busy
|
|
# Failed to activate new LV.
|
|
|
|
should lvcreate -l1 $vg "$dev1"
|