]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
Display the sanitizer config in the regrtest header. (#105301)
authorGregory P. Smith <greg@krypto.org>
Tue, 6 Jun 2023 06:36:36 +0000 (23:36 -0700)
committerGitHub <noreply@github.com>
Tue, 6 Jun 2023 06:36:36 +0000 (23:36 -0700)
Display the sanitizers present in libregrtest.

Having this in the CI output for tests with the relevant environment
variable displayed will help make it easier to do what we need to
create an equivalent local test run.

Lib/test/libregrtest/main.py
Lib/test/support/__init__.py

index 3c3509d030337143af4c79eff9ff129535f11a5d..9001ca33b6166aeab18d518721b3914584a25dae 100644 (file)
@@ -526,6 +526,26 @@ class Regrtest:
             print("== CPU count:", cpu_count)
         print("== encodings: locale=%s, FS=%s"
               % (locale.getencoding(), sys.getfilesystemencoding()))
+        asan = support.check_sanitizer(address=True)
+        msan = support.check_sanitizer(memory=True)
+        ubsan = support.check_sanitizer(ub=True)
+        # This makes it easier to remember what to set in your local
+        # environment when trying to reproduce a sanitizer failure.
+        if asan or msan or ubsan:
+            names = [n for n in (asan and "address",
+                                 msan and "memory",
+                                 ubsan and "undefined behavior")
+                     if n]
+            print(f"== sanitizers: {', '.join(names)}")
+            a_opts = os.environ.get("ASAN_OPTIONS")
+            if asan and a_opts is not None:
+                print(f"==  ASAN_OPTIONS={a_opts}")
+            m_opts = os.environ.get("ASAN_OPTIONS")
+            if msan and m_opts is not None:
+                print(f"==  MSAN_OPTIONS={m_opts}")
+            ub_opts = os.environ.get("UBSAN_OPTIONS")
+            if ubsan and ub_opts is not None:
+                print(f"==  UBSAN_OPTIONS={ub_opts}")
 
     def no_tests_run(self):
         return not any((self.good, self.bad, self.skipped, self.interrupted,
index fee834323888567788a4688aa58093f1e9c2d823..0b5ff3a5cf545b05115ea5cc0ffee62cb6368960 100644 (file)
@@ -414,7 +414,7 @@ def check_sanitizer(*, address=False, memory=False, ub=False):
     )
     address_sanitizer = (
         '-fsanitize=address' in _cflags or
-        '--with-memory-sanitizer' in _config_args
+        '--with-address-sanitizer' in _config_args
     )
     ub_sanitizer = (
         '-fsanitize=undefined' in _cflags or