Commit d63c3319 authored by Michael Achenbach's avatar Michael Achenbach Committed by Commit Bot

[test] Add more stress options to gc fuzzer

This adds gc stress and scavenge stress to legacy gc fuzzer. Each
flag can be used in separation or combined.

TBR=sergiyb@chromium.org
NOTRY=true

Bug: v8:6972
Change-Id: Id03ef96bd42b77415dd201e7f78b3b42786dd3bc
Reviewed-on: https://chromium-review.googlesource.com/874452
Commit-Queue: Michael Achenbach <machenbach@chromium.org>
Reviewed-by: 's avatarMichael Achenbach <machenbach@chromium.org>
Cr-Commit-Position: refs/heads/master@{#50708}
parent 6da9254c
...@@ -71,10 +71,14 @@ class GCFuzzer(base_runner.BaseTestRunner): ...@@ -71,10 +71,14 @@ class GCFuzzer(base_runner.BaseTestRunner):
parser.add_option("--fuzzer-random-seed", default=0, parser.add_option("--fuzzer-random-seed", default=0,
help="Default seed for initializing fuzzer random " help="Default seed for initializing fuzzer random "
"generator") "generator")
parser.add_option("--stress-compaction", default=False, action="store_true",
help="Enable stress_compaction_random flag")
parser.add_option("--stress-gc", default=False, action="store_true",
help="Enable stress-gc-interval flag")
parser.add_option("--stress-marking", default=False, action="store_true", parser.add_option("--stress-marking", default=False, action="store_true",
help="Enable stress-marking flag") help="Enable stress-marking flag")
parser.add_option("--stress-compaction", default=False, action="store_true", parser.add_option("--stress-scavenge", default=False, action="store_true",
help="Enable stress_compaction_percentage flag") help="Enable stress-scavenge flag")
parser.add_option("--distribution-factor1", help="DEPRECATED") parser.add_option("--distribution-factor1", help="DEPRECATED")
parser.add_option("--distribution-factor2", help="DEPRECATED") parser.add_option("--distribution-factor2", help="DEPRECATED")
...@@ -168,9 +172,9 @@ class GCFuzzer(base_runner.BaseTestRunner): ...@@ -168,9 +172,9 @@ class GCFuzzer(base_runner.BaseTestRunner):
if t.output_proc.has_unexpected_output(runner.outputs[t]): if t.output_proc.has_unexpected_output(runner.outputs[t]):
print '%s failed, skipping' % t.path print '%s failed, skipping' % t.path
continue continue
max_limit = self._get_max_limit_reached(runner.outputs[t]) max_limits = self._get_max_limits_reached(runner.outputs[t])
if max_limit: if max_limits:
test_results[t.path] = max_limit test_results[t.path] = max_limits
runner = None runner = None
...@@ -183,24 +187,50 @@ class GCFuzzer(base_runner.BaseTestRunner): ...@@ -183,24 +187,50 @@ class GCFuzzer(base_runner.BaseTestRunner):
for s in suites: for s in suites:
s.tests = [] s.tests = []
for t in test_backup[s]: for t in test_backup[s]:
max_percent = test_results.get(t.path, 0) results = test_results.get(t.path)
if not max_percent or max_percent < 1.0: if not results:
continue continue
max_percent = int(max_percent) max_marking, max_new_space, max_allocations = results
subtests_count = self._calculate_n_tests(max_percent, options) # Only when combining the flags, make sure one has a minimum of 1 if
# also the other is >=1. Otherwise we might skip it below.
if options.stress_marking and options.stress_scavenge:
if max_new_space:
max_marking = max(max_marking, 1)
if max_marking:
max_new_space = max(max_new_space, 1)
# Make as many subtests as determined by the most dominant factor
# (one of marking or new space).
subtests_count = 1
base_flags = []
if options.stress_marking:
if not max_marking:
# Skip 0 as it switches off the flag.
continue
subtests_count = max(
subtests_count, self._calculate_n_tests(max_marking, options))
base_flags += ['--stress_marking', str(max_marking)]
if options.stress_scavenge:
if not max_new_space:
# Skip 0 as it switches off the flag.
continue
# Divide by 5, since new space is more dominating than marking.
subtests_count = max(
subtests_count, self._calculate_n_tests(
max(1, max_new_space / 5), options))
base_flags += ['--stress_scavenge', str(max_new_space)]
if options.stress_gc:
# Only makes sense in combination with other flags, since we always
# reach our upper limit of 5000.
base_flags += ['--random-gc-interval', str(max_allocations)]
if options.stress_compaction:
base_flags.append('--stress_compaction_random')
if options.verbose:
print ('%s [x%d] (max marking limit=%.02f)' %
(t.path, subtests_count, max_percent))
for i in xrange(0, subtests_count): for i in xrange(0, subtests_count):
fuzzer_seed = self._next_fuzzer_seed()
fuzzing_flags = [ fuzzing_flags = [
'--stress_marking', str(max_percent), '--fuzzer_random_seed', str(self._next_fuzzer_seed()),
'--fuzzer_random_seed', str(fuzzer_seed), ] + base_flags
]
if options.stress_compaction:
fuzzing_flags.append('--stress_compaction_random')
s.tests.append(t.create_variant(t.variant, fuzzing_flags, i)) s.tests.append(t.create_variant(t.variant, fuzzing_flags, i))
for t in s.tests: for t in s.tests:
t.cmd = t.get_command(ctx) t.cmd = t.get_command(ctx)
...@@ -225,7 +255,7 @@ class GCFuzzer(base_runner.BaseTestRunner): ...@@ -225,7 +255,7 @@ class GCFuzzer(base_runner.BaseTestRunner):
"dcheck_always_on": self.build_config.dcheck_always_on, "dcheck_always_on": self.build_config.dcheck_always_on,
"deopt_fuzzer": False, "deopt_fuzzer": False,
"gc_fuzzer": True, "gc_fuzzer": True,
"gc_stress": False, "gc_stress": True,
"gcov_coverage": self.build_config.gcov_coverage, "gcov_coverage": self.build_config.gcov_coverage,
"isolates": options.isolates, "isolates": options.isolates,
"mode": self.mode_options.status_mode, "mode": self.mode_options.status_mode,
...@@ -259,16 +289,32 @@ class GCFuzzer(base_runner.BaseTestRunner): ...@@ -259,16 +289,32 @@ class GCFuzzer(base_runner.BaseTestRunner):
return num_tests return num_tests
# 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), new space size (0-100) and allocations
# (6-5000).
@staticmethod @staticmethod
def _get_max_limit_reached(output): def _get_max_limits_reached(output):
"""Returns: list [max marking, max new space, allocations]"""
if not output.stdout: if not output.stdout:
return None return None
results = [0, 0, 0]
for l in reversed(output.stdout.splitlines()): for l in reversed(output.stdout.splitlines()):
if l.startswith('### Maximum marking limit reached ='): if l.startswith('### Maximum marking limit reached ='):
return float(l.split()[6]) results[0] = float(l.split()[6])
elif l.startswith('### Maximum new space size reached ='):
results[1] = float(l.split()[7])
elif l.startswith('### Allocations ='):
# Also remove the comma in the end after split.
results[2] = int(l.split()[3][:-1])
if all(results):
break
if any(results):
return (
max(0, int(results[0])),
max(0, int(results[1])),
min(5000, max(6, results[2])),
)
return None return None
def _next_fuzzer_seed(self): def _next_fuzzer_seed(self):
......
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