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