2008-09-29 15:59:19 +00:00
# Copyright (C) 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 = "foo" # silence test-lib for now
. ./test-lib.sh
aux( ) {
2008-10-14 19:48:01 +00:00
# use just "$@" for verbose operation
" $@ " > /dev/null 2> /dev/null
2008-10-06 16:55:30 +00:00
#"$@"
2008-09-29 15:59:19 +00:00
}
2008-10-06 16:55:30 +00:00
STACKTRACE( ) {
trap - ERR;
i = 0;
while FUNC = ${ FUNCNAME [ $i ] } ; test " $FUNC " != "main" ; do
echo " $i ${ FUNC } () called from ${ BASH_SOURCE [ $i ] } : ${ BASH_LINENO [ $i ] } "
i = $(( $i + 1 )) ;
done
2010-03-17 14:55:28 +00:00
# Attempt to get a stacktrace if a core file exists
# and the lvm binary was built with debugging
TEST_LVM_BINARY = $( dirname $( which lvm) ) /../../tools/lvm
TEST_LVM_CORE = ` ls core* | head -1`
GDB_BINARY = ` which gdb`
READELF_BINARY = ` which readelf`
if [ -n " $TEST_LVM_CORE " -a -n " $GDB_BINARY " -a -n " $READELF_BINARY " ] ; then
if $READELF_BINARY -S $TEST_LVM_BINARY 2>& 1 | grep -q .debug_info; then
echo bt full > gdb_commands.txt
echo l >> gdb_commands.txt
echo quit >> gdb_commands.txt
$GDB_BINARY -batch -c $TEST_LVM_CORE -x gdb_commands.txt $TEST_LVM_BINARY
fi
fi
2010-02-15 16:30:13 +00:00
}
init_udev_transaction( ) {
if test " $DM_UDEV_SYNCHRONISATION " = 1; then
2010-03-23 14:47:35 +00:00
COOKIE = $( dmsetup udevcreatecookie)
# Cookie is not generated if udev is not running!
if test -n " $COOKIE " ; then
export DM_UDEV_COOKIE = $COOKIE
fi
2010-02-15 16:30:13 +00:00
fi
}
finish_udev_transaction( ) {
2010-03-23 14:47:35 +00:00
if test " $DM_UDEV_SYNCHRONISATION " = 1 -a -n " $DM_UDEV_COOKIE " ; then
2010-02-15 16:30:13 +00:00
dmsetup udevreleasecookie
unset DM_UDEV_COOKIE
fi
}
2008-10-06 16:55:30 +00:00
2010-03-18 09:19:30 +00:00
prepare_clvmd( ) {
if test -z " $LVM_TEST_LOCKING " || test " $LVM_TEST_LOCKING " -ne 3 ; then
return 0 # not needed
fi
if pgrep clvmd ; then
echo " Cannot use fake cluster locking with real clvmd ( $( pgrep clvmd) ) running. "
2010-03-18 09:27:39 +00:00
exit 200
2010-03-18 09:19:30 +00:00
fi
# skip if we don't have our own clvmd...
( which clvmd | grep $abs_builddir ) || exit 200
trap 'aux teardown_' EXIT # don't forget to clean up
clvmd -Isinglenode -d 1 &
LOCAL_CLVMD = " $! "
}
2008-09-29 15:59:19 +00:00
teardown( ) {
2008-10-14 19:48:01 +00:00
echo $LOOP
echo $PREFIX
2010-03-18 09:19:30 +00:00
test -n " $LOCAL_CLVMD " && kill -9 " $LOCAL_CLVMD "
2008-10-14 19:48:01 +00:00
test -n " $PREFIX " && {
2008-12-10 16:16:53 +00:00
rm -rf $G_root_ /dev/$PREFIX *
2010-02-15 16:30:13 +00:00
init_udev_transaction
2008-10-14 19:48:01 +00:00
while dmsetup table | grep -q ^$PREFIX ; do
2009-05-13 19:18:47 +00:00
for s in ` dmsetup table | grep ^$PREFIX | awk '{ print substr($1,1,length($1)-1) }' ` ; do
2008-10-14 19:48:01 +00:00
dmsetup remove $s 2>/dev/null > /dev/null || true
done
done
2010-02-15 16:30:13 +00:00
finish_udev_transaction
2008-10-14 19:48:01 +00:00
}
2008-09-29 15:59:19 +00:00
2010-01-19 16:44:57 +00:00
# NOTE: SCSI_DEBUG_DEV test must come before the LOOP test because
# prepare_scsi_debug_dev() also sets LOOP to short-circuit prepare_loop()
if [ -n " $SCSI_DEBUG_DEV " ] ; then
modprobe -r scsi_debug
else
test -n " $LOOP " && losetup -d $LOOP
test -n " $LOOPFILE " && rm -f $LOOPFILE
fi
unset devs # devs is set in prepare_devs()
2009-01-09 10:16:57 +00:00
}
2008-09-29 15:59:19 +00:00
2009-01-09 10:16:57 +00:00
teardown_( ) {
teardown
2008-10-14 19:48:01 +00:00
cleanup_ # user-overridable cleanup
testlib_cleanup_ # call test-lib cleanup routine, too
2008-09-29 15:59:19 +00:00
}
make_ioerror( ) {
2008-10-14 19:48:01 +00:00
echo 0 10000000 error | dmsetup create ioerror
2008-12-10 16:16:53 +00:00
ln -s $G_dev_ /mapper/ioerror $G_dev_ /ioerror
2008-09-29 15:59:19 +00:00
}
prepare_loop( ) {
2008-10-14 19:48:01 +00:00
size = $1
test -n " $size " || size = 32
2008-09-29 15:59:19 +00:00
2008-10-14 19:48:01 +00:00
test -n " $LOOP " && return 0
2009-01-09 10:16:57 +00:00
trap 'aux teardown_' EXIT # don't forget to clean up
2008-10-06 16:55:30 +00:00
trap 'set +vex; STACKTRACE; set -vex' ERR
#trap - ERR
LOOPFILE = " $PWD /test.img "
dd if = /dev/zero of = " $LOOPFILE " bs = $(( 1024 * 1024 )) count = 1 seek = $(( $size - 1 ))
if LOOP = ` losetup -s -f " $LOOPFILE " 2>/dev/null` ; then
return 0
elif LOOP = ` losetup -f` && losetup $LOOP " $LOOPFILE " ; then
# no -s support
return 0
else
# no -f support
2008-12-05 05:03:23 +00:00
# Iterate through $G_dev_/loop{,/}{0,1,2,3,4,5,6,7}
2008-10-06 16:55:30 +00:00
for slash in '' /; do
2008-12-05 05:03:23 +00:00
for i in 0 1 2 3 4 5 6 7; do
2008-10-06 16:55:30 +00:00
local dev = $G_dev_ /loop$slash $i
! losetup $dev >/dev/null 2>& 1 || continue
# got a free
losetup " $dev " " $LOOPFILE "
LOOP = $dev
2008-12-05 05:03:23 +00:00
break
2008-10-06 16:55:30 +00:00
done
2008-12-05 05:03:23 +00:00
if [ -n " $LOOP " ] ; then
break
fi
2008-10-06 16:55:30 +00:00
done
2008-11-04 14:38:53 +00:00
test -n " $LOOP " # confirm or fail
return 0
2008-10-06 16:55:30 +00:00
fi
2008-11-04 14:38:53 +00:00
exit 1 # should not happen
2008-09-29 15:59:19 +00:00
}
2010-01-19 16:44:57 +00:00
get_sd_devs_( )
{
# prepare_scsi_debug_dev() requires the ability to lookup
# the scsi_debug created SCSI device in /dev/
local _devs = $( lvmdiskscan --config 'devices { filter = [ "a|/dev/sd.*|", "r|.*|" ] scan = "/dev/" }' | grep /dev/sd | awk '{ print $1 }' )
echo $_devs
}
# A drop-in replacement for prepare_loop() that uses scsi_debug to create
# a ramdisk-based SCSI device upon which all LVM devices will be created
# - scripts must take care not to use a DEV_SIZE that will enduce OOM-killer
prepare_scsi_debug_dev( )
{
local DEV_SIZE = " $1 "
shift
local SCSI_DEBUG_PARAMS = " $@ "
test -n " $SCSI_DEBUG_DEV " && return 0
trap 'aux teardown_' EXIT # don't forget to clean up
trap 'set +vex; STACKTRACE; set -vex' ERR
# Skip test if awk isn't available (required for get_sd_devs_)
which awk || exit 200
# Skip test if scsi_debug module is unavailable or is already in use
modinfo scsi_debug || exit 200
lsmod | grep -q scsi_debug && exit 200
# Create the scsi_debug device and determine the new scsi device's name
local devs_before = ` get_sd_devs_`
# NOTE: it will _never_ make sense to pass num_tgts param;
# last param wins.. so num_tgts=1 is imposed
2010-03-28 15:52:04 +00:00
modprobe scsi_debug dev_size_mb = $DEV_SIZE $SCSI_DEBUG_PARAMS num_tgts = 1 || exit 200
2010-01-19 16:44:57 +00:00
sleep 2 # allow for async Linux SCSI device registration
local devs_after = ` get_sd_devs_`
for dev1 in $devs_after ; do
FOUND = 0
for dev2 in $devs_before ; do
if [ " $dev1 " = " $dev2 " ] ; then
FOUND = 1
break
fi
done
if [ $FOUND -eq 0 ] ; then
# Create symlink to scsi_debug device in $G_dev_
SCSI_DEBUG_DEV = $G_dev_ /$( basename $dev1 )
# Setting $LOOP provides means for prepare_devs() override
LOOP = $SCSI_DEBUG_DEV
ln -snf $dev1 $SCSI_DEBUG_DEV
return 0
fi
done
exit 1 # should not happen
}
cleanup_scsi_debug_dev( )
{
aux teardown
unset SCSI_DEBUG_DEV
}
2008-09-29 15:59:19 +00:00
prepare_devs( ) {
2008-10-14 19:48:01 +00:00
local n = " $1 "
test -z " $n " && n = 3
local devsize = " $2 "
test -z " $devsize " && devsize = 33
2009-05-13 19:18:47 +00:00
local pvname = " $3 "
test -z " $pvname " && pvname = "pv"
2008-10-14 19:48:01 +00:00
prepare_loop $(( $n * $devsize ))
PREFIX = " LVMTEST $$ "
2008-12-05 05:03:23 +00:00
if ! loopsz = ` blockdev --getsz $LOOP 2>/dev/null` ; then
loopsz = ` blockdev --getsize $LOOP 2>/dev/null`
fi
2008-10-14 19:48:01 +00:00
local size = $(( $loopsz / $n ))
2010-02-15 16:30:13 +00:00
init_udev_transaction
2008-10-14 19:48:01 +00:00
for i in ` seq 1 $n ` ; do
2009-05-13 19:18:47 +00:00
local name = " ${ PREFIX } $pvname $i "
2008-10-14 19:48:01 +00:00
local dev = " $G_dev_ /mapper/ $name "
eval " dev $i = $dev "
devs = " $devs $dev "
echo 0 $size linear $LOOP $(( ( $i - 1 ) * $size )) > $name .table
dmsetup create $name $name .table
done
2010-02-15 16:30:13 +00:00
finish_udev_transaction
2008-09-29 15:59:19 +00:00
2010-04-06 17:36:41 +00:00
for i in ` seq 1 $n ` ; do
local name = " ${ PREFIX } $pvname $i "
dmsetup info -c $name
done
for i in ` seq 1 $n ` ; do
local name = " ${ PREFIX } $pvname $i "
dmsetup table $name
done
2008-09-29 15:59:19 +00:00
# set up some default names
2008-10-14 19:48:01 +00:00
vg = ${ PREFIX } vg
vg1 = ${ PREFIX } vg1
vg2 = ${ PREFIX } vg2
lv = LV
lv1 = LV1
lv2 = LV2
lv3 = LV3
2009-05-13 21:29:10 +00:00
lv4 = LV4
2008-09-29 15:59:19 +00:00
}
disable_dev( ) {
2010-02-15 16:30:13 +00:00
init_udev_transaction
2008-10-14 19:48:01 +00:00
for dev in " $@ " ; do
2008-09-29 15:59:19 +00:00
# first we make the device inaccessible
2008-10-14 19:48:01 +00:00
echo 0 10000000 error | dmsetup load $dev
dmsetup resume $dev
2008-09-29 15:59:19 +00:00
# now let's try to get rid of it if it's unused
#dmsetup remove $dev
2008-10-14 19:48:01 +00:00
done
2010-02-15 16:30:13 +00:00
finish_udev_transaction
2008-09-29 15:59:19 +00:00
}
enable_dev( ) {
2010-02-15 16:30:13 +00:00
init_udev_transaction
2008-10-14 19:48:01 +00:00
for dev in " $@ " ; do
local name = ` echo " $dev " | sed -e 's,.*/,,' `
dmsetup create $name $name .table || dmsetup load $name $name .table
dmsetup resume $dev
done
2010-02-15 16:30:13 +00:00
finish_udev_transaction
2008-09-29 15:59:19 +00:00
}
2009-01-09 10:16:57 +00:00
backup_dev( ) {
for dev in " $@ " ; do
dd if = $dev of = $dev .backup bs = 1024
done
}
restore_dev( ) {
for dev in " $@ " ; do
test -e $dev .backup || {
echo " Internal error: $dev not backed up, can't restore! "
exit 1
}
dd of = $dev if = $dev .backup bs = 1024
done
}
2008-09-29 15:59:19 +00:00
prepare_pvs( ) {
2008-10-14 19:48:01 +00:00
prepare_devs " $@ "
pvcreate $devs
2008-09-29 15:59:19 +00:00
}
prepare_vg( ) {
2008-10-14 19:48:01 +00:00
prepare_pvs " $@ "
2009-12-28 18:33:04 +00:00
vgcreate -c n $vg $devs
2010-04-06 14:25:07 +00:00
pvs -v
2008-09-29 15:59:19 +00:00
}
prepare_lvmconf( ) {
2009-08-02 21:45:45 +00:00
local filter = " $1 "
test -z " $filter " && \
filter = '[ "a/dev\/mirror/", "a/dev\/mapper\/.*pv[0-9_]*$/", "r/.*/" ]'
2010-03-18 09:19:30 +00:00
locktype =
if test -n " $LVM_TEST_LOCKING " ; then locktype = " locking_type = $LVM_TEST_LOCKING " ; fi
2008-10-14 19:48:01 +00:00
cat > $G_root_ /etc/lvm.conf <<-EOF
2010-03-31 22:18:17 +00:00
$LVM_TEST_CONFIG
2008-09-29 15:59:19 +00:00
devices {
dir = " $G_dev_ "
scan = " $G_dev_ "
2009-08-02 21:45:45 +00:00
filter = $filter
2008-09-29 15:59:19 +00:00
cache_dir = " $G_root_ /etc "
sysfs_scan = 0
}
log {
syslog = 0
indent = 1
}
backup {
backup = 0
archive = 0
}
global {
2009-11-30 17:17:11 +00:00
abort_on_internal_errors = 1
2008-09-29 15:59:19 +00:00
library_dir = " $G_root_ /lib "
2009-11-30 17:17:11 +00:00
locking_dir = " $G_root_ /var/lock/lvm "
2010-03-18 09:19:30 +00:00
$locktype
2008-09-29 15:59:19 +00:00
}
2010-01-11 15:43:19 +00:00
activation {
udev_sync = 1
udev_rules = 1
}
2008-09-29 15:59:19 +00:00
EOF
}
2010-02-17 15:41:28 +00:00
set -vexE -o pipefail
2008-09-29 15:59:19 +00:00
aux prepare_lvmconf
2010-03-18 09:19:30 +00:00
prepare_clvmd
2008-09-29 15:59:19 +00:00