2013-06-10 11:28:47 +02:00
#!/usr/bin/env bash
2017-06-29 10:38:06 +02:00
# Copyright (C) 2011-2017 Red Hat, Inc. All rights reserved.
2011-01-05 00:16:18 +00: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,
2016-01-21 11:49:46 +01:00
# Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
2011-01-05 00:16:18 +00:00
2015-10-27 15:08:43 +01:00
initskip( ) {
2017-07-10 10:40:09 +02:00
test $# -eq 0 || echo "TEST SKIPPED:" " $@ "
2015-10-27 15:08:43 +01:00
exit 200
}
2011-01-05 00:16:18 +00:00
# sanitize the environment
LANG = C
LC_ALL = C
TZ = UTC
2012-03-16 12:59:43 +00:00
# Put script name into variable, so it can used in external scripts
TESTNAME = ${ 0 ##*/ }
# Nice debug message
2012-03-20 10:51:57 +00:00
PS4 = '#${BASH_SOURCE[0]##*/}:${LINENO}+ '
2012-03-16 12:59:43 +00:00
export TESTNAME PS4
2021-03-23 11:33:30 +01:00
LVM_TEST_FLAVOUR = ${ LVM_TEST_FLAVOUR -ndev-vanilla }
2018-07-26 15:01:50 +02:00
2017-07-16 18:27:03 +02:00
LVM_TEST_BACKING_DEVICE = ${ LVM_TEST_BACKING_DEVICE - }
2017-07-12 01:15:41 +02:00
LVM_TEST_DEVDIR = ${ LVM_TEST_DEVDIR - }
2017-07-11 11:23:34 +02:00
LVM_TEST_NODEBUG = ${ LVM_TEST_NODEBUG - }
2017-07-12 01:15:41 +02:00
LVM_TEST_LVM1 = ${ LVM_TEST_LVM1 - }
2021-06-03 17:59:17 +08:00
LVM_TEST_FAILURE = ${ LVM_TEST_FAILURE - }
2021-06-03 17:59:22 +08:00
LVM_TEST_MULTI_HOST = ${ LVM_TEST_MULTI_HOST - }
2017-07-12 01:15:41 +02:00
# TODO: LVM_TEST_SHARED
SHARED = ${ SHARED - }
2017-07-11 11:23:34 +02:00
LVM_TEST_LVMLOCKD = ${ LVM_TEST_LVMLOCKD - }
LVM_TEST_LVMLOCKD_TEST = ${ LVM_TEST_LVMLOCKD_TEST - }
LVM_TEST_LVMPOLLD = ${ LVM_TEST_LVMPOLLD - }
2021-03-08 17:19:26 -06:00
LVM_TEST_DEVICES_FILE = ${ LVM_TEST_DEVICES_FILE - }
2017-07-11 11:23:34 +02:00
LVM_TEST_LOCK_TYPE_DLM = ${ LVM_TEST_LOCK_TYPE_DLM - }
LVM_TEST_LOCK_TYPE_SANLOCK = ${ LVM_TEST_LOCK_TYPE_SANLOCK - }
2021-06-03 17:59:09 +08:00
LVM_TEST_LOCK_TYPE_IDM = ${ LVM_TEST_LOCK_TYPE_IDM - }
2017-07-11 11:23:34 +02:00
SKIP_WITHOUT_CLVMD = ${ SKIP_WITHOUT_CLVMD - }
SKIP_WITH_CLVMD = ${ SKIP_WITH_CLVMD - }
SKIP_WITH_LVMPOLLD = ${ SKIP_WITH_LVMPOLLD - }
SKIP_WITH_LVMLOCKD = ${ SKIP_WITH_LVMLOCKD - }
2018-05-12 00:08:06 +02:00
SKIP_ROOT_DM_CHECK = ${ SKIP_ROOT_DM_CHECK - }
2020-09-18 14:25:50 +02:00
SKIP_WITH_LOW_SPACE = ${ SKIP_WITH_LOW_SPACE -50 }
2017-07-11 11:23:34 +02:00
2018-07-26 15:01:50 +02:00
test -n " $LVM_TEST_FLAVOUR " || { echo "NOTE: Empty flavour" >& 2; initskip; }
test -f " lib/flavour- $LVM_TEST_FLAVOUR " || { echo " NOTE: Flavour ' $LVM_TEST_FLAVOUR ' does not exist " >& 2; initskip; }
. " lib/flavour- $LVM_TEST_FLAVOUR "
2015-10-26 20:09:47 +01:00
2015-10-27 15:08:43 +01:00
test -n " $SKIP_WITHOUT_CLVMD " && test " $LVM_TEST_LOCKING " -ne 3 && initskip
2018-05-12 00:06:44 +02:00
test -n " $SKIP_WITH_CLVMD " && test " $LVM_TEST_LOCKING " = 3 && initskip
2015-10-26 20:09:47 +01:00
2024-04-05 13:17:13 +02:00
# When requested testing LVMLOCKD & LVMPOLLD - ignore skipping of marked test for lvmpolld
test -n " $LVM_TEST_LVMLOCKD " && test -n " $LVM_TEST_LVMPOLLD " && SKIP_WITH_LVMPOLLD =
2024-04-04 16:50:18 +02:00
test -n " $SKIP_WITH_LVMPOLLD " && test -n " $LVM_TEST_LVMPOLLD " && initskip
2015-10-27 15:08:43 +01:00
2016-02-22 16:13:42 -06:00
test -n " $SKIP_WITH_LVMLOCKD " && test -n " $LVM_TEST_LVMLOCKD " && initskip
2021-08-18 16:23:48 -05:00
test -n " $SKIP_WITH_DEVICES_FILE " && test -n " $LVM_TEST_DEVICES_FILE " && initskip
2015-10-27 15:08:43 +01:00
unset CDPATH
2021-06-03 17:59:17 +08:00
export LVM_TEST_BACKING_DEVICE LVM_TEST_DEVDIR LVM_TEST_NODEBUG LVM_TEST_FAILURE
2021-06-03 17:59:22 +08:00
export LVM_TEST_MULTI_HOST
2018-09-10 11:10:55 -05:00
export LVM_TEST_LVMLOCKD LVM_TEST_LVMLOCKD_TEST
2021-06-03 17:59:09 +08:00
export LVM_TEST_LVMPOLLD LVM_TEST_LOCK_TYPE_DLM LVM_TEST_LOCK_TYPE_SANLOCK LVM_TEST_LOCK_TYPE_IDM
2021-03-08 17:19:26 -06:00
export LVM_TEST_DEVICES_FILE
2015-10-27 15:08:43 +01:00
# grab some common utilities
. lib/utils
2015-10-26 20:09:47 +01:00
2012-03-16 12:59:43 +00:00
TESTOLDPWD = $( pwd )
2011-06-30 00:57:29 +00:00
COMMON_PREFIX = "LVMTEST"
2019-09-16 13:01:50 -05:00
PREFIX = " ${ COMMON_PREFIX } $$ "
2011-01-05 00:16:18 +00:00
2024-08-29 23:05:41 +02:00
# Check we are not conflicting with some exiting setup
2018-05-12 00:08:06 +02:00
if test -z " $SKIP_ROOT_DM_CHECK " ; then
2023-10-08 22:03:07 +02:00
d = $( dmsetup info -c -o name --noheadings --rows -S " suspended=Suspended||name=~ ${ PREFIX } [^0-9] " )
2023-10-13 14:59:42 +02:00
case " $d " in
"No devices found" ) ; ;
"" ) ; ;
*) die " DM table already has either suspended or $PREFIX prefixed devices: $d " ; ;
esac
2018-05-12 00:08:06 +02:00
fi
2015-10-06 14:55:24 +02:00
2021-03-19 10:39:00 +01:00
test -n " $LVM_TEST_DIR " || LVM_TEST_DIR = ${ TMPDIR :- /tmp }
2021-03-20 00:28:13 +01:00
test " $LVM_TEST_DIR " = "/dev" && die "Setting LVM_TEST_DIR=/dev is not supported!"
2021-03-19 10:39:00 +01:00
TESTDIR = $( mkdtemp " $LVM_TEST_DIR " " $PREFIX .XXXXXXXXXX " ) || \
die " failed to create temporary directory in \" $LVM_TEST_DIR \" "
2015-04-29 13:37:13 +02:00
RUNNING_DMEVENTD = $( pgrep dmeventd || true )
2011-01-05 00:16:18 +00:00
2012-03-16 12:59:43 +00:00
export TESTOLDPWD TESTDIR COMMON_PREFIX PREFIX RUNNING_DMEVENTD
2017-07-10 13:33:55 +02:00
LVM_LOG_FILE_EPOCH = DEBUG
2017-10-26 13:58:43 +02:00
LVM_LOG_FILE_MAX_LINES = ${ LVM_LOG_FILE_MAX_LINES -1000000 }
2017-07-10 13:33:55 +02:00
LVM_EXPECTED_EXIT_STATUS = 1
export LVM_LOG_FILE_EPOCH LVM_LOG_FILE_MAX_LINES LVM_EXPECTED_EXIT_STATUS
2011-01-05 00:16:18 +00:00
2018-05-12 00:08:06 +02:00
if test -z " $SKIP_ROOT_DM_CHECK " ; then
# Teardown only with root
test -n " $BASH " && trap 'set +vx; STACKTRACE; set -vx' ERR
trap 'aux teardown' EXIT # don't forget to clean up
else
trap 'cd $TESTOLDPWD; rm -rf "${TESTDIR:?}"' EXIT
fi
2011-01-05 00:16:18 +00:00
2013-08-23 10:06:14 +02:00
cd " $TESTDIR "
2023-05-29 14:17:43 +02:00
mkdir lib tmp
2014-06-27 00:58:28 +02:00
# Setting up symlink from $i to $TESTDIR/lib
2023-07-13 21:25:15 +02:00
# library libdevmapper-event-lvm2.so.2.03 is needed with name
2017-07-12 13:51:16 +02:00
test -n " ${ abs_top_builddir +varset } " && \
2023-07-13 21:25:15 +02:00
find " $abs_top_builddir /daemons/dmeventd/plugins/ " -name '*.so*' \
2014-06-27 00:58:28 +02:00
-exec ln -s -t lib "{}" +
find " $TESTOLDPWD /lib " ! \( -name '*.sh' -o -name '*.[cdo]' \
-o -name '*~' \) -exec ln -s -t lib "{}" +
2023-07-13 21:25:15 +02:00
LD_LIBRARY_PATH = " $TESTDIR /lib: $LD_LIBRARY_PATH "
2013-08-23 10:06:14 +02:00
2014-06-05 12:09:02 +02:00
DM_DEFAULT_NAME_MANGLING_MODE = none
2012-03-16 12:59:43 +00:00
DM_DEV_DIR = " $TESTDIR /dev "
LVM_SYSTEM_DIR = " $TESTDIR /etc "
2023-05-29 14:17:43 +02:00
TMPDIR = " $TESTDIR /tmp "
2017-02-21 09:38:49 +01:00
# abort on the internal dm errors in the tests (allowing test user override)
DM_ABORT_ON_INTERNAL_ERRORS = ${ DM_ABORT_ON_INTERNAL_ERRORS :- 1 }
2018-03-15 10:41:08 +01:00
DM_DEBUG_WITH_LINE_NUMBERS = ${ DM_DEBUG_WITH_LINE_NUMBERS :- 1 }
2017-02-21 09:38:49 +01:00
export DM_DEFAULT_NAME_MANGLING_MODE DM_DEV_DIR LVM_SYSTEM_DIR DM_ABORT_ON_INTERNAL_ERRORS
2014-06-27 00:58:28 +02:00
mkdir " $LVM_SYSTEM_DIR " " $DM_DEV_DIR "
2023-06-20 21:56:28 +02:00
MACHINEID = $( uuidgen 2>/dev/null || echo "abcdefabcdefabcdefabcdefabcdefab" )
echo " ${ MACHINEID //-/ } " > " $LVM_SYSTEM_DIR /machine-id " # remove all '-'
2011-09-24 20:54:35 +00:00
if test -n " $LVM_TEST_DEVDIR " ; then
2015-05-04 10:15:56 +02:00
test -d " $LVM_TEST_DEVDIR " || die " Test device directory LVM_TEST_DEVDIR=\" $LVM_TEST_DEVDIR \" is not valid. "
2012-03-16 12:59:43 +00:00
DM_DEV_DIR = $LVM_TEST_DEVDIR
2018-05-12 00:08:06 +02:00
elif test -z " $SKIP_ROOT_DM_CHECK " ; then
2015-04-29 13:37:13 +02:00
mknod " $DM_DEV_DIR /testnull " c 1 3 || die "mknod failed"
2012-03-16 12:59:43 +00:00
echo >" $DM_DEV_DIR /testnull " || \
die " Filesystem does support devices in $DM_DEV_DIR (mounted with nodev?) "
2017-02-21 09:38:49 +01:00
# dmsetup makes here needed control entry if still missing
dmsetup version || \
die " Dmsetup in $DM_DEV_DIR can't report version? "
2011-09-24 20:54:35 +00:00
fi
2011-01-05 00:16:18 +00:00
2012-03-16 12:59:43 +00:00
echo " $TESTNAME " >TESTNAME
2017-09-11 14:33:07 +02:00
# Require 50M of free space in testdir
2020-09-18 14:25:50 +02:00
test " $( df -k -P . | awk '/\// {print $4}' ) " -gt $(( SKIP_WITH_LOW_SPACE * 1024 )) || \
skip " Testing requires more then ${ SKIP_WITH_LOW_SPACE } M of free space in directory $TESTDIR !\\n $( df -H | sed -e 's,^,## DF: ,' ) "
2017-09-11 14:33:07 +02:00
2014-03-04 16:24:44 +01:00
echo " Kernel is $( uname -a) "
2014-03-02 19:15:52 +01:00
# Report SELinux mode
2015-04-29 13:37:13 +02:00
echo " Selinux mode is $( getenforce 2>/dev/null || echo not installed) . "
2015-05-01 15:37:50 +02:00
free -m || true
2014-03-02 19:15:52 +01:00
2017-09-11 14:33:07 +02:00
df -h || true
2012-03-16 12:59:43 +00:00
# Set vars from utils now that we have TESTDIR/PREFIX/...
prepare_test_vars
2017-07-11 11:23:34 +02:00
# Set strict shell mode
# see: http://redsymbol.net/articles/unofficial-bash-strict-mode
test -n " $BASH " && set -euE -o pipefail
2011-01-05 00:16:18 +00:00
2015-04-15 14:31:28 +02:00
# Vars for harness
echo " @TESTDIR= $TESTDIR "
echo " @PREFIX= $PREFIX "
2024-04-08 21:16:33 +02:00
# Date of executed test
echo " ## DATE: $( date || true ) "
# Hostname IP address
2024-04-11 16:28:52 +02:00
echo " ## HOST: $( hostname -I 2>/dev/null || hostname 2>/dev/null || true ) "
2024-04-08 21:16:33 +02:00
2018-09-10 11:10:55 -05:00
if test -z " $SKIP_ROOT_DM_CHECK " ; then
2015-04-14 09:47:14 +02:00
aux lvmconf
fi
2014-03-02 19:15:52 +01:00
2015-05-09 00:59:18 +01:00
test -n " $LVM_TEST_LVMPOLLD " && {
export LVM_LVMPOLLD_SOCKET = " $TESTDIR /lvmpolld.socket "
export LVM_LVMPOLLD_PIDFILE = " $TESTDIR /lvmpolld.pid "
aux prepare_lvmpolld
}
2018-05-23 12:56:33 -05:00
export SHARED = ""
2015-03-05 14:00:44 -06:00
if test -n " $LVM_TEST_LVMLOCKD " ; then
if test -n " $LVM_TEST_LOCK_TYPE_SANLOCK " ; then
aux lvmconf 'local/host_id = 1'
fi
2016-02-23 13:58:22 -06:00
2015-03-05 14:00:44 -06:00
export SHARED = "--shared"
fi
2016-02-23 13:58:22 -06:00
# for check_lvmlockd_test, lvmlockd is restarted for each shell test.
# for check_lvmlockd_{sanlock,dlm}, lvmlockd is started once by
# aa-lvmlockd-{sanlock,dlm}-prepare.sh and left running for all shell tests.
if test -n " $LVM_TEST_LVMLOCKD_TEST " ; then
aux prepare_lvmlockd
fi
2015-04-13 16:30:17 +02:00
echo " <======== Processing test: \" $TESTNAME \" ========> "
2011-01-05 00:16:18 +00:00
set -vx