Merge "Make consistency job gating."

This commit is contained in:
Zuul 2018-10-04 20:13:11 +00:00 committed by Gerrit Code Review
commit 1528548993
5 changed files with 68 additions and 33 deletions

View File

@ -152,41 +152,41 @@ def run():
exit_code = 0 exit_code = 0
if len(missing_uuids) > 0: if len(missing_uuids) > 0:
exit_code = 1 exit_code = 1
print "### Idempotent ID Errors Detected. To resolve these errors, " \ print("### Idempotent ID Errors Detected. To resolve these errors, "
"fix the uuid name (format id-<uuid>) in the guideline to " \ "fix the uuid name (format id-<uuid>) in the guideline to "
"match the id in the test suite:" "match the id in the test suite:")
for test in missing_uuids: for test in missing_uuids:
print "Idempotent ID in guideline '%s' does not appear in test " \ print("Idempotent ID in guideline '%s' does not appear in test "
"library '%s'\n" \ "library '%s'\n"
" idempotent_id:\n" \ " idempotent_id:\n"
" %s\n" \ " %s\n"
" names: " % (args.guideline_file, args.testlib, test[0]) " names: " % (args.guideline_file, args.testlib, test[0]))
for testname in test[1]: for testname in test[1]:
print " %s" % (testname) print(" %s" % (testname))
print "" print("")
if len(missing_tests) > 0: if len(missing_tests) > 0:
exit_code = 1 exit_code = 1
print "### Test Name Errors Detected. " \ print("### Test Name Errors Detected. "
"To resolve these errors, update " \ "To resolve these errors, update "
"the Interop guideline with the missing " \ "the Interop guideline with the missing "
"test names:" "test names:")
for uuid in missing_tests: for uuid in missing_tests:
print "Test found in test library '%s'\n" \ print("Test found in test library '%s'\n"
" idempotent_id:\n" \ " idempotent_id:\n"
" %s\n" \ " %s\n"
" name:\n" \ " name:\n"
" %s\n" \ " %s\n"
"Entry in guideline '%s'\n" \ "Entry in guideline '%s'\n"
" idempotent_id:\n" \ " idempotent_id:\n"
" %s\n" \ " %s\n"
" names: " % (args.testlib, " names: " % (args.testlib,
uuid, tests[uuid], uuid, tests[uuid],
args.guideline_file, args.guideline_file,
missing_tests[uuid][0]) missing_tests[uuid][0]))
for testname in missing_tests[uuid][1]: for testname in missing_tests[uuid][1]:
print " %s" % (testname) print(" %s" % (testname))
print "" print("")
sys.exit(exit_code) sys.exit(exit_code)

View File

@ -1,19 +1,40 @@
#!/bin/bash #!/bin/bash
tempestdir=$(mktemp -d) # This script will run consistency checks for Tempest tests against
echo $tempestdir # the three latest interoperability guidelines. It can run in two
git clone git://git.openstack.org/openstack/tempest $tempestdir # modes.
#
# * If no arguments are specified, the script will check out Tempest
# into a temporary directory, run the consistency checks, then delete
# temporary checkout.
#
# * If an argument is given, this script will assume that it is a
# user checked-out repository and run the consistency checks against
# that, and leave the directory unchanged on exit. This mode is useful
# for gate jobs and Tempest development.
set -x
PYTHONPATH=$tempestdir python ./tools/checktests.py --guideline next.json if [ ! $@ ]; then
TEMPESTDIR=$(mktemp -d)
git clone git://git.openstack.org/openstack/tempest $TEMPESTDIR
CLEANTEMPEST=cleantempest
else
TEMPESTDIR=${1}
fi
PYTHONPATH=$TEMPESTDIR python ./tools/checktests.py --guideline next.json
exit_1=$? exit_1=$?
PYTHONPATH=$tempestdir python ./tools/checktests.py --guideline 2018.02.json PYTHONPATH=$TEMPESTDIR python ./tools/checktests.py --guideline 2018.02.json
exit_2=$? exit_2=$?
PYTHONPATH=$tempestdir python ./tools/checktests.py --guideline 2017.09.json PYTHONPATH=$TEMPESTDIR python ./tools/checktests.py --guideline 2017.09.json
exit_3=$? exit_3=$?
rm -rf $tempestdir if [[ ! -z "${CLEANTEMPEST}" ]]; then
rm -rf $TEMPESTDIR
fi
! (( $exit_1 || $exit_2 || $exit_3 )) ! (( $exit_1 || $exit_2 || $exit_3 ))

View File

@ -76,7 +76,7 @@ commands=
[testenv:consistency] [testenv:consistency]
commands= commands=
bash tools/consistency.sh bash tools/consistency.sh {posargs}
whitelist_externals = whitelist_externals =
sh sh
bash bash

12
zuul.d/jobs.yaml Normal file
View File

@ -0,0 +1,12 @@
- job:
name: interop-tempest-consistency
parent: tox
description: |
Ensure consistency between Tempest source and current interop guidelines.
vars:
tox_envlist: consistency
tox_extra_args: "-vv -- {{ ansible_user_dir }}/{{ zuul.projects['git.openstack.org/openstack/tempest'].src_dir }}"
zuul_work_dir: src/git.openstack.org/openstack/interop
required-projects:
- name: openstack/tempest
- name: openstack/interop

View File

@ -4,6 +4,8 @@
check: check:
jobs: jobs:
- openstack-tox-pep8 - openstack-tox-pep8
- interop-tempest-consistency
gate: gate:
jobs: jobs:
- openstack-tox-pep8 - openstack-tox-pep8
- interop-tempest-consistency