Change-Id: I49d8f1b9668029d2b8bd35b366b673d7a08a057f BUG: 1304301 Signed-off-by: Krutika Dhananjay <kdhananj@redhat.com> Reviewed-on: http://review.gluster.org/13344 Smoke: Gluster Build System <jenkins@build.gluster.com> NetBSD-regression: NetBSD Build System <jenkins@build.gluster.org> CentOS-regression: Gluster Build System <jenkins@build.gluster.com> Reviewed-by: Pranith Kumar Karampuri <pkarampu@redhat.com>
289 lines
8.4 KiB
Bash
Executable File
289 lines
8.4 KiB
Bash
Executable File
#!/bin/bash
|
|
# Copyright (c) 2013-2014 Red Hat, Inc. <http://www.redhat.com>
|
|
#
|
|
|
|
export TZ=UTC
|
|
force="no"
|
|
retry="no"
|
|
tests=""
|
|
exit_on_failure="yes"
|
|
|
|
function check_dependencies()
|
|
{
|
|
## Check all dependencies are present
|
|
MISSING=""
|
|
|
|
# Check for dbench
|
|
env dbench --usage > /dev/null 2>&1
|
|
if [ $? -ne 0 ]; then
|
|
MISSING="$MISSING dbench"
|
|
fi
|
|
|
|
# Check for git
|
|
env git --version > /dev/null 2>&1
|
|
if [ $? -ne 0 ]; then
|
|
MISSING="$MISSING git"
|
|
fi
|
|
|
|
# Check for nfs-utils (Linux-only: built-in NetBSD with different name)
|
|
if [ "x`uname -s`" = "xLinux" ] ; then
|
|
env mount.nfs -V > /dev/null 2>&1
|
|
if [ $? -ne 0 ]; then
|
|
MISSING="$MISSING nfs-utils"
|
|
fi
|
|
fi
|
|
|
|
# Check for the Perl Test Harness
|
|
env prove --version > /dev/null 2>&1
|
|
if [ $? -ne 0 ]; then
|
|
MISSING="$MISSING perl-Test-Harness"
|
|
fi
|
|
|
|
which json_verify > /dev/null
|
|
if [ $? -ne 0 ]; then
|
|
MISSING="$MISSING json_verify"
|
|
fi
|
|
|
|
# Check for XFS programs (Linux Only: NetBSD does without)
|
|
if [ "x`uname -s`" = "xLinux" ] ; then
|
|
env mkfs.xfs -V > /dev/null 2>&1
|
|
if [ $? -ne 0 ]; then
|
|
MISSING="$MISSING xfsprogs"
|
|
fi
|
|
fi
|
|
|
|
# Check for attr
|
|
env getfattr --version > /dev/null 2>&1
|
|
if [ $? -ne 0 ]; then
|
|
MISSING="$MISSING attr"
|
|
fi
|
|
|
|
# Check for pidof
|
|
pidof pidof > /dev/null 2>&1
|
|
if [ $? -ne 0 ]; then
|
|
MISSING="$MISSING pidof"
|
|
fi
|
|
|
|
# check for psutil python package
|
|
test `uname -s` == "Darwin" || test `uname -s` == "FreeBSD" && {
|
|
pip show psutil | grep -q psutil >/dev/null 2>&1
|
|
if [ $? -ne 0 ]; then
|
|
MISSING="$MISSING psutil"
|
|
fi
|
|
}
|
|
|
|
## If dependencies are missing, warn the user and abort
|
|
if [ "x$MISSING" != "x" ]; then
|
|
test "x${force}" != "xyes" && echo "Aborting."
|
|
echo
|
|
echo "The following required tools are missing:"
|
|
echo
|
|
for pkg in $MISSING; do
|
|
echo " * $pkg"
|
|
done
|
|
echo
|
|
test "x${force}" = "xyes" && return
|
|
echo "Please install them and try again."
|
|
echo
|
|
exit 2
|
|
fi
|
|
}
|
|
|
|
function check_location()
|
|
{
|
|
regression_testsdir=$(dirname $0);
|
|
|
|
if [ ! -f ${regression_testsdir}/tests/include.rc ]; then
|
|
echo "Aborting."
|
|
echo
|
|
echo "The tests/ subdirectory seems to be missing."
|
|
echo
|
|
echo "Please correct the problem and try again."
|
|
echo
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
function check_user()
|
|
{
|
|
# If we're not running as root, warn the user and abort
|
|
MYUID=`/usr/bin/id -u`
|
|
if [ 0${MYUID} -ne 0 ]; then
|
|
echo "Aborting."
|
|
echo
|
|
echo "The GlusterFS Test Framework must be run as root."
|
|
echo
|
|
echo "Please change to the root user and try again."
|
|
echo
|
|
exit 3
|
|
fi
|
|
}
|
|
|
|
function match()
|
|
{
|
|
# Patterns considered valid:
|
|
# 0. Empty means everything
|
|
# "" matches ** i.e all
|
|
# 1. full or partial file/directory names
|
|
# basic matches tests/basic
|
|
# basic/afr matches tests/basic/afr
|
|
# 2. globs
|
|
# basic/* matches all files and directories in basic
|
|
# basic/*/ matches subdirectories in basic (afr|ec)
|
|
# 3. numbered bug matching
|
|
# 884455 matches bugs/bug-884455.t
|
|
# 859927 matches bugs/859927, bugs/bug-859927.t
|
|
# 1015990 matches /bugs/bug-1015990-rep.t, bug-1015990.t
|
|
# ...lots of other cases accepted as well, since globbing is tricky.
|
|
local t=$1
|
|
shift
|
|
local a
|
|
local match=1
|
|
if [ -z "$@" ]; then
|
|
match=0
|
|
return $match
|
|
fi
|
|
for a in $@ ; do
|
|
case "$t" in
|
|
*$a*)
|
|
match=0
|
|
;;
|
|
esac
|
|
done
|
|
return $match
|
|
}
|
|
|
|
# If you're submitting a fix related to one of these tests and want its result
|
|
# to be considered, you'll need to remove it from the list as part of your
|
|
# patch.
|
|
function is_bad_test ()
|
|
{
|
|
local name=$1
|
|
for bt in ./tests/basic/quota-anon-fd-nfs.t \
|
|
./tests/bugs/quota/bug-1235182.t \
|
|
./tests/basic/quota-nfs.t \
|
|
./tests/basic/tier/tier_lookup_heal.t \
|
|
./tests/basic/tier/bug-1214222-directories_missing_after_attach_tier.t \
|
|
./tests/basic/tier/fops-during-migration.t \
|
|
./tests/basic/tier/record-metadata-heat.t \
|
|
./tests/basic/tier/tier-snapshot.t \
|
|
./tests/bugs/snapshot/bug-1109889.t \
|
|
./tests/bugs/distribute/bug-1066798.t \
|
|
./tests/bugs/glusterd/bug-1238706-daemons-stop-on-peer-cleanup.t \
|
|
./tests/geo-rep/georep-basic-dr-rsync.t \
|
|
./tests/geo-rep/georep-basic-dr-tarssh.t \
|
|
./tests/bugs/fuse/bug-924726.t \
|
|
./tests/basic/afr/split-brain-healing.t \
|
|
./tests/basic/afr/replace-brick-self-heal.t \
|
|
./tests/bugs/snapshot/bug-1140162-file-snapshot-features-encrypt-opts-validation.t \
|
|
./tests/bugs/tier/bug-1286974.t \
|
|
./tests/features/weighted-rebalance.t \
|
|
./tests/performance/open-behind.t \
|
|
./tests/basic/afr/self-heald.t \
|
|
; do
|
|
[ x"$name" = x"$bt" ] && return 0 # bash: zero means true/success
|
|
done
|
|
return 1 # bash: non-zero means false/failure
|
|
}
|
|
|
|
function run_tests()
|
|
{
|
|
RES=0
|
|
FAILED=''
|
|
GENERATED_CORE=''
|
|
|
|
for t in $(find ${regression_testsdir}/tests -name '*.t' \
|
|
| LC_COLLATE=C sort) ; do
|
|
old_cores=$(ls /core.* 2> /dev/null | wc -l)
|
|
if match $t "$@" ; then
|
|
echo
|
|
echo "=================================================="
|
|
if is_bad_test $t; then
|
|
echo "Skipping bad test file $t"
|
|
echo "=================================================="
|
|
echo
|
|
continue
|
|
fi
|
|
echo "Running tests in file $t"
|
|
prove -mf --timer $t
|
|
TMP_RES=$?
|
|
if [ ${TMP_RES} -ne 0 ] && [ "x${retry}" = "xyes" ] ; then
|
|
echo "$t: bad status $TMP_RES"
|
|
echo ""
|
|
echo " *********************************"
|
|
echo " * REGRESSION FAILED *"
|
|
echo " * Retrying failed tests in case *"
|
|
echo " * we got some spurous failures *"
|
|
echo " *********************************"
|
|
echo ""
|
|
prove -mf --timer $t
|
|
TMP_RES=$?
|
|
fi
|
|
if [ ${TMP_RES} -ne 0 ] ; then
|
|
RES=${TMP_RES}
|
|
FAILED="${FAILED}${t} "
|
|
fi
|
|
new_cores=$(ls /core.* 2> /dev/null | wc -l)
|
|
if [ x"$new_cores" != x"$old_cores" ]; then
|
|
core_diff=$((new_cores-old_cores))
|
|
echo "$t: $core_diff new core files"
|
|
RES=1
|
|
GENERATED_CORE="${GENERATED_CORE}${t} "
|
|
fi
|
|
echo "End of test $t"
|
|
echo "=================================================="
|
|
echo
|
|
if [ $RES -ne 0 ] && [ x"$exit_on_failure" = "xyes" ] ; then
|
|
break;
|
|
fi
|
|
fi
|
|
done
|
|
echo
|
|
echo "Run complete"
|
|
if [ ${RES} -ne 0 ] ; then
|
|
FAILED=$( echo ${FAILED} | tr ' ' '\n' | sort -u )
|
|
FAILED_COUNT=$( echo -n "${FAILED}" | grep -c '^' )
|
|
echo -e "$FAILED_COUNT test(s) failed \n${FAILED}"
|
|
GENERATED_CORE=$( echo ${GENERATED_CORE} | tr ' ' '\n' | sort -u )
|
|
GENERATED_CORE_COUNT=$( echo -n "${GENERATED_CORE}" | grep -c '^' )
|
|
echo -e "$GENERATED_CORE_COUNT test(s) generated core \n${GENERATED_CORE}"
|
|
fi
|
|
echo "Result is $RES"
|
|
return ${RES}
|
|
}
|
|
|
|
function parse_args () {
|
|
args=`getopt frc "$@"`
|
|
set -- $args
|
|
while [ $# -gt 0 ]; do
|
|
case "$1" in
|
|
-f) force="yes" ;;
|
|
-r) retry="yes" ;;
|
|
-c) exit_on_failure="no" ;;
|
|
--) shift; break;;
|
|
esac
|
|
shift
|
|
done
|
|
tests="$@"
|
|
}
|
|
|
|
|
|
echo
|
|
echo ... GlusterFS Test Framework ...
|
|
echo
|
|
|
|
# Get user options
|
|
parse_args "$@"
|
|
|
|
# Make sure we're running as the root user
|
|
check_user
|
|
|
|
# Make sure the needed programs are available
|
|
check_dependencies
|
|
|
|
# Check we're running from the right location
|
|
check_location
|
|
|
|
# Run the tests
|
|
run_tests "$tests"
|