2014-04-22 22:16:18 +00:00
|
|
|
#!/bin/bash -x
|
|
|
|
|
|
|
|
# If a bundle file is present, call tox with the jenkins version of
|
|
|
|
# the test environment so it is used. Otherwise, use the normal
|
2014-12-16 23:11:27 +00:00
|
|
|
# (non-bundle) test environment. Also, run pbr freeze on the
|
2014-04-22 22:16:18 +00:00
|
|
|
# resulting environment at the end so that we have a record of exactly
|
|
|
|
# what packages we ended up testing.
|
|
|
|
#
|
|
|
|
# Usage: run-tox.sh VENV
|
|
|
|
#
|
|
|
|
# Where VENV is the name of the tox environment to run (specified in the
|
|
|
|
# project's tox.ini file).
|
|
|
|
|
|
|
|
venv=$1
|
|
|
|
|
2014-09-29 20:28:19 +00:00
|
|
|
if [[ -z "$venv" ]]; then
|
|
|
|
echo "Usage: $?"
|
|
|
|
echo
|
|
|
|
echo "VENV: The tox environment to run (eg 'python27')"
|
|
|
|
exit 1
|
2014-04-22 22:16:18 +00:00
|
|
|
fi
|
|
|
|
|
2015-03-04 20:44:57 +00:00
|
|
|
function freeze_venv {
|
|
|
|
[ -e $bin_path/pbr ] && freezecmd=pbr || freezecmd=pip
|
|
|
|
|
|
|
|
echo "Begin $freezecmd freeze output from test virtualenv:"
|
|
|
|
echo "======================================================================"
|
2016-04-24 15:39:22 +00:00
|
|
|
${bin_path}/${freezecmd} freeze | sort -f
|
2015-03-04 20:44:57 +00:00
|
|
|
echo "======================================================================"
|
|
|
|
}
|
|
|
|
|
|
|
|
function process_testr_artifacts {
|
|
|
|
if [ ! -d ".testrepository" ] ; then
|
|
|
|
return
|
|
|
|
fi
|
2014-11-26 17:54:07 +00:00
|
|
|
|
|
|
|
if [ -f ".testrepository/0.2" ] ; then
|
2015-05-29 15:59:01 +00:00
|
|
|
cp .testrepository/0.2 ./testrepository.subunit
|
2014-11-26 17:54:07 +00:00
|
|
|
elif [ -f ".testrepository/0" ] ; then
|
2015-05-29 15:59:01 +00:00
|
|
|
$bin_path/testr last --subunit > ./testrepository.subunit
|
2014-11-26 17:54:07 +00:00
|
|
|
fi
|
2015-08-14 00:33:45 +00:00
|
|
|
/usr/os-testr-env/bin/subunit2html ./testrepository.subunit testr_results.html
|
2015-05-29 15:59:01 +00:00
|
|
|
SUBUNIT_SIZE=$(du -k ./testrepository.subunit | awk '{print $1}')
|
|
|
|
gzip -9 ./testrepository.subunit
|
2014-11-26 17:54:07 +00:00
|
|
|
gzip -9 ./testr_results.html
|
|
|
|
|
|
|
|
if [[ "$SUBUNIT_SIZE" -gt 50000 ]]; then
|
|
|
|
echo
|
2015-05-29 15:59:01 +00:00
|
|
|
echo "testrepository.subunit was > 50 MB of uncompressed data!!!"
|
2014-11-26 17:54:07 +00:00
|
|
|
echo "Something is causing tests for this project to log significant amounts"
|
|
|
|
echo "of data. This may be writers to python logging, stdout, or stderr."
|
|
|
|
echo "Failing this test as a result"
|
|
|
|
echo
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2015-03-04 20:44:57 +00:00
|
|
|
rancount=$($bin_path/testr last | sed -ne 's/Ran \([0-9]\+\).*tests in.*/\1/p')
|
2014-11-26 17:54:07 +00:00
|
|
|
if [ -z "$rancount" ] || [ "$rancount" -eq "0" ] ; then
|
|
|
|
echo
|
|
|
|
echo "Zero tests were run. At least one test should have been run."
|
|
|
|
echo "Failing this test as a result"
|
|
|
|
echo
|
|
|
|
exit 1
|
|
|
|
fi
|
2015-03-04 20:44:57 +00:00
|
|
|
}
|
2014-11-26 17:54:07 +00:00
|
|
|
|
2015-03-04 20:44:57 +00:00
|
|
|
function check_sudo_usage {
|
|
|
|
sudo $script_path/jenkins-sudo-grep.sh post
|
|
|
|
sudoresult=$?
|
2014-04-22 22:16:18 +00:00
|
|
|
|
2015-03-04 20:44:57 +00:00
|
|
|
if [ $sudoresult -ne "0" ]; then
|
|
|
|
echo
|
|
|
|
echo "This test has failed because it attempted to execute commands"
|
|
|
|
echo "with sudo. See above for the exact commands used."
|
|
|
|
echo
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
}
|
2014-04-22 22:16:18 +00:00
|
|
|
|
2015-03-04 20:44:57 +00:00
|
|
|
function check_oom {
|
|
|
|
$script_path/jenkins-oom-grep.sh post
|
|
|
|
oomresult=$?
|
2014-04-22 22:16:18 +00:00
|
|
|
|
2015-03-04 20:44:57 +00:00
|
|
|
if [ $oomresult -ne "0" ]; then
|
2014-11-26 17:54:07 +00:00
|
|
|
echo
|
2015-03-04 20:44:57 +00:00
|
|
|
echo "This test has failed because it attempted to exceed configured"
|
|
|
|
echo "memory limits and was killed prior to completion. See above"
|
|
|
|
echo "for related kernel messages."
|
2014-11-26 17:54:07 +00:00
|
|
|
echo
|
|
|
|
exit 1
|
|
|
|
fi
|
2015-03-04 20:44:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function check_nose_html {
|
|
|
|
htmlreport=$(find . -name $NOSE_HTML_OUT_FILE)
|
|
|
|
if [ -f "$htmlreport" ]; then
|
|
|
|
passcount=$(grep -c 'tr class=.passClass' $htmlreport)
|
|
|
|
if [ $passcount -eq "0" ]; then
|
|
|
|
echo
|
|
|
|
echo "Zero tests passed, which probably means there was an error"
|
|
|
|
echo "parsing one of the python files, or that some other failure"
|
|
|
|
echo "during test setup prevented a sane run."
|
|
|
|
echo
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2015-05-28 16:07:09 +00:00
|
|
|
script_path=/usr/local/jenkins/slave_scripts
|
|
|
|
bin_path=.tox/$venv/bin
|
2015-03-04 20:44:57 +00:00
|
|
|
|
|
|
|
export PYTHON=$bin_path/python
|
|
|
|
export NOSE_WITH_XUNIT=1
|
|
|
|
export NOSE_WITH_HTML_OUTPUT=1
|
|
|
|
export NOSE_HTML_OUT_FILE='nose_results.html'
|
2015-06-04 05:33:48 +00:00
|
|
|
export TMPDIR=$(/bin/mktemp -d)
|
2015-07-29 06:18:35 +00:00
|
|
|
export UPPER_CONSTRAINTS_FILE=$(pwd)/upper-constraints.txt
|
2015-03-04 20:44:57 +00:00
|
|
|
trap "rm -rf $TMPDIR" EXIT
|
|
|
|
|
|
|
|
cat /etc/image-hostname.txt
|
|
|
|
|
|
|
|
$script_path/jenkins-oom-grep.sh pre
|
|
|
|
|
|
|
|
sudo $script_path/jenkins-sudo-grep.sh pre
|
|
|
|
|
|
|
|
tox -v -e$venv
|
|
|
|
result=$?
|
|
|
|
|
|
|
|
freeze_venv
|
|
|
|
process_testr_artifacts
|
|
|
|
check_sudo_usage
|
|
|
|
check_oom
|
|
|
|
check_nose_html
|
2014-11-26 17:54:07 +00:00
|
|
|
|
2015-07-17 15:44:04 +00:00
|
|
|
# Rename tox' .log files to .log.txt so that Apache serves them as
|
|
|
|
# text/plain files since it can handle .txt special - and .log is
|
|
|
|
# unknown and therefore served as binary.
|
2016-02-08 16:52:58 +00:00
|
|
|
find .tox -type f -name "*.log" -exec mv {} {}.txt \;
|
2015-07-17 15:44:04 +00:00
|
|
|
|
2014-04-22 22:16:18 +00:00
|
|
|
exit $result
|