12 from lit
.llvm
import llvm_config
14 # Configuration file for the 'lit' test runner.
16 # name: The name of this test suite.
19 # testFormat: The test format to use to interpret tests.
21 # For now we require '&&' between commands, until they get globally killed and the test runner updated.
22 config
.test_format
= lit
.formats
.ShTest(not llvm_config
.use_lit_shell
)
24 # suffixes: A list of file extensions to treat as test files.
25 config
.suffixes
= [".ll", ".s", ".test", ".yaml", ".objtxt"]
27 # excludes: A list of directories to exclude from the testsuite. The 'Inputs'
28 # subdirectories contain auxiliary inputs for various tests in their parent
30 config
.excludes
= ["Inputs"]
32 # test_source_root: The root path where tests are located.
33 config
.test_source_root
= os
.path
.dirname(__file__
)
35 config
.test_exec_root
= os
.path
.join(config
.lld_obj_root
, "test")
37 llvm_config
.use_default_substitutions()
58 llvm_config
.add_tool_substitutions(tool_patterns
)
60 # LLD tests tend to be flaky on NetBSD, so add some retries.
61 # We don't do this on other platforms because it's slower.
62 if platform
.system() in ["NetBSD"]:
63 config
.test_retry_attempts
= 2
65 # When running under valgrind, we mangle '-vg' onto the end of the triple so we
66 # can check it with XFAIL and XTARGET.
67 if lit_config
.useValgrind
:
68 config
.target_triple
+= "-vg"
70 llvm_config
.feature_config(
80 "LoongArch": "loongarch",
87 "WebAssembly": "wasm",
91 ("--assertion-mode", {"ON": "asserts"}),
95 # Set a fake constant version so that we get consistent output.
96 config
.environment
["LLD_VERSION"] = "LLD 1.0"
98 # LLD_IN_TEST determines how many times `main` is run inside each process, which
99 # lets us test that it's cleaning up after itself and resetting global state
100 # correctly (which is important for usage as a library).
101 run_lld_main_twice
= lit_config
.params
.get("RUN_LLD_MAIN_TWICE", False)
102 if not run_lld_main_twice
:
103 config
.environment
["LLD_IN_TEST"] = "1"
105 config
.environment
["LLD_IN_TEST"] = "2"
106 # Many ELF tests fail in this mode.
107 config
.excludes
.append("ELF")
108 # Some old Mach-O backend tests fail, and it's due for removal anyway.
109 config
.excludes
.append("mach-o")
110 # Some new Mach-O backend tests fail; give them a way to mark themselves
111 # unsupported in this mode.
112 config
.available_features
.add("main-run-twice")
114 # Indirectly check if the mt.exe Microsoft utility exists by searching for
115 # cvtres, which always accompanies it. Alternatively, check if we can use
116 # libxml2 to merge manifests.
117 if lit
.util
.which("cvtres", config
.environment
["PATH"]) or config
.have_libxml2
:
118 config
.available_features
.add("manifest_tool")
120 if config
.enable_backtrace
:
121 config
.available_features
.add("backtrace")
123 if config
.have_libxml2
:
124 config
.available_features
.add("libxml2")
126 if config
.have_dia_sdk
:
127 config
.available_features
.add("diasdk")
129 if config
.sizeof_void_p
== 8:
130 config
.available_features
.add("llvm-64-bits")
132 if config
.has_plugins
:
133 config
.available_features
.add("plugins")
135 if config
.build_examples
:
136 config
.available_features
.add("examples")
138 if config
.linked_bye_extension
:
139 config
.substitutions
.append(("%loadbye", ""))
140 config
.substitutions
.append(("%loadnewpmbye", ""))
142 config
.substitutions
.append(
145 "-load={}/Bye{}".format(config
.llvm_shlib_dir
, config
.llvm_shlib_ext
),
148 config
.substitutions
.append(
151 "-load-pass-plugin={}/Bye{}".format(
152 config
.llvm_shlib_dir
, config
.llvm_shlib_ext
157 tar_executable
= lit
.util
.which("tar", config
.environment
["PATH"])
161 tar_version
= subprocess
.Popen(
162 [tar_executable
, "--version"],
163 stdout
=subprocess
.PIPE
,
164 stderr
=subprocess
.PIPE
,
167 sout
, _
= tar_version
.communicate()
168 if "GNU tar" in sout
.decode():
169 config
.available_features
.add("gnutar")
171 # ELF tests expect the default target for ld.lld to be ELF.
172 if config
.ld_lld_default_mingw
:
173 config
.excludes
.append("ELF")