Commit 32c1a793 authored by littledan's avatar littledan Committed by Commit bot

[test] Presumbit check against missing tests in status files

Our test infrastructure ignores missing tests which are listed in
status files. Sometimes, tests are removed and status file lines
are not updated. This patch adds a presubmit check for status
files addressing JavaScript tests to not reference missing tests.
It also cleans up existing violations.

R=machenbach

Review-Url: https://codereview.chromium.org/2610353002
Cr-Commit-Position: refs/heads/master@{#42106}
parent a6402fd9
...@@ -198,7 +198,6 @@ ...@@ -198,7 +198,6 @@
'regress/regress-4121': [SKIP], 'regress/regress-4121': [SKIP],
'compare-known-objects-slow': [SKIP], 'compare-known-objects-slow': [SKIP],
# Tests taking too long # Tests taking too long
'mirror-object': [SKIP],
'packed-elements': [SKIP], 'packed-elements': [SKIP],
'regress/regress-1122': [SKIP], 'regress/regress-1122': [SKIP],
'regress/regress-331444': [SKIP], 'regress/regress-331444': [SKIP],
...@@ -301,7 +300,6 @@ ...@@ -301,7 +300,6 @@
'json2': [PASS, SLOW], 'json2': [PASS, SLOW],
'math-floor-of-div-nosudiv': [PASS, SLOW], 'math-floor-of-div-nosudiv': [PASS, SLOW],
'math-floor-of-div': [PASS, SLOW], 'math-floor-of-div': [PASS, SLOW],
'mirror-object': [PASS, SLOW],
'packed-elements': [PASS, SLOW], 'packed-elements': [PASS, SLOW],
'regress/regress-1122': [PASS, SLOW], 'regress/regress-1122': [PASS, SLOW],
'regress/regress-2185-2': [PASS, SLOW], 'regress/regress-2185-2': [PASS, SLOW],
...@@ -395,7 +393,6 @@ ...@@ -395,7 +393,6 @@
# Slow tests. # Slow tests.
'array-sort': [PASS, SLOW], 'array-sort': [PASS, SLOW],
'compiler/osr-with-args': [PASS, SLOW], 'compiler/osr-with-args': [PASS, SLOW],
'mirror-object': [PASS, SLOW],
'packed-elements': [PASS, SLOW], 'packed-elements': [PASS, SLOW],
'regress/regress-2185-2': [PASS, SLOW], 'regress/regress-2185-2': [PASS, SLOW],
'regress/regress-2790': [PASS, SLOW], 'regress/regress-2790': [PASS, SLOW],
...@@ -416,7 +413,6 @@ ...@@ -416,7 +413,6 @@
'array-splice': [PASS, TIMEOUT], 'array-splice': [PASS, TIMEOUT],
# Long running test. # Long running test.
'mirror-object': [PASS, TIMEOUT],
'string-indexof-2': [PASS, TIMEOUT], 'string-indexof-2': [PASS, TIMEOUT],
# Long running tests. Skipping because having them timeout takes too long on # Long running tests. Skipping because having them timeout takes too long on
...@@ -435,12 +431,6 @@ ...@@ -435,12 +431,6 @@
'math-floor-of-div-minus-zero': [SKIP], 'math-floor-of-div-minus-zero': [SKIP],
}], # 'arch == mipsel or arch == mips' }], # 'arch == mipsel or arch == mips'
##############################################################################
['arch == mips', {
# Flaky with TF.
'mirror-script': [PASS, NO_VARIANTS],
}], # 'arch == mips'
############################################################################## ##############################################################################
['arch == mips64el or arch == mips64', { ['arch == mips64el or arch == mips64', {
...@@ -453,7 +443,6 @@ ...@@ -453,7 +443,6 @@
'array-splice': [PASS, TIMEOUT], 'array-splice': [PASS, TIMEOUT],
# Long running test. # Long running test.
'mirror-object': [PASS, TIMEOUT],
'string-indexof-2': [PASS, TIMEOUT], 'string-indexof-2': [PASS, TIMEOUT],
# BUG(3251035): Timeouts in long looping crankshaft optimization # BUG(3251035): Timeouts in long looping crankshaft optimization
......
...@@ -433,18 +433,15 @@ ...@@ -433,18 +433,15 @@
# incompatibilities if the test cases turn out to be broken or ambiguous. # incompatibilities if the test cases turn out to be broken or ambiguous.
# Some of these are related to v8:4361 in being visible side effects from Intl. # Some of these are related to v8:4361 in being visible side effects from Intl.
'intl402/6.2.3': [FAIL], 'intl402/6.2.3': [FAIL],
'intl402/Collator/10.1.2.1_4': [FAIL],
'intl402/Collator/10.1.2_a': [PASS, FAIL], 'intl402/Collator/10.1.2_a': [PASS, FAIL],
'intl402/Collator/10.2.3_b': [PASS, FAIL], 'intl402/Collator/10.2.3_b': [PASS, FAIL],
'intl402/Collator/prototype/10.3_a': [FAIL], 'intl402/Collator/prototype/10.3_a': [FAIL],
'intl402/DateTimeFormat/12.1.2': [PASS, FAIL], 'intl402/DateTimeFormat/12.1.2': [PASS, FAIL],
'intl402/DateTimeFormat/12.1.2.1_4': [FAIL],
'intl402/DateTimeFormat/12.2.3_b': [FAIL], 'intl402/DateTimeFormat/12.2.3_b': [FAIL],
'intl402/DateTimeFormat/prototype/12.3_a': [FAIL], 'intl402/DateTimeFormat/prototype/12.3_a': [FAIL],
'intl402/Number/prototype/toLocaleString/13.2.1_5': [PASS, FAIL], 'intl402/Number/prototype/toLocaleString/13.2.1_5': [PASS, FAIL],
'intl402/NumberFormat/11.1.1_20_c': [FAIL], 'intl402/NumberFormat/11.1.1_20_c': [FAIL],
'intl402/NumberFormat/11.1.2': [PASS, FAIL], 'intl402/NumberFormat/11.1.2': [PASS, FAIL],
'intl402/NumberFormat/11.1.2.1_4': [FAIL],
'intl402/NumberFormat/11.2.3_b': [FAIL], 'intl402/NumberFormat/11.2.3_b': [FAIL],
'intl402/NumberFormat/prototype/11.3_a': [FAIL], 'intl402/NumberFormat/prototype/11.3_a': [FAIL],
'intl402/String/prototype/localeCompare/13.1.1_7': [PASS, FAIL], 'intl402/String/prototype/localeCompare/13.1.1_7': [PASS, FAIL],
......
...@@ -232,11 +232,22 @@ def _ReadSection(section, rules, wildcards, variables): ...@@ -232,11 +232,22 @@ def _ReadSection(section, rules, wildcards, variables):
else: else:
_ParseOutcomeList(rule, section[rule], rules, variables) _ParseOutcomeList(rule, section[rule], rules, variables)
JS_TEST_PATHS = {
'debugger': [[]],
'inspector': [[]],
'intl': [[]],
'message': [[]],
'mjsunit': [[]],
'mozilla': [['data']],
'test262': [['data', 'test'], ['local-tests', 'test']],
'webkit': [[]],
}
def PresubmitCheck(path): def PresubmitCheck(path):
with open(path) as f: with open(path) as f:
contents = ReadContent(f.read()) contents = ReadContent(f.read())
root_prefix = os.path.basename(os.path.dirname(path)) + "/" basename = os.path.basename(os.path.dirname(path))
root_prefix = basename + "/"
status = {"success": True} status = {"success": True}
def _assert(check, message): # Like "assert", but doesn't throw. def _assert(check, message): # Like "assert", but doesn't throw.
if not check: if not check:
...@@ -255,6 +266,11 @@ def PresubmitCheck(path): ...@@ -255,6 +266,11 @@ def PresubmitCheck(path):
"Suite name prefix must not be used in rule keys") "Suite name prefix must not be used in rule keys")
_assert(not rule.endswith('.js'), _assert(not rule.endswith('.js'),
".js extension must not be used in rule keys.") ".js extension must not be used in rule keys.")
if basename in JS_TEST_PATHS and '*' not in rule:
_assert(any(os.path.exists(os.path.join(os.path.dirname(path),
*(paths + [rule + ".js"])))
for paths in JS_TEST_PATHS[basename]),
"missing file for %s test %s" % (basename, rule))
return status["success"] return status["success"]
except Exception as e: except Exception as e:
print e print e
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment