2010-08-11 17:40:28 -04:00
|
|
|
#!/bin/bash
|
|
|
|
|
2011-08-28 16:19:55 +05:30
|
|
|
set -eu
|
|
|
|
|
2010-08-11 17:40:28 -04:00
|
|
|
function usage {
|
|
|
|
echo "Usage: $0 [OPTION]..."
|
|
|
|
echo "Run Nova's test suite(s)"
|
|
|
|
echo ""
|
|
|
|
echo " -V, --virtual-env Always use virtualenv. Install automatically if not present"
|
|
|
|
echo " -N, --no-virtual-env Don't use virtualenv. Run tests in local environment"
|
2011-10-30 09:00:59 -04:00
|
|
|
echo " -s, --no-site-packages Isolate the virtualenv from the global Python environment"
|
2011-06-29 07:47:51 -07:00
|
|
|
echo " -r, --recreate-db Recreate the test database (deprecated, as this is now the default)."
|
|
|
|
echo " -n, --no-recreate-db Don't recreate the test database."
|
2010-09-28 14:48:03 -04:00
|
|
|
echo " -f, --force Force a clean re-build of the virtual environment. Useful when dependencies have been added."
|
2012-03-14 07:35:05 +04:00
|
|
|
echo " -p, --pep8 Just run PEP8 and HACKING compliance check"
|
|
|
|
echo " -P, --no-pep8 Don't run static code checks"
|
2011-07-19 10:52:38 -04:00
|
|
|
echo " -c, --coverage Generate coverage report"
|
2010-08-11 17:40:28 -04:00
|
|
|
echo " -h, --help Print this usage message"
|
2011-06-15 01:21:11 +00:00
|
|
|
echo " --hide-elapsed Don't print the elapsed time for each test along with slow test list"
|
2010-08-11 17:40:28 -04:00
|
|
|
echo ""
|
|
|
|
echo "Note: with no options specified, the script will try to run the tests in a virtual environment,"
|
|
|
|
echo " If no virtualenv is found, the script will ask if you would like to create one. If you "
|
|
|
|
echo " prefer to run tests NOT in a virtual environment, simply pass the -N option."
|
|
|
|
exit
|
|
|
|
}
|
|
|
|
|
|
|
|
function process_option {
|
2010-09-28 14:48:03 -04:00
|
|
|
case "$1" in
|
2010-08-13 10:14:34 -04:00
|
|
|
-h|--help) usage;;
|
2011-08-28 16:19:55 +05:30
|
|
|
-V|--virtual-env) always_venv=1; never_venv=0;;
|
|
|
|
-N|--no-virtual-env) always_venv=0; never_venv=1;;
|
2011-10-30 09:00:59 -04:00
|
|
|
-s|--no-site-packages) no_site_packages=1;;
|
2011-08-28 16:19:55 +05:30
|
|
|
-r|--recreate-db) recreate_db=1;;
|
|
|
|
-n|--no-recreate-db) recreate_db=0;;
|
|
|
|
-f|--force) force=1;;
|
|
|
|
-p|--pep8) just_pep8=1;;
|
2011-09-22 18:22:42 -04:00
|
|
|
-P|--no-pep8) no_pep8=1;;
|
2011-08-28 16:19:55 +05:30
|
|
|
-c|--coverage) coverage=1;;
|
2012-10-30 16:30:02 -07:00
|
|
|
-*) testropts="$testropts $1";;
|
|
|
|
*) testrargs="$testrargs $1"
|
2010-08-11 17:40:28 -04:00
|
|
|
esac
|
|
|
|
}
|
2010-07-27 21:35:55 -07:00
|
|
|
|
2011-12-08 15:14:48 -08:00
|
|
|
venv=.venv
|
2010-07-27 21:35:55 -07:00
|
|
|
with_venv=tools/with_venv.sh
|
2010-08-11 17:40:28 -04:00
|
|
|
always_venv=0
|
|
|
|
never_venv=0
|
2010-09-28 14:48:03 -04:00
|
|
|
force=0
|
2011-10-30 09:00:59 -04:00
|
|
|
no_site_packages=0
|
|
|
|
installvenvopts=
|
2012-10-30 16:30:02 -07:00
|
|
|
testrargs=
|
|
|
|
testropts=
|
2011-01-19 10:50:54 +01:00
|
|
|
wrapper=""
|
2011-04-06 18:17:43 -04:00
|
|
|
just_pep8=0
|
2011-09-22 18:22:42 -04:00
|
|
|
no_pep8=0
|
2011-07-19 10:52:38 -04:00
|
|
|
coverage=0
|
2011-06-29 07:47:51 -07:00
|
|
|
recreate_db=1
|
2010-12-28 01:40:24 -08:00
|
|
|
|
2012-10-30 16:30:02 -07:00
|
|
|
LANG=en_US.UTF-8
|
|
|
|
LANGUAGE=en_US:en
|
|
|
|
LC_ALL=C
|
2012-08-17 16:14:51 +08:00
|
|
|
|
2010-09-28 14:48:03 -04:00
|
|
|
for arg in "$@"; do
|
|
|
|
process_option $arg
|
|
|
|
done
|
2010-08-11 17:40:28 -04:00
|
|
|
|
2011-10-30 09:00:59 -04:00
|
|
|
if [ $no_site_packages -eq 1 ]; then
|
|
|
|
installvenvopts="--no-site-packages"
|
|
|
|
fi
|
|
|
|
|
2012-10-30 16:30:02 -07:00
|
|
|
function init_testr {
|
|
|
|
if [ ! -d .testrepository ]; then
|
|
|
|
${wrapper} testr init
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2011-01-19 10:50:54 +01:00
|
|
|
function run_tests {
|
2012-02-13 17:58:52 -08:00
|
|
|
# Cleanup *pyc
|
|
|
|
${wrapper} find . -type f -name "*.pyc" -delete
|
2012-11-29 11:56:49 -05:00
|
|
|
|
2012-10-30 16:30:02 -07:00
|
|
|
if [ $coverage -eq 1 ]; then
|
|
|
|
# Do not test test_coverage_ext when gathering coverage.
|
2012-12-18 11:33:01 -05:00
|
|
|
if [ "x$testrargs" = "x" ]; then
|
|
|
|
testrargs = "^(?!.*test_coverage_ext).*$"
|
|
|
|
fi
|
2012-10-30 16:30:02 -07:00
|
|
|
export PYTHON="${wrapper} coverage run --source nova --parallel-mode"
|
2011-02-23 08:46:11 -08:00
|
|
|
fi
|
2012-10-30 16:30:02 -07:00
|
|
|
# Just run the test suites in current environment
|
|
|
|
set +e
|
2012-12-18 11:33:01 -05:00
|
|
|
TESTRTESTS="$TESTRTESTS $testrargs"
|
2012-10-30 16:30:02 -07:00
|
|
|
echo "Running \`${wrapper} $TESTRTESTS\`"
|
|
|
|
${wrapper} $TESTRTESTS
|
|
|
|
RESULT=$?
|
|
|
|
set -e
|
|
|
|
|
|
|
|
copy_subunit_log
|
|
|
|
|
2011-02-23 08:46:11 -08:00
|
|
|
return $RESULT
|
2011-01-19 10:50:54 +01:00
|
|
|
}
|
2010-07-27 21:35:55 -07:00
|
|
|
|
2012-10-30 16:30:02 -07:00
|
|
|
function copy_subunit_log {
|
|
|
|
LOGNAME=`cat .testrepository/next-stream`
|
|
|
|
LOGNAME=$(($LOGNAME - 1))
|
|
|
|
LOGNAME=".testrepository/${LOGNAME}"
|
|
|
|
cp $LOGNAME subunit.log
|
|
|
|
}
|
2012-02-09 08:00:09 +00:00
|
|
|
|
2011-04-06 18:17:43 -04:00
|
|
|
function run_pep8 {
|
2012-03-14 07:35:05 +04:00
|
|
|
echo "Running PEP8 and HACKING compliance check..."
|
2012-06-27 22:52:41 +00:00
|
|
|
|
|
|
|
# Files of interest
|
|
|
|
# NOTE(lzyeval): Avoid selecting nova-api-paste.ini and nova.conf in nova/bin
|
|
|
|
# when running on devstack.
|
|
|
|
# NOTE(lzyeval): Avoid selecting *.pyc files to reduce pep8 check-up time
|
|
|
|
# when running on devstack.
|
2012-07-13 13:47:10 -04:00
|
|
|
srcfiles=`find nova -type f -name "*.py" ! -wholename "nova\/openstack*"`
|
2012-06-27 22:52:41 +00:00
|
|
|
srcfiles+=" `find bin -type f ! -name "nova.conf*" ! -name "*api-paste.ini*"`"
|
|
|
|
srcfiles+=" `find tools -type f -name "*.py"`"
|
|
|
|
srcfiles+=" setup.py"
|
2012-04-13 16:46:42 -04:00
|
|
|
|
|
|
|
# Until all these issues get fixed, ignore.
|
2013-01-04 15:46:18 -05:00
|
|
|
ignore='--ignore=N402,E12,E711,E721,E712'
|
2012-06-27 22:52:41 +00:00
|
|
|
|
2012-04-13 16:46:42 -04:00
|
|
|
${wrapper} python tools/hacking.py ${ignore} ${srcfiles}
|
2012-06-27 22:52:41 +00:00
|
|
|
|
|
|
|
# NOTE(sirp): Dom0 plugins are written for Python 2.4, meaning some HACKING
|
|
|
|
# checks are too strict.
|
|
|
|
pep8onlyfiles=`find plugins -type f -name "*.py"`
|
2012-07-10 01:04:16 -04:00
|
|
|
pep8onlyfiles+=" `find plugins/xenserver/xenapi/etc/xapi.d/plugins/ -type f -perm +111`"
|
2012-10-11 19:31:11 +00:00
|
|
|
${wrapper} pep8 ${ignore} ${pep8onlyfiles}
|
2012-01-20 00:50:56 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-12-18 11:33:01 -05:00
|
|
|
TESTRTESTS="testr run --parallel $testropts"
|
2010-09-28 14:48:03 -04:00
|
|
|
|
2011-01-19 10:50:54 +01:00
|
|
|
if [ $never_venv -eq 0 ]
|
|
|
|
then
|
|
|
|
# Remove the virtual environment if --force used
|
|
|
|
if [ $force -eq 1 ]; then
|
|
|
|
echo "Cleaning virtualenv..."
|
|
|
|
rm -rf ${venv}
|
|
|
|
fi
|
|
|
|
if [ -e ${venv} ]; then
|
|
|
|
wrapper="${with_venv}"
|
2010-08-11 17:40:28 -04:00
|
|
|
else
|
2011-01-19 10:50:54 +01:00
|
|
|
if [ $always_venv -eq 1 ]; then
|
|
|
|
# Automatically install the virtualenv
|
2011-10-30 09:00:59 -04:00
|
|
|
python tools/install_venv.py $installvenvopts
|
2011-01-19 10:50:54 +01:00
|
|
|
wrapper="${with_venv}"
|
2010-08-11 17:40:28 -04:00
|
|
|
else
|
2011-01-19 10:50:54 +01:00
|
|
|
echo -e "No virtual environment found...create one? (Y/n) \c"
|
|
|
|
read use_ve
|
|
|
|
if [ "x$use_ve" = "xY" -o "x$use_ve" = "x" -o "x$use_ve" = "xy" ]; then
|
|
|
|
# Install the virtualenv and run the test suite in it
|
2011-10-30 09:00:59 -04:00
|
|
|
python tools/install_venv.py $installvenvopts
|
2011-01-30 21:55:32 -08:00
|
|
|
wrapper=${with_venv}
|
2011-01-19 10:50:54 +01:00
|
|
|
fi
|
2010-08-11 17:40:28 -04:00
|
|
|
fi
|
|
|
|
fi
|
2010-07-27 21:35:55 -07:00
|
|
|
fi
|
2011-01-19 10:50:54 +01:00
|
|
|
|
2011-07-21 10:30:55 -04:00
|
|
|
# Delete old coverage data from previous runs
|
|
|
|
if [ $coverage -eq 1 ]; then
|
|
|
|
${wrapper} coverage erase
|
|
|
|
fi
|
|
|
|
|
2011-06-07 16:08:25 -04:00
|
|
|
if [ $just_pep8 -eq 1 ]; then
|
|
|
|
run_pep8
|
|
|
|
exit
|
|
|
|
fi
|
|
|
|
|
2011-06-25 17:26:38 -07:00
|
|
|
if [ $recreate_db -eq 1 ]; then
|
2011-07-04 17:31:24 +02:00
|
|
|
rm -f tests.sqlite
|
2011-06-25 17:26:38 -07:00
|
|
|
fi
|
|
|
|
|
2012-10-30 16:30:02 -07:00
|
|
|
init_testr
|
2011-08-28 16:19:55 +05:30
|
|
|
run_tests
|
2011-04-06 18:17:43 -04:00
|
|
|
|
2011-06-15 01:16:53 +00:00
|
|
|
# NOTE(sirp): we only want to run pep8 when we're running the full-test suite,
|
|
|
|
# not when we're running tests individually. To handle this, we need to
|
2012-10-30 16:30:02 -07:00
|
|
|
# distinguish between options (testropts), which begin with a '-', and
|
|
|
|
# arguments (testrargs).
|
|
|
|
if [ -z "$testrargs" ]; then
|
2011-09-22 18:22:42 -04:00
|
|
|
if [ $no_pep8 -eq 0 ]; then
|
|
|
|
run_pep8
|
|
|
|
fi
|
2011-01-30 21:55:32 -08:00
|
|
|
fi
|
2011-07-19 10:52:38 -04:00
|
|
|
|
|
|
|
if [ $coverage -eq 1 ]; then
|
2011-07-21 10:47:34 -04:00
|
|
|
echo "Generating coverage report in covhtml/"
|
2012-04-28 22:01:56 -04:00
|
|
|
# Don't compute coverage for common code, which is tested elsewhere
|
2012-10-30 16:30:02 -07:00
|
|
|
${wrapper} coverage combine
|
2012-04-28 22:01:56 -04:00
|
|
|
${wrapper} coverage html --include='nova/*' --omit='nova/openstack/common/*' -d covhtml -i
|
2011-07-19 10:52:38 -04:00
|
|
|
fi
|