aboutsummaryrefslogtreecommitdiffstats
path: root/utils
diff options
context:
space:
mode:
authorBill Wendling <isanbard@gmail.com>2011-10-21 06:58:01 +0000
committerStephen Hines <srhines@google.com>2011-11-14 09:10:59 -0800
commit42e0a001f4e35a6436f198f8b97c0dc14adfa153 (patch)
treeb26fb6d0494d3107d5e54ef4193eb3df531d8a68 /utils
parentc066193e0bddd9b36cd3be866d256ea9ab6ac3ad (diff)
downloadexternal_llvm-42e0a001f4e35a6436f198f8b97c0dc14adfa153.zip
external_llvm-42e0a001f4e35a6436f198f8b97c0dc14adfa153.tar.gz
external_llvm-42e0a001f4e35a6436f198f8b97c0dc14adfa153.tar.bz2
Modify the script to output the regressions and passes into categories. My Python-fu could use some improving...
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@142643 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'utils')
-rwxr-xr-xutils/release/findRegressions.py53
1 files changed, 44 insertions, 9 deletions
diff --git a/utils/release/findRegressions.py b/utils/release/findRegressions.py
index d3811a5..7586231 100755
--- a/utils/release/findRegressions.py
+++ b/utils/release/findRegressions.py
@@ -62,6 +62,13 @@ def parse(file):
# Diff results and look for regressions.
def diffResults(d_old, d_new):
+ regressions = {}
+ passes = {}
+ removed = ''
+
+ for x in ['compile state', 'compile time', 'exec state', 'exec time']:
+ regressions[x] = ''
+ passes[x] = ''
for t in sorted(d_old.keys()) :
if d_new.has_key(t):
@@ -77,13 +84,13 @@ def diffResults(d_old, d_new):
if d_old[t][x] == 'PASS':
if d_new[t][x] != 'PASS':
- print t + " *** REGRESSION (" + x + " now fails)"
+ regressions[x] += t + "\n"
else:
if d_new[t][x] == 'PASS':
- print t + " * NEW PASS (" + x + " now fails)"
+ passes[x] += t + "\n"
else :
- print t + "*** REGRESSION (" + x + " now fails)"
+ regressions[x] += t + "\n"
if x == 'compile state' or x == 'exec state':
continue
@@ -92,25 +99,53 @@ def diffResults(d_old, d_new):
if not d_old[t].has_key(x) and not d_new[t].has_key(x):
continue
elif not d_new[t].has_key(x):
- print t + " *** REGRESSION (" + x + ")"
+ regressions[x] += t + "\n"
elif not d_old[t].has_key(x):
- print t + " * NEW PASS (" + x + ")"
+ passes[x] += t + "\n"
if math.isnan(d_old[t][x]) and math.isnan(d_new[t][x]):
continue
elif math.isnan(d_old[t][x]) and not math.isnan(d_new[t][x]):
- print t + " * NEW PASS (" + x + ")"
+ passes[x] += t + "\n"
elif not math.isnan(d_old[t][x]) and math.isnan(d_new[t][x]):
- print t + " *** REGRESSION (" + x + ")"
+ regressions[x] += t + ": NaN%\n"
if d_new[t][x] > d_old[t][x] and d_old[t][x] > 0.0 and \
(d_new[t][x] - d_old[t][x]) / d_old[t][x] > .05:
- print t + " *** REGRESSION (" + x + ")"
+ regressions[x] += t + ": " + "{0:.1f}".format(100 * (d_new[t][x] - d_old[t][x]) / d_old[t][x]) + "%\n"
else :
- print t + ": Removed from test-suite."
+ removed += t + "\n"
+
+ if len(regressions['compile state']) != 0:
+ print 'REGRESSION: Compilation Failed'
+ print regressions['compile state']
+
+ if len(regressions['exec state']) != 0:
+ print 'REGRESSION: Execution Failed'
+ print regressions['exec state']
+
+ if len(regressions['compile time']) != 0:
+ print 'REGRESSION: Compilation Time'
+ print regressions['compile time']
+
+ if len(regressions['exec time']) != 0:
+ print 'REGRESSION: Execution Time'
+ print regressions['exec time']
+
+ if len(passes['compile state']) != 0:
+ print 'NEW PASSES: Compilation'
+ print passes['compile state']
+
+ if len(passes['exec state']) != 0:
+ print 'NEW PASSES: Execution'
+ print passes['exec state']
+
+ if len(removed) != 0:
+ print 'REMOVED TESTS'
+ print removed
# Main
if len(sys.argv) < 3 :