While investigating another issue, I noticed that `MaybeReexec()` never actually "re-executes via `execv()`" anymore. `DyldNeedsEnvVariable()` only returned true on macOS 10.10 and below. Usually, I try to avoid "unnecessary" cleanups (it's hard to be certain that there truly is no fallout), but I decided to do this one because: * I initially tricked myself into thinking that `MaybeReexec()` was relevant to my original investigation (instead of being dead code). * The deleted code itself is quite complicated. * Over time a few other things were mushed into `MaybeReexec()`: initializing `MonotonicNanoTime()`, verifying interceptors are working, and stripping the `DYLD_INSERT_LIBRARIES` env var to avoid problems when forking. * This platform-specific thing leaked into `sanitizer_common.h`. * The `ReexecDisabled()` config nob relies on the "strong overrides weak pattern", which is now problematic and can be completely removed. * `ReexecDisabled()` actually hid another issue with interceptors not working in unit tests. I added an explicit `verify_interceptors` (defaults to `true`) option instead. Differential Revision: https://reviews.llvm.org/D129157
41 lines
1.6 KiB
C++
41 lines
1.6 KiB
C++
//===-- asan_test_main.cpp ------------------------------------------------===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file is a part of AddressSanitizer, an address sanity checker.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
#include "asan_test_utils.h"
|
|
#include "sanitizer_common/sanitizer_platform.h"
|
|
|
|
// Default ASAN_OPTIONS for the unit tests.
|
|
extern "C" const char* __asan_default_options() {
|
|
#if SANITIZER_APPLE
|
|
// On Darwin, we default to `abort_on_error=1`, which would make tests run
|
|
// much slower. Let's override this and run lit tests with 'abort_on_error=0'
|
|
// and make sure we do not overwhelm the syslog while testing. Also, let's
|
|
// turn symbolization off to speed up testing, especially when not running
|
|
// with llvm-symbolizer but with atos.
|
|
return "symbolize=false:abort_on_error=0:log_to_syslog=0";
|
|
#elif SANITIZER_SUPPRESS_LEAK_ON_PTHREAD_EXIT
|
|
// On PowerPC and ARM Thumb, a couple tests involving pthread_exit fail due to
|
|
// leaks detected by LSan. Symbolized leak report is required to apply a
|
|
// suppression for this known problem.
|
|
return "";
|
|
#else
|
|
// Let's turn symbolization off to speed up testing (more than 3 times speedup
|
|
// observed).
|
|
return "symbolize=false";
|
|
#endif
|
|
}
|
|
|
|
int main(int argc, char **argv) {
|
|
testing::GTEST_FLAG(death_test_style) = "threadsafe";
|
|
testing::InitGoogleTest(&argc, argv);
|
|
return RUN_ALL_TESTS();
|
|
}
|