Commit 0ff84265 authored by Michał Majewski's avatar Michał Majewski Committed by Commit Bot

Revert "Setting up the environment for testrunner refactored"

This reverts commit 697b2c09.

Reason for revert: <INSERT REASONING HERE>

Original change's description:
> Setting up the environment for testrunner refactored
> 
> Bug: v8:6917
> Change-Id: Ibc3c738ef807d37d8b76f440d9765c4d0405c021
> Reviewed-on: https://chromium-review.googlesource.com/735421
> Commit-Queue: Michał Majewski <majeski@google.com>
> Reviewed-by: Michael Achenbach <machenbach@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#48923}

TBR=machenbach@chromium.org,majeski@google.com

Change-Id: Iafb29f1f13decc6e6ed00ed6e815008fcde1dc44
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Bug: v8:6917
Reviewed-on: https://chromium-review.googlesource.com/737635Reviewed-by: 's avatarMichael Achenbach <machenbach@chromium.org>
Commit-Queue: Michael Achenbach <machenbach@chromium.org>
Cr-Commit-Position: refs/heads/master@{#48959}
parent af75f763
...@@ -166,7 +166,6 @@ class BaseTestRunner(object): ...@@ -166,7 +166,6 @@ class BaseTestRunner(object):
parser.print_help() parser.print_help()
raise raise
self._setup_env()
return self._do_execute(options, args) return self._do_execute(options, args)
except TestRunnerError: except TestRunnerError:
return 1 return 1
...@@ -322,71 +321,6 @@ class BaseTestRunner(object): ...@@ -322,71 +321,6 @@ class BaseTestRunner(object):
def _process_options(self, options): def _process_options(self, options):
pass pass
def _setup_env(self):
# Use the v8 root as cwd as some test cases use "load" with relative paths.
os.chdir(BASE_DIR)
# Many tests assume an English interface.
os.environ['LANG'] = 'en_US.UTF-8'
symbolizer_option = self._get_external_symbolizer_option()
if self.build_config.asan:
asan_options = [symbolizer_option, "allow_user_segv_handler=1"]
if not utils.GuessOS() in ['macos', 'windows']:
# LSAN is not available on mac and windows.
asan_options.append('detect_leaks=1')
os.environ['ASAN_OPTIONS'] = ":".join(asan_options)
if self.build_config.cfi_vptr:
os.environ['UBSAN_OPTIONS'] = ":".join([
'print_stacktrace=1',
'print_summary=1',
'symbolize=1',
symbolizer_option,
])
if self.build_config.ubsan_vptr:
os.environ['UBSAN_OPTIONS'] = ":".join([
'print_stacktrace=1',
symbolizer_option,
])
if self.build_config.msan:
os.environ['MSAN_OPTIONS'] = symbolizer_option
if self.build_config.tsan:
suppressions_file = os.path.join(
BASE_DIR,
'tools',
'sanitizers',
'tsan_suppressions.txt')
os.environ['TSAN_OPTIONS'] = " ".join([
symbolizer_option,
'suppressions=%s' % suppressions_file,
'exit_code=0',
'report_thread_leaks=0',
'history_size=7',
'report_destroy_locked=0',
])
def _get_external_symbolizer_option(self):
external_symbolizer_path = os.path.join(
BASE_DIR,
'third_party',
'llvm-build',
'Release+Asserts',
'bin',
'llvm-symbolizer',
)
if utils.IsWindows():
# Quote, because sanitizers might confuse colon as option separator.
external_symbolizer_path = '"%s.exe"' % external_symbolizer_path
return 'external_symbolizer_path=%s' % external_symbolizer_path
# TODO(majeski): remove options & args parameters # TODO(majeski): remove options & args parameters
def _do_execute(self, options, args): def _do_execute(self, options, args):
raise NotImplementedError() raise NotImplementedError()
...@@ -201,6 +201,9 @@ class DeoptFuzzer(base_runner.BaseTestRunner): ...@@ -201,6 +201,9 @@ class DeoptFuzzer(base_runner.BaseTestRunner):
return shard return shard
def _do_execute(self, options, args): def _do_execute(self, options, args):
# Use the v8 root as cwd as some test cases use "load" with relative paths.
os.chdir(base_runner.BASE_DIR)
suite_paths = utils.GetSuitePaths(join(base_runner.BASE_DIR, "test")) suite_paths = utils.GetSuitePaths(join(base_runner.BASE_DIR, "test"))
if len(args) == 0: if len(args) == 0:
......
...@@ -73,9 +73,13 @@ class StandardTestRunner(base_runner.BaseTestRunner): ...@@ -73,9 +73,13 @@ class StandardTestRunner(base_runner.BaseTestRunner):
def __init__(self): def __init__(self):
super(StandardTestRunner, self).__init__() super(StandardTestRunner, self).__init__()
self.sancov_dir = None
def _do_execute(self, options, args): def _do_execute(self, options, args):
# Use the v8 root as cwd as some test cases use "load" with relative
# paths.
os.chdir(base_runner.BASE_DIR)
self._setup_env(options)
if options.swarming: if options.swarming:
# Swarming doesn't print how isolated commands are called. Lets make # Swarming doesn't print how isolated commands are called. Lets make
# this less cryptic by printing it ourselves. # this less cryptic by printing it ourselves.
...@@ -244,11 +248,7 @@ class StandardTestRunner(base_runner.BaseTestRunner): ...@@ -244,11 +248,7 @@ class StandardTestRunner(base_runner.BaseTestRunner):
def _process_options(self, options): def _process_options(self, options):
global VARIANTS global VARIANTS
if options.sancov_dir: # Special processing of other options, sorted alphabetically.
self.sancov_dir = options.sancov_dir
if not os.path.exists(self.sancov_dir):
print("sancov-dir %s doesn't exist" % self.sancov_dir)
raise base_runner.TestRunnerError()
if options.buildbot: if options.buildbot:
options.network = False options.network = False
...@@ -337,19 +337,73 @@ class StandardTestRunner(base_runner.BaseTestRunner): ...@@ -337,19 +337,73 @@ class StandardTestRunner(base_runner.BaseTestRunner):
base_runner.TEST_MAP["bot_default"].remove("intl") base_runner.TEST_MAP["bot_default"].remove("intl")
base_runner.TEST_MAP["default"].remove("intl") base_runner.TEST_MAP["default"].remove("intl")
def _setup_env(self): def _setup_env(self, options):
super(StandardTestRunner, self)._setup_env() """Setup additional environment variables."""
symbolizer_option = self._get_external_symbolizer_option() # Many tests assume an English interface.
os.environ['LANG'] = 'en_US.UTF-8'
external_symbolizer_path = os.path.join(
base_runner.BASE_DIR,
'third_party',
'llvm-build',
'Release+Asserts',
'bin',
'llvm-symbolizer',
)
if utils.IsWindows():
# Quote, because sanitizers might confuse colon as option separator.
external_symbolizer_path = '"%s.exe"' % external_symbolizer_path
symbolizer = 'external_symbolizer_path=%s' % external_symbolizer_path
if self.build_config.asan:
asan_options = [symbolizer, "allow_user_segv_handler=1"]
if not utils.GuessOS() in ['macos', 'windows']:
# LSAN is not available on mac and windows.
asan_options.append('detect_leaks=1')
os.environ['ASAN_OPTIONS'] = ":".join(asan_options)
if self.sancov_dir: if options.sancov_dir:
assert os.path.exists(options.sancov_dir)
os.environ['ASAN_OPTIONS'] = ":".join([ os.environ['ASAN_OPTIONS'] = ":".join([
'coverage=1', 'coverage=1',
'coverage_dir=%s' % self.sancov_dir, 'coverage_dir=%s' % options.sancov_dir,
symbolizer_option, symbolizer,
"allow_user_segv_handler=1", "allow_user_segv_handler=1",
]) ])
if self.build_config.cfi_vptr:
os.environ['UBSAN_OPTIONS'] = ":".join([
'print_stacktrace=1',
'print_summary=1',
'symbolize=1',
symbolizer,
])
if self.build_config.ubsan_vptr:
os.environ['UBSAN_OPTIONS'] = ":".join([
'print_stacktrace=1',
symbolizer,
])
if self.build_config.msan:
os.environ['MSAN_OPTIONS'] = symbolizer
if self.build_config.tsan:
suppressions_file = os.path.join(
base_runner.BASE_DIR,
'tools',
'sanitizers',
'tsan_suppressions.txt')
os.environ['TSAN_OPTIONS'] = " ".join([
symbolizer,
'suppressions=%s' % suppressions_file,
'exit_code=0',
'report_thread_leaks=0',
'history_size=7',
'report_destroy_locked=0',
])
def _random_seed(self): def _random_seed(self):
seed = 0 seed = 0
while not seed: while not seed:
...@@ -392,7 +446,7 @@ class StandardTestRunner(base_runner.BaseTestRunner): ...@@ -392,7 +446,7 @@ class StandardTestRunner(base_runner.BaseTestRunner):
self.build_config.predictable, self.build_config.predictable,
options.no_harness, options.no_harness,
use_perf_data=not options.swarming, use_perf_data=not options.swarming,
sancov_dir=self.sancov_dir) sancov_dir=options.sancov_dir)
# TODO(all): Combine "simulator" and "simulator_run". # TODO(all): Combine "simulator" and "simulator_run".
# TODO(machenbach): In GN we can derive simulator run from # TODO(machenbach): In GN we can derive simulator run from
...@@ -539,7 +593,7 @@ class StandardTestRunner(base_runner.BaseTestRunner): ...@@ -539,7 +593,7 @@ class StandardTestRunner(base_runner.BaseTestRunner):
"generated with failure information.") "generated with failure information.")
exit_code = 0 exit_code = 0
if self.sancov_dir: if options.sancov_dir:
# If tests ran with sanitizer coverage, merge coverage files in the end. # If tests ran with sanitizer coverage, merge coverage files in the end.
try: try:
print "Merging sancov files." print "Merging sancov files."
...@@ -547,7 +601,7 @@ class StandardTestRunner(base_runner.BaseTestRunner): ...@@ -547,7 +601,7 @@ class StandardTestRunner(base_runner.BaseTestRunner):
sys.executable, sys.executable,
join( join(
base_runner.BASE_DIR, "tools", "sanitizers", "sancov_merger.py"), base_runner.BASE_DIR, "tools", "sanitizers", "sancov_merger.py"),
"--coverage-dir=%s" % self.sancov_dir]) "--coverage-dir=%s" % options.sancov_dir])
except: except:
print >> sys.stderr, "Error: Merging sancov files failed." print >> sys.stderr, "Error: Merging sancov files failed."
exit_code = 1 exit_code = 1
......
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