xref: /llvm-project/bolt/test/lit.cfg.py (revision d1df113e3056f6e82a292f624e33ccaa8c93e529)
1# -*- Python -*-
2
3import os
4import platform
5import re
6import subprocess
7import tempfile
8
9import lit.formats
10import lit.util
11
12from lit.llvm import llvm_config
13from lit.llvm.subst import ToolSubst
14from lit.llvm.subst import FindTool
15
16# Configuration file for the 'lit' test runner.
17
18# name: The name of this test suite.
19config.name = 'BOLT'
20
21# testFormat: The test format to use to interpret tests.
22#
23# For now we require '&&' between commands, until they get globally killed and
24# the test runner updated.
25config.test_format = lit.formats.ShTest(not llvm_config.use_lit_shell)
26
27# suffixes: A list of file extensions to treat as test files.
28config.suffixes = ['.c', '.cpp', '.cppm', '.m', '.mm', '.cu',
29                   '.ll', '.cl', '.s', '.S', '.modulemap', '.test', '.rs']
30
31# excludes: A list of directories to exclude from the testsuite. The 'Inputs'
32# subdirectories contain auxiliary inputs for various tests in their parent
33# directories.
34config.excludes = ['Inputs', 'CMakeLists.txt', 'README.txt', 'LICENSE.txt']
35
36# test_source_root: The root path where tests are located.
37config.test_source_root = os.path.dirname(__file__)
38
39# test_exec_root: The root path where tests should be run.
40config.test_exec_root = os.path.join(config.bolt_obj_root, 'test')
41
42# checking if maxIndividualTestTime is available on the platform and sets
43# it to 60sec if so, declares lit-max-individual-test-time feature for
44# further checking by tests.
45supported, errormsg = lit_config.maxIndividualTestTimeIsSupported
46if supported:
47    config.available_features.add("lit-max-individual-test-time")
48    lit_config.maxIndividualTestTime = 60
49else:
50    lit_config.warning('Setting a timeout per test not supported. ' + errormsg
51                       + ' Some tests will be skipped.')
52
53if config.bolt_enable_runtime:
54    config.available_features.add("bolt-runtime")
55
56llvm_config.use_default_substitutions()
57
58llvm_config.use_clang()
59llvm_config.use_lld()
60
61config.substitutions.append(('%cflags', '-no-pie'))
62config.substitutions.append(('%cxxflags', '-no-pie'))
63
64tool_dirs = [config.llvm_tools_dir,
65             config.test_source_root]
66
67tools = [
68    ToolSubst('llc', unresolved='fatal'),
69    ToolSubst('lld', unresolved='fatal'),
70    ToolSubst('llvm-dwarfdump', unresolved='fatal'),
71    ToolSubst('llvm-bolt', unresolved='fatal'),
72    ToolSubst('perf2bolt', unresolved='fatal'),
73    ToolSubst('yaml2obj', unresolved='fatal'),
74    ToolSubst('llvm-mc', unresolved='fatal'),
75    ToolSubst('llvm-nm', unresolved='fatal'),
76    ToolSubst('llvm-objdump', unresolved='fatal'),
77    ToolSubst('llvm-objcopy', unresolved='fatal'),
78    ToolSubst('llvm-strip', unresolved='fatal'),
79    ToolSubst('llvm-readelf', unresolved='fatal'),
80    ToolSubst('link_fdata', command=FindTool('link_fdata.sh'), unresolved='fatal'),
81    ToolSubst('merge-fdata', unresolved='fatal'),
82]
83llvm_config.add_tool_substitutions(tools, tool_dirs)
84
85def calculate_arch_features(arch_string):
86    features = []
87    for arch in arch_string.split():
88        features.append(arch.lower() + '-registered-target')
89    return features
90
91
92llvm_config.feature_config(
93    [('--assertion-mode', {'ON': 'asserts'}),
94     ('--cxxflags', {r'-D_GLIBCXX_DEBUG\b': 'libstdcxx-safe-mode'}),
95        ('--targets-built', calculate_arch_features)
96     ])
97