tests: Preserve tarball of tests when they timeout

When tests timeout, the timeout command sends TERM
signal to the command being executed. In the case of run-tests.sh
it invokes prove, which further invokes perl and finally the test
is run using bash. The TERM signal does not seem to be reachnig
the end bash that is actually executing the tests, and hence
when any test is terminated due to a timeout, the cleanup routine
in include.rc does not get a chance to run and preserve the
tarball.

Further, cleanup invokes tarball generation, but is invoked at
the beginning and end of every test, and at times in beteween
as well. This caused way too many tarballs in case we decide to
preserve the same whenever generated by cleanup.

This patch hence moves the tarball generation to run-tests.sh
instead, and further stores them named <test>-iteration-<n>.tar
and also prints tarball name generated and stored per iteration.

This should help relate failed runs to the tarball iteration #
and to look at relevant logs.

Further the patch also provides a -p option to run-tests.sh for
unit testing purposes, where running a test in a loop without the
option will generate as many tarballs, and using the option will
reduce this to preserving the last tarball, saving space in
smaller unit test setups.

Fixes: bz#1614062
Change-Id: I0aee76c89df0691cf4d0c1fcd4c04dffe0d7c896
Signed-off-by: ShyamsundarR <srangana@redhat.com>
This commit is contained in:
ShyamsundarR 2018-08-14 14:00:41 -04:00 committed by Atin Mukherjee
parent 43f037f6b1
commit d34455a2d2
2 changed files with 58 additions and 34 deletions

View File

@ -14,6 +14,13 @@ result_output="/tmp/gluster_regression.txt"
section_separator="========================================"
run_timeout=200
kill_after_time=5
# Option below preserves log tarballs for each run of a test separately
# named: <test>-iteration-<n>.tar
# If set to any other value, then log tarball is just named after the test and
# overwritten in each iteration (saves space)
# named: <test>.tar
# Use option -p to override default behavior
skip_preserve_logs="yes"
OSTYPE=$(uname -s)
@ -24,31 +31,67 @@ OSTYPE=$(uname -s)
# $3 extension: Extension string that would be appended to the generated
# filename
# Out:
# string of next available filename with appended "-<n>" if applicable
# string of next available filename with appended "-<n>"
# Example:
# Interested routines that want to create a file name, say foo.txt at
# Interested routines that want to create a file name, say foo-<n>.txt at
# location /var/log/gluster would pass in "/var/log/gluster" "foo" "txt"
# and be returned next available foo.txt filename to create. If foo.txt
# is available then foo is returned, else foo-<n> (where n is the next
# integer) is returned for use"
# and be returned next available foo-<n> filename to create.
# Notes:
# Function will not accept empty extension, and will return the same name
# over and over (which can be fixed when there is a use-case for it)
# over and over (which can be fixed when there is a need for it)
function get_next_filename()
{
local basepath=$1
local filename=$2
local extension=$3
local next=2
local tfilename=${filename}
local next=1
local tfilename="${filename}-${next}"
while [ -e "${basepath}/${tfilename}.${extension}" ]; do
tfilename="${filename}-${next}"
next=$((next+1))
tfilename="${filename}-${next}"
done
echo "$tfilename"
}
# Tar the gluster logs and generate a tarball named after the first parameter
# passed in to the function. Ideally the test name is passed to this function
# to generate the required tarball.
# Tarball name is further controlled by the variable skip_preserve_logs
function tar_logs()
{
t=$1
logdir=$(gluster --print-logdir)
basetarname=$(basename "$t" .t)
if [ -n "$logdir" ]
then
if [[ $skip_preserve_logs == "yes" ]]; then
savetarname=$(get_next_filename "${logdir}" \
"${basetarname}-iteration" "tar" \
| tail -1)
else
savetarname="$basetarname"
fi
# Can't use --exclude here because NetBSD doesn't have it.
# However, both it and Linux have -X to take patterns from
# a file, so use that.
(echo '*.tar'; echo .notar) > "${logdir}"/.notar \
&& \
tar -cf "${logdir}"/"${savetarname}".tar -X "${logdir}"/.notar \
"${logdir}"/* 2> /dev/null \
&& \
find "$logdir"/* -maxdepth 0 -name '*.tar' -prune \
-o -exec rm -rf '{}' ';'
echo "Logs preserved in tarball $savetarname.tar"
else
echo "Logs not preserved, as logdir is not set"
fi
}
function check_dependencies()
{
## Check all dependencies are present
@ -338,6 +381,8 @@ function run_tests()
fi
TMP_RES=$?
ELAPSEDTIMEMAP[$t]=`expr $(date +%s) - $starttime`
tar_logs "$t"
# timeout always return 124 if it is actually a timeout.
if ((${TMP_RES} == 124)); then
echo "${t} timed out after ${cmd_timeout} seconds"
@ -352,12 +397,6 @@ function run_tests()
echo " * we got some spurious failures *"
echo " *********************************"
echo ""
# backup old tar ball with time stamp
# TODO: Using gluster CLI here is possibly not the best thing!
logdir=$(gluster --print-logdir)
basetarname=$(basename "$t" .t)
savetarname=$(get_next_filename "${logdir}" "${basetarname}-$(date +%H:%M:%S)" "tar" | tail -1)
mv "$logdir"/"$basetarname".tar "$logdir"/"$savetarname".tar
if [ ${timeout_cmd_exists} == "yes" ]; then
timeout -k ${kill_after_time} ${cmd_timeout} prove -vmfe '/bin/bash' ${t}
@ -365,6 +404,8 @@ function run_tests()
prove -vmfe '/bin/bash' ${t}
fi
TMP_RES=$?
tar_logs "$t"
if ((${TMP_RES} == 124)); then
echo "${t} timed out after ${cmd_timeout} seconds"
fi
@ -452,7 +493,7 @@ function run_head_tests()
}
function parse_args () {
args=`getopt frcbkhHo:t: "$@"`
args=`getopt frcbkphHo:t: "$@"`
set -- $args
while [ $# -gt 0 ]; do
case "$1" in
@ -463,6 +504,7 @@ function parse_args () {
-c) exit_on_failure="no" ;;
-b) skip_bad_tests="no" ;;
-k) skip_known_bugs="no" ;;
-p) skip_preserve_logs="no" ;;
-o) result_output="$2"; shift;;
-t) run_timeout="$2"; shift;;
--) shift; break;;

View File

@ -680,24 +680,6 @@ function cleanup()
return 1;
fi >&2
# tar logs at the start and end of every test
if [ -n "$LOGDIR" -a -z "$STOP_WASTING_SPACE" ]
then
tarname=$(basename $0 .t)
# Can't use --exclude here because NetBSD doesn't have it.
# However, both it and Linux have -X to take patterns from
# a file, so use that.
(echo '*.tar'; echo .notar) > ${LOGDIR}/.notar \
&& \
tar -cf ${LOGDIR}/${tarname}.tar -X ${LOGDIR}/.notar \
${LOGDIR}/* 2> /dev/null \
&& \
find $LOGDIR/* -maxdepth 0 -name '*.tar' -prune \
-o -exec rm -rf '{}' ';'
else
echo "LOGDIR is not set"
fi
mkdir -p $WORKDIRS
# This is usually the last thing a test script calls, so our return
# value becomes their exit value. While it's not great for the mkdir