1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-21 22:04:19 +03:00
lvm2/test/shell/lvcreate-repair.sh
Zdenek Kabelac a59c3731c3 Improve test suite
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.)
2012-03-28 11:10:08 +00:00

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"