Refactor tools/unit_tests.sh
unit_tests.sh has a lot of duplicated statements. This commits introduces run_test function to clarify the differences. selenium_tests.sh is also updated to clarify which positional arguments are used. Direct usage of $1, $2 is not easy to understand. Change-Id: Ie13f0a804968d548b3c13b0d87daa745dd2ad040
This commit is contained in:
parent
ccaaf8cbb9
commit
218ee6bcce
@ -1,5 +1,7 @@
|
|||||||
# Uses envpython and toxinidir from tox run to construct a test command
|
ROOT=$1
|
||||||
|
|
||||||
test_results="--junitxml=${1}/test_reports/selenium_test_results.xml --html=${1}/test_reports/selenium_test_results.html"
|
report_args="--junitxml=$ROOT/test_reports/selenium_test_results.xml"
|
||||||
|
report_args+=" --html=$ROOT/test_reports/selenium_test_results.html"
|
||||||
|
report_args+=" --self-contained-html"
|
||||||
|
|
||||||
pytest ${1}/openstack_dashboard/ --ds=openstack_dashboard.test.settings -v -m selenium $test_results --self-contained-html
|
pytest $ROOT/openstack_dashboard/ --ds=openstack_dashboard.test.settings -v -m selenium $report_args
|
||||||
|
@ -1,8 +1,7 @@
|
|||||||
# Uses envpython and toxinidir from tox run to construct a test command
|
root=$1
|
||||||
testcommand="pytest"
|
|
||||||
posargs="${@:2}"
|
posargs="${@:2}"
|
||||||
|
|
||||||
tagarg="not selenium and not integration and not plugin_test"
|
report_dir=$root/test_reports
|
||||||
|
|
||||||
# Attempt to identify if any of the arguments passed from tox is a test subset
|
# Attempt to identify if any of the arguments passed from tox is a test subset
|
||||||
if [ -n "$posargs" ]; then
|
if [ -n "$posargs" ]; then
|
||||||
@ -14,37 +13,70 @@ if [ -n "$posargs" ]; then
|
|||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
|
||||||
horizon_test_results="--junitxml=${1}/test_reports/horizon_test_results.xml --html=${1}/test_reports/horizon_test_results.html"
|
|
||||||
dashboard_test_results="--junitxml=${1}/test_reports/openstack_dashboard_test_results.xml --html=${1}/test_reports/openstack_dashboard_test_results.html"
|
function run_test {
|
||||||
auth_test_results="--junitxml=${1}/test_reports/openstack_auth_test_results.xml --html=${1}/test_reports/openstack_auth_test_results.html"
|
local project=$1
|
||||||
plugins_test_results="--junitxml=${1}/test_reports/plugin_test_results.xml --html=${1}/test_reports/plugin_test_results.html"
|
local tag
|
||||||
single_html="--self-contained-html"
|
local target
|
||||||
|
local settings_module
|
||||||
|
local report_args
|
||||||
|
|
||||||
|
tag="not selenium and not integration and not plugin_test"
|
||||||
|
|
||||||
|
case "$project" in
|
||||||
|
horizon)
|
||||||
|
settings_module="horizon.test.settings"
|
||||||
|
;;
|
||||||
|
openstack_dashboard)
|
||||||
|
settings_module="openstack_dashboard.test.settings"
|
||||||
|
;;
|
||||||
|
openstack_auth)
|
||||||
|
settings_module="openstack_auth.tests.settings"
|
||||||
|
;;
|
||||||
|
plugin|plugin-test|plugin_test)
|
||||||
|
project="plugin"
|
||||||
|
tag="plugin_test"
|
||||||
|
target="$root/openstack_dashboard/test/test_plugins"
|
||||||
|
settings_module="openstack_dashboard.test.settings"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
# Declare error by returning 1 which usually means error in bash
|
||||||
|
return 1
|
||||||
|
esac
|
||||||
|
|
||||||
|
if [ -z "$target" ]; then
|
||||||
|
if [ -n "$subset" ]; then
|
||||||
|
target="$subset"
|
||||||
|
else
|
||||||
|
target="$root/$project"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
report_args="--junitxml=$report_dir/${project}_test_results.xml"
|
||||||
|
report_args+=" --html=$report_dir/${project}_test_results.html"
|
||||||
|
report_args+=" --self-contained-html"
|
||||||
|
|
||||||
|
pytest $target --ds=$settings_module -v -m "$tag" $report_args
|
||||||
|
return $?
|
||||||
|
}
|
||||||
|
|
||||||
# If we are running a test subset, supply the correct settings file.
|
# If we are running a test subset, supply the correct settings file.
|
||||||
# If not, simply run the entire test suite.
|
# If not, simply run the entire test suite.
|
||||||
if [ -n "$subset" ]; then
|
if [ -n "$subset" ]; then
|
||||||
project="${subset%%/*}"
|
project="${subset%%/*}"
|
||||||
if [ $project == "horizon" ]; then
|
run_test $project
|
||||||
$testcommand $posargs --ds=horizon.test.settings -v -m "$tagarg" $horizon_test_results $single_html
|
exit $?
|
||||||
elif [ $project == "openstack_dashboard" ]; then
|
|
||||||
$testcommand $posargs --ds=openstack_dashboard.test.settings -v -m "$tagarg" $dashboard_test_results $single_html
|
|
||||||
elif [ $project == "openstack_auth" ]; then
|
|
||||||
$testcommand $posargs --ds=openstack_auth.tests.settings -v -m "$tagarg" $auth_test_results $single_html
|
|
||||||
elif [ $project == "plugin-test" ]; then
|
|
||||||
$testcommand ${1}/openstack_dashboard/test/test_plugins --ds=openstack_dashboard.test.settings -v -m plugin_test $plugins_test_results $single_html
|
|
||||||
fi
|
|
||||||
else
|
else
|
||||||
$testcommand ${1}/horizon/ --ds=horizon.test.settings -v -m "$tagarg" $horizon_test_results $single_html
|
results=()
|
||||||
horizon_tests=$?
|
for project in horizon openstack_dashboard openstack_auth plugin; do
|
||||||
$testcommand ${1}/openstack_dashboard/ --ds=openstack_dashboard.test.settings -v -m "$tagarg" $dashboard_test_results $single_html
|
run_test $project
|
||||||
openstack_dashboard_tests=$?
|
results+=($?)
|
||||||
$testcommand ${1}/openstack_auth/tests/ --ds=openstack_auth.tests.settings -v -m "$tagarg" $auth_test_results $single_html
|
done
|
||||||
auth_tests=$?
|
|
||||||
$testcommand ${1}/openstack_dashboard/ --ds=openstack_dashboard.test.settings -v -m plugin_test $plugins_test_results $single_html
|
|
||||||
plugin_tests=$?
|
|
||||||
# we have to tell tox if either of these test runs failed
|
# we have to tell tox if either of these test runs failed
|
||||||
if [[ $horizon_tests != 0 || $openstack_dashboard_tests != 0 || \
|
for r in "${results[@]}"; do
|
||||||
$auth_tests != 0 || $plugin_tests != 0 ]]; then
|
if [ $r != 0 ]; then
|
||||||
exit 1;
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
done
|
||||||
fi
|
fi
|
||||||
|
Loading…
x
Reference in New Issue
Block a user