Skip to content

Commit

Permalink
Merge pull request grpc#4647 from ctiller/run_errors
Browse files Browse the repository at this point in the history
Handle errors in run_tests.py a little better
  • Loading branch information
murgatroid99 committed Jan 8, 2016
2 parents d4f86d0 + 4f2be36 commit c8bfa7c
Showing 1 changed file with 34 additions and 13 deletions.
47 changes: 34 additions & 13 deletions tools/run_tests/run_tests.py
Original file line number Diff line number Diff line change
Expand Up @@ -961,6 +961,15 @@ def _calculate_num_runs_failures(list_of_results):
return num_runs, num_failures


# _build_and_run results
class BuildAndRunError(object):

BUILD = object()
TEST = object()
POST_TEST = object()


# returns a list of things that failed (or an empty list on success)
def _build_and_run(
check_cancelled, newline_on_success, cache, xml_report=None, build_only=False):
"""Do one pass of building & running tests."""
Expand All @@ -969,10 +978,10 @@ def _build_and_run(
build_steps, maxjobs=1, stop_on_failure=True,
newline_on_success=newline_on_success, travis=args.travis)
if num_failures:
return 1
return [BuildAndRunError.BUILD]

if build_only:
return 0
return []

# start antagonists
antagonists = [subprocess.Popen(['tools/run_tests/antagonist.py'])
Expand Down Expand Up @@ -1030,12 +1039,16 @@ def _build_and_run(
number_failures, _ = jobset.run(
post_tests_steps, maxjobs=1, stop_on_failure=True,
newline_on_success=newline_on_success, travis=args.travis)
if num_test_failures or number_failures:
return 2

out = []
if number_failures:
out.append(BuildAndRunError.POST_TEST)
if num_test_failures:
out.append(BuildAndRunError.TEST)

if cache: cache.save()

return 0
return out


test_cache = TestCache(runs_per_test == 1)
Expand All @@ -1048,25 +1061,33 @@ def _build_and_run(
initial_time = dw.most_recent_change()
have_files_changed = lambda: dw.most_recent_change() != initial_time
previous_success = success
success = _build_and_run(check_cancelled=have_files_changed,
newline_on_success=False,
cache=test_cache,
build_only=args.build_only) == 0
if not previous_success and success:
errors = _build_and_run(check_cancelled=have_files_changed,
newline_on_success=False,
cache=test_cache,
build_only=args.build_only) == 0
if not previous_success and not errors:
jobset.message('SUCCESS',
'All tests are now passing properly',
do_newline=True)
jobset.message('IDLE', 'No change detected')
while not have_files_changed():
time.sleep(1)
else:
result = _build_and_run(check_cancelled=lambda: False,
errors = _build_and_run(check_cancelled=lambda: False,
newline_on_success=args.newline_on_success,
cache=test_cache,
xml_report=args.xml_report,
build_only=args.build_only)
if result == 0:
if not errors:
jobset.message('SUCCESS', 'All tests passed', do_newline=True)
else:
jobset.message('FAILED', 'Some tests failed', do_newline=True)
sys.exit(result)
exit_code = 0
if BuildAndRunError.BUILD in errors:
exit_code |= 1
if BuildAndRunError.TEST in errors and not args.travis:
exit_code |= 2
if BuildAndRunError.POST_TEST in errors:
exit_code |= 4
sys.exit(exit_code)

0 comments on commit c8bfa7c

Please sign in to comment.