Commit 53a367ec authored by Michal Majewski's avatar Michal Majewski Committed by Commit Bot

[test] Use analysis flag in gc fuzzer.

Bug: v8:6972
Change-Id: I0f3f933f14b26771b73daa053c17ce4cf8906bd7
Reviewed-on: https://chromium-review.googlesource.com/819635
Commit-Queue: Michał Majewski <majeski@google.com>
Reviewed-by: 's avatarMichael Achenbach <machenbach@chromium.org>
Cr-Commit-Position: refs/heads/master@{#50459}
parent 70516918
...@@ -192,12 +192,7 @@ class GCFuzzer(base_runner.BaseTestRunner): ...@@ -192,12 +192,7 @@ class GCFuzzer(base_runner.BaseTestRunner):
print('>>> Collection phase') print('>>> Collection phase')
for s in suites: for s in suites:
analysis_flags = [ analysis_flags = ['--fuzzer-gc-analysis']
# > 100% to not influence default incremental marking, but we need this
# flag to print reached incremental marking limit.
'--stress_marking', '1000',
'--trace_incremental_marking',
]
s.tests = map(lambda t: t.create_variant(t.variant, analysis_flags, s.tests = map(lambda t: t.create_variant(t.variant, analysis_flags,
'analysis'), 'analysis'),
s.tests) s.tests)
...@@ -308,31 +303,16 @@ class GCFuzzer(base_runner.BaseTestRunner): ...@@ -308,31 +303,16 @@ class GCFuzzer(base_runner.BaseTestRunner):
# Parses test stdout and returns what was the highest reached percent of the # Parses test stdout and returns what was the highest reached percent of the
# incremental marking limit (0-100). # incremental marking limit (0-100).
# Skips values >=100% since they already trigger incremental marking.
@staticmethod @staticmethod
def _get_max_limit_reached(output): def _get_max_limit_reached(output):
def is_im_line(l): if not output.stdout:
return 'IncrementalMarking' in l and '% of the memory limit reached' in l
def line_to_percent(l):
return filter(lambda part: '%' in part, l.split(' '))[0]
def percent_str_to_float(s):
return float(s[:-1])
if not (output and output.stdout):
return None return None
im_lines = filter(is_im_line, output.stdout.splitlines()) for l in reversed(output.stdout.splitlines()):
percents_str = map(line_to_percent, im_lines) if l.startswith('### Maximum marking limit reached ='):
percents = map(percent_str_to_float, percents_str) return float(l.split()[6])
# Skip >= 100%. return None
percents = filter(lambda p: p < 100, percents)
if not percents:
return None
return max(percents)
def _next_fuzzer_seed(self): def _next_fuzzer_seed(self):
fuzzer_seed = None fuzzer_seed = None
......
...@@ -151,7 +151,7 @@ class ExpectedOutProc(OutProc): ...@@ -151,7 +151,7 @@ class ExpectedOutProc(OutProc):
return (line.startswith('==') or return (line.startswith('==') or
line.startswith('**') or line.startswith('**') or
line.startswith('ANDROID') or line.startswith('ANDROID') or
'[IncrementalMarking]' in line or line.startswith('###') or
# FIXME(machenbach): The test driver shouldn't try to use slow # FIXME(machenbach): The test driver shouldn't try to use slow
# asserts if they weren't compiled. This fails in optdebug=2. # asserts if they weren't compiled. This fails in optdebug=2.
line == 'Warning: unknown flag --enable-slow-asserts.' or line == 'Warning: unknown flag --enable-slow-asserts.' or
......
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