2013-06-10 11:28:47 +02:00
#!/usr/bin/env bash
2012-03-20 10:51:57 +00:00
# Copyright (C) 2011-2012 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,
# Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
# 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
2011-01-05 00:16:18 +00:00
unset CDPATH
# grab some common utilities
. lib/utils
2012-03-16 12:59:43 +00:00
TESTOLDPWD = $( pwd )
2011-06-30 00:57:29 +00:00
COMMON_PREFIX = "LVMTEST"
PREFIX = " ${ COMMON_PREFIX } $$ "
2011-01-05 00:16:18 +00:00
2015-02-12 10:33:48 +01:00
if test -z " $LVM_TEST_DIR " ; then LVM_TEST_DIR = $TMPDIR ; fi
2014-06-27 23:16:49 +02:00
TESTDIR = $( mkdtemp " ${ LVM_TEST_DIR :- /tmp } " " $PREFIX .XXXXXXXXXX " ) || \
2012-03-20 10:51:57 +00:00
die " failed to create temporary directory in ${ LVM_TEST_DIR :- $TESTOLDPWD } "
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
2015-04-20 10:05:27 +02:00
export LVM_LOG_FILE_EPOCH = DEBUG
2015-04-20 19:16:33 +02:00
export LVM_EXPECTED_EXIT_STATUS = 1
2011-01-05 00:16:18 +00:00
2012-03-16 12:59:43 +00:00
test -n " $BASH " && trap 'set +vx; STACKTRACE; set -vx' ERR
2011-01-05 00:16:18 +00:00
trap 'aux teardown' EXIT # don't forget to clean up
2013-08-23 10:06:14 +02:00
cd " $TESTDIR "
2014-06-27 00:58:28 +02:00
mkdir lib
# Setting up symlink from $i to $TESTDIR/lib
test -n " $abs_top_builddir " && \
find " $abs_top_builddir /daemons/dmeventd/plugins/ " -name '*.so' \
-exec ln -s -t lib "{}" +
find " $TESTOLDPWD /lib " ! \( -name '*.sh' -o -name '*.[cdo]' \
-o -name '*~' \) -exec ln -s -t lib "{}" +
2013-08-23 10:06:14 +02:00
if test -n " $LVM_TEST_FLAVOUR " ; then
2014-06-27 00:58:28 +02:00
. lib/flavour-$LVM_TEST_FLAVOUR
2013-08-23 10:06:14 +02:00
fi
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 "
2014-06-27 00:58:28 +02:00
mkdir " $LVM_SYSTEM_DIR " " $DM_DEV_DIR "
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
2011-09-24 20:54:35 +00:00
else
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?) "
mkdir " $DM_DEV_DIR /mapper "
2011-09-24 20:54:35 +00:00
fi
2011-01-05 00:16:18 +00:00
2013-07-25 14:32:09 +02: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 }
2014-06-05 12:09:02 +02:00
export DM_DEFAULT_NAME_MANGLING_MODE DM_DEV_DIR LVM_SYSTEM_DIR DM_ABORT_ON_INTERNAL_ERRORS
2011-01-05 00:16:18 +00:00
2012-03-16 12:59:43 +00:00
echo " $TESTNAME " >TESTNAME
2011-01-05 00:16:18 +00: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
2012-03-16 12:59:43 +00:00
# Set vars from utils now that we have TESTDIR/PREFIX/...
prepare_test_vars
test -n " $BASH " && set -eE -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 "
2015-04-14 09:47:14 +02:00
if test -n " $LVM_TEST_LVMETAD " ; then
2012-03-16 12:59:43 +00:00
export LVM_LVMETAD_SOCKET = " $TESTDIR /lvmetad.socket "
2013-11-29 20:56:29 +00:00
export LVM_LVMETAD_PIDFILE = " $TESTDIR /lvmetad.pid "
2014-01-24 15:59:38 +01:00
aux prepare_lvmetad
2015-04-14 09:47:14 +02:00
else
# lvmetad prepares its own lvmconf
aux lvmconf
aux prepare_clvmd
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
}
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
export SHARED = "--shared"
fi
2015-04-13 16:30:17 +02:00
echo " <======== Processing test: \" $TESTNAME \" ========> "
2011-01-05 00:16:18 +00:00
set -vx