diff options
author | David Eichmann <EichmannD@gmail.com> | 2019-05-16 13:19:38 +0100 |
---|---|---|
committer | David Eichmann <EichmannD@gmail.com> | 2019-05-20 15:41:55 +0100 |
commit | 5bb80cf2c5601fc57231946c10aee76398b907dd (patch) | |
tree | 54907fcc14d6ff0b456966d45c16944a27ee585a | |
parent | 7105fb66a7bacf822f7f23028136f89ff5737d0e (diff) | |
download | haskell-5bb80cf2c5601fc57231946c10aee76398b907dd.tar.gz |
Improve test runner logging when calculating performance metric baseline #16662
We attempt to get 75 commit hashes via `git log`, but this only gave 10
hashes in a CI run (see #16662). Better logging may help solve this
error if it occurs again in the future.
-rw-r--r-- | testsuite/driver/perf_notes.py | 21 |
1 files changed, 16 insertions, 5 deletions
diff --git a/testsuite/driver/perf_notes.py b/testsuite/driver/perf_notes.py index 0aa2fa962e..84ef62c3a9 100644 --- a/testsuite/driver/perf_notes.py +++ b/testsuite/driver/perf_notes.py @@ -297,10 +297,19 @@ def baseline_commit_log(commit): global _baseline_depth_commit_log commit = commit_hash(commit) if not commit in _baseline_depth_commit_log: - _baseline_depth_commit_log[commit] = \ - subprocess.check_output(['git', 'log', '--format=%H', \ - '-n' + str(BaselineSearchDepth)]) \ - .decode().split('\n') + n = BaselineSearchDepth + output = subprocess.check_output(['git', 'log', '--format=%H', '-n' + str(n), commit]).decode() + hashes = list(filter(is_commit_hash, output.split('\n'))) + + # We only got 10 results (expecting 75) in a CI pipeline (issue #16662). + # It's unclear from the logs what went wrong. Since no exception was + # thrown, we can assume the `git log` call above succeeded. The best we + # can do for now is improve logging. + actualN = len(hashes) + if actualN != n: + print("Expected " + str(n) + " hashes, but git gave " + str(actualN) + ":\n" + output) + _baseline_depth_commit_log[commit] = hashes + return _baseline_depth_commit_log[commit] # Cache of baseline values. This is a dict of dicts indexed on: @@ -397,7 +406,9 @@ def baseline_metric(commit, name, test_env, metric, way): # Searches through previous commits trying local then ci for each commit in. def search(useCiNamespace, depth): # Stop if reached the max search depth. - if depth >= BaselineSearchDepth: + # We use len(commit_hashes) instead of BaselineSearchDepth incase + # baseline_commit_log() returned fewer than BaselineSearchDepth hashes. + if depth >= len(commit_hashes): return None # Check for a metric on this commit. |