1lit - LLVM Integrated Tester 2============================ 3 4.. program:: lit 5 6SYNOPSIS 7-------- 8 9:program:`lit` [*options*] [*tests*] 10 11DESCRIPTION 12----------- 13 14:program:`lit` is a portable tool for executing LLVM and Clang style test 15suites, summarizing their results, and providing indication of failures. 16:program:`lit` is designed to be a lightweight testing tool with as simple a 17user interface as possible. 18 19:program:`lit` should be run with one or more *tests* to run specified on the 20command line. Tests can be either individual test files or directories to 21search for tests (see :ref:`test-discovery`). 22 23Each specified test will be executed (potentially in parallel) and once all 24tests have been run :program:`lit` will print summary information on the number 25of tests which passed or failed (see :ref:`test-status-results`). The 26:program:`lit` program will execute with a non-zero exit code if any tests 27fail. 28 29By default :program:`lit` will use a succinct progress display and will only 30print summary information for test failures. See :ref:`output-options` for 31options controlling the :program:`lit` progress display and output. 32 33:program:`lit` also includes a number of options for controlling how tests are 34executed (specific features may depend on the particular test format). See 35:ref:`execution-options` for more information. 36 37Finally, :program:`lit` also supports additional options for only running a 38subset of the options specified on the command line, see 39:ref:`selection-options` for more information. 40 41:program:`lit` parses options from the environment variable ``LIT_OPTS`` after 42parsing options from the command line. ``LIT_OPTS`` is primarily useful for 43supplementing or overriding the command-line options supplied to :program:`lit` 44by ``check`` targets defined by a project's build system. 45 46Users interested in the :program:`lit` architecture or designing a 47:program:`lit` testing implementation should see :ref:`lit-infrastructure`. 48 49GENERAL OPTIONS 50--------------- 51 52.. option:: -h, --help 53 54 Show the :program:`lit` help message. 55 56.. option:: -j N, --workers=N 57 58 Run ``N`` tests in parallel. By default, this is automatically chosen to 59 match the number of detected available CPUs. 60 61.. option:: --config-prefix=NAME 62 63 Search for :file:`{NAME}.cfg` and :file:`{NAME}.site.cfg` when searching for 64 test suites, instead of :file:`lit.cfg` and :file:`lit.site.cfg`. 65 66.. option:: -D NAME[=VALUE], --param NAME[=VALUE] 67 68 Add a user defined parameter ``NAME`` with the given ``VALUE`` (or the empty 69 string if not given). The meaning and use of these parameters is test suite 70 dependent. 71 72.. _output-options: 73 74OUTPUT OPTIONS 75-------------- 76 77.. option:: -q, --quiet 78 79 Suppress any output except for test failures. 80 81.. option:: -s, --succinct 82 83 Show less output, for example don't show information on tests that pass. 84 Also show a progress bar, unless ``--no-progress-bar`` is specified. 85 86.. option:: -v, --verbose 87 88 Show more information on test failures, for example the entire test output 89 instead of just the test result. 90 91.. option:: -vv, --echo-all-commands 92 93 Echo all commands to stdout, as they are being executed. 94 This can be valuable for debugging test failures, as the last echoed command 95 will be the one which has failed. 96 :program:`lit` normally inserts a no-op command (``:`` in the case of bash) 97 with argument ``'RUN: at line N'`` before each command pipeline, and this 98 option also causes those no-op commands to be echoed to stdout to help you 99 locate the source line of the failed command. 100 This option implies ``--verbose``. 101 102.. option:: -a, --show-all 103 104 Show more information about all tests, for example the entire test 105 commandline and output. 106 107.. option:: --no-progress-bar 108 109 Do not use curses based progress bar. 110 111.. option:: --show-unsupported 112 113 Show the names of unsupported tests. 114 115.. option:: --show-xfail 116 117 Show the names of tests that were expected to fail. 118 119.. _execution-options: 120 121EXECUTION OPTIONS 122----------------- 123 124.. option:: --path=PATH 125 126 Specify an additional ``PATH`` to use when searching for executables in tests. 127 128.. option:: --vg 129 130 Run individual tests under valgrind (using the memcheck tool). The 131 ``--error-exitcode`` argument for valgrind is used so that valgrind failures 132 will cause the program to exit with a non-zero status. 133 134 When this option is enabled, :program:`lit` will also automatically provide a 135 "``valgrind``" feature that can be used to conditionally disable (or expect 136 failure in) certain tests. 137 138.. option:: --vg-arg=ARG 139 140 When :option:`--vg` is used, specify an additional argument to pass to 141 :program:`valgrind` itself. 142 143.. option:: --vg-leak 144 145 When :option:`--vg` is used, enable memory leak checks. When this option is 146 enabled, :program:`lit` will also automatically provide a "``vg_leak``" 147 feature that can be used to conditionally disable (or expect failure in) 148 certain tests. 149 150.. option:: --time-tests 151 152 Track the wall time individual tests take to execute and includes the results 153 in the summary output. This is useful for determining which tests in a test 154 suite take the most time to execute. Note that this option is most useful 155 with ``-j 1``. 156 157.. _selection-options: 158 159SELECTION OPTIONS 160----------------- 161 162.. option:: --max-failures N 163 164 Stop execution after the given number ``N`` of failures. 165 An integer argument should be passed on the command line 166 prior to execution. 167 168.. option:: --max-tests=N 169 170 Run at most ``N`` tests and then terminate. 171 172.. option:: --max-time=N 173 174 Spend at most ``N`` seconds (approximately) running tests and then terminate. 175 Note that this is not an alias for :option:`--timeout`; the two are 176 different kinds of maximums. 177 178.. option:: --num-shards=M 179 180 Divide the set of selected tests into ``M`` equal-sized subsets or 181 "shards", and run only one of them. Must be used with the 182 ``--run-shard=N`` option, which selects the shard to run. The environment 183 variable ``LIT_NUM_SHARDS`` can also be used in place of this 184 option. These two options provide a coarse mechanism for partitioning large 185 testsuites, for parallel execution on separate machines (say in a large 186 testing farm). 187 188.. option:: --run-shard=N 189 190 Select which shard to run, assuming the ``--num-shards=M`` option was 191 provided. The two options must be used together, and the value of ``N`` 192 must be in the range ``1..M``. The environment variable 193 ``LIT_RUN_SHARD`` can also be used in place of this option. 194 195.. option:: --shuffle 196 197 Run the tests in a random order. 198 199.. option:: --timeout=N 200 201 Spend at most ``N`` seconds (approximately) running each individual test. 202 ``0`` means no time limit, and ``0`` is the default. Note that this is not an 203 alias for :option:`--max-time`; the two are different kinds of maximums. 204 205.. option:: --filter=REGEXP 206 207 Run only those tests whose name matches the regular expression specified in 208 ``REGEXP``. The environment variable ``LIT_FILTER`` can be also used in place 209 of this option, which is especially useful in environments where the call 210 to ``lit`` is issued indirectly. 211 212ADDITIONAL OPTIONS 213------------------ 214 215.. option:: --debug 216 217 Run :program:`lit` in debug mode, for debugging configuration issues and 218 :program:`lit` itself. 219 220.. option:: --show-suites 221 222 List the discovered test suites and exit. 223 224.. option:: --show-tests 225 226 List all of the discovered tests and exit. 227 228EXIT STATUS 229----------- 230 231:program:`lit` will exit with an exit code of 1 if there are any FAIL or XPASS 232results. Otherwise, it will exit with the status 0. Other exit codes are used 233for non-test related failures (for example a user error or an internal program 234error). 235 236.. _test-discovery: 237 238TEST DISCOVERY 239-------------- 240 241The inputs passed to :program:`lit` can be either individual tests, or entire 242directories or hierarchies of tests to run. When :program:`lit` starts up, the 243first thing it does is convert the inputs into a complete list of tests to run 244as part of *test discovery*. 245 246In the :program:`lit` model, every test must exist inside some *test suite*. 247:program:`lit` resolves the inputs specified on the command line to test suites 248by searching upwards from the input path until it finds a :file:`lit.cfg` or 249:file:`lit.site.cfg` file. These files serve as both a marker of test suites 250and as configuration files which :program:`lit` loads in order to understand 251how to find and run the tests inside the test suite. 252 253Once :program:`lit` has mapped the inputs into test suites it traverses the 254list of inputs adding tests for individual files and recursively searching for 255tests in directories. 256 257This behavior makes it easy to specify a subset of tests to run, while still 258allowing the test suite configuration to control exactly how tests are 259interpreted. In addition, :program:`lit` always identifies tests by the test 260suite they are in, and their relative path inside the test suite. For 261appropriately configured projects, this allows :program:`lit` to provide 262convenient and flexible support for out-of-tree builds. 263 264.. _test-status-results: 265 266TEST STATUS RESULTS 267------------------- 268 269Each test ultimately produces one of the following eight results: 270 271**PASS** 272 273 The test succeeded. 274 275**FLAKYPASS** 276 277 The test succeeded after being re-run more than once. This only applies to 278 tests containing an ``ALLOW_RETRIES:`` annotation. 279 280**XFAIL** 281 282 The test failed, but that is expected. This is used for test formats which allow 283 specifying that a test does not currently work, but wish to leave it in the test 284 suite. 285 286**XPASS** 287 288 The test succeeded, but it was expected to fail. This is used for tests which 289 were specified as expected to fail, but are now succeeding (generally because 290 the feature they test was broken and has been fixed). 291 292**FAIL** 293 294 The test failed. 295 296**UNRESOLVED** 297 298 The test result could not be determined. For example, this occurs when the test 299 could not be run, the test itself is invalid, or the test was interrupted. 300 301**UNSUPPORTED** 302 303 The test is not supported in this environment. This is used by test formats 304 which can report unsupported tests. 305 306**TIMEOUT** 307 308 The test was run, but it timed out before it was able to complete. This is 309 considered a failure. 310 311Depending on the test format tests may produce additional information about 312their status (generally only for failures). See the :ref:`output-options` 313section for more information. 314 315.. _lit-infrastructure: 316 317LIT INFRASTRUCTURE 318------------------ 319 320This section describes the :program:`lit` testing architecture for users interested in 321creating a new :program:`lit` testing implementation, or extending an existing one. 322 323:program:`lit` proper is primarily an infrastructure for discovering and running 324arbitrary tests, and to expose a single convenient interface to these 325tests. :program:`lit` itself doesn't know how to run tests, rather this logic is 326defined by *test suites*. 327 328TEST SUITES 329~~~~~~~~~~~ 330 331As described in :ref:`test-discovery`, tests are always located inside a *test 332suite*. Test suites serve to define the format of the tests they contain, the 333logic for finding those tests, and any additional information to run the tests. 334 335:program:`lit` identifies test suites as directories containing ``lit.cfg`` or 336``lit.site.cfg`` files (see also :option:`--config-prefix`). Test suites are 337initially discovered by recursively searching up the directory hierarchy for 338all the input files passed on the command line. You can use 339:option:`--show-suites` to display the discovered test suites at startup. 340 341Once a test suite is discovered, its config file is loaded. Config files 342themselves are Python modules which will be executed. When the config file is 343executed, two important global variables are predefined: 344 345**lit_config** 346 347 The global **lit** configuration object (a *LitConfig* instance), which defines 348 the builtin test formats, global configuration parameters, and other helper 349 routines for implementing test configurations. 350 351**config** 352 353 This is the config object (a *TestingConfig* instance) for the test suite, 354 which the config file is expected to populate. The following variables are also 355 available on the *config* object, some of which must be set by the config and 356 others are optional or predefined: 357 358 **name** *[required]* The name of the test suite, for use in reports and 359 diagnostics. 360 361 **test_format** *[required]* The test format object which will be used to 362 discover and run tests in the test suite. Generally this will be a builtin test 363 format available from the *lit.formats* module. 364 365 **test_source_root** The filesystem path to the test suite root. For out-of-dir 366 builds this is the directory that will be scanned for tests. 367 368 **test_exec_root** For out-of-dir builds, the path to the test suite root inside 369 the object directory. This is where tests will be run and temporary output files 370 placed. 371 372 **environment** A dictionary representing the environment to use when executing 373 tests in the suite. 374 375 **suffixes** For **lit** test formats which scan directories for tests, this 376 variable is a list of suffixes to identify test files. Used by: *ShTest*. 377 378 **substitutions** For **lit** test formats which substitute variables into a test 379 script, the list of substitutions to perform. Used by: *ShTest*. 380 381 **unsupported** Mark an unsupported directory, all tests within it will be 382 reported as unsupported. Used by: *ShTest*. 383 384 **parent** The parent configuration, this is the config object for the directory 385 containing the test suite, or None. 386 387 **root** The root configuration. This is the top-most :program:`lit` configuration in 388 the project. 389 390 **pipefail** Normally a test using a shell pipe fails if any of the commands 391 on the pipe fail. If this is not desired, setting this variable to false 392 makes the test fail only if the last command in the pipe fails. 393 394 **available_features** A set of features that can be used in `XFAIL`, 395 `REQUIRES`, and `UNSUPPORTED` directives. 396 397TEST DISCOVERY 398~~~~~~~~~~~~~~ 399 400Once test suites are located, :program:`lit` recursively traverses the source 401directory (following *test_source_root*) looking for tests. When :program:`lit` 402enters a sub-directory, it first checks to see if a nested test suite is 403defined in that directory. If so, it loads that test suite recursively, 404otherwise it instantiates a local test config for the directory (see 405:ref:`local-configuration-files`). 406 407Tests are identified by the test suite they are contained within, and the 408relative path inside that suite. Note that the relative path may not refer to 409an actual file on disk; some test formats (such as *GoogleTest*) define 410"virtual tests" which have a path that contains both the path to the actual 411test file and a subpath to identify the virtual test. 412 413.. _local-configuration-files: 414 415LOCAL CONFIGURATION FILES 416~~~~~~~~~~~~~~~~~~~~~~~~~ 417 418When :program:`lit` loads a subdirectory in a test suite, it instantiates a 419local test configuration by cloning the configuration for the parent directory 420--- the root of this configuration chain will always be a test suite. Once the 421test configuration is cloned :program:`lit` checks for a *lit.local.cfg* file 422in the subdirectory. If present, this file will be loaded and can be used to 423specialize the configuration for each individual directory. This facility can 424be used to define subdirectories of optional tests, or to change other 425configuration parameters --- for example, to change the test format, or the 426suffixes which identify test files. 427 428SUBSTITUTIONS 429~~~~~~~~~~~~~ 430 431:program:`lit` allows patterns to be substituted inside RUN commands. It also 432provides the following base set of substitutions, which are defined in 433TestRunner.py: 434 435 ======================= ============== 436 Macro Substitution 437 ======================= ============== 438 %s source path (path to the file currently being run) 439 %S source dir (directory of the file currently being run) 440 %p same as %S 441 %{pathsep} path separator 442 %t temporary file name unique to the test 443 %basename_t The last path component of %t but without the ``.tmp`` extension 444 %T parent directory of %t (not unique, deprecated, do not use) 445 %% % 446 %/s %s but ``\`` is replaced by ``/`` 447 %/S %S but ``\`` is replaced by ``/`` 448 %/p %p but ``\`` is replaced by ``/`` 449 %/t %t but ``\`` is replaced by ``/`` 450 %/T %T but ``\`` is replaced by ``/`` 451 %{/s:regex_replacement} %/s but escaped for use in the replacement of a ``s@@@`` command in sed 452 %{/S:regex_replacement} %/S but escaped for use in the replacement of a ``s@@@`` command in sed 453 %{/p:regex_replacement} %/p but escaped for use in the replacement of a ``s@@@`` command in sed 454 %{/t:regex_replacement} %/t but escaped for use in the replacement of a ``s@@@`` command in sed 455 %{/T:regex_replacement} %/T but escaped for use in the replacement of a ``s@@@`` command in sed 456 %:s On Windows, %/s but a ``:`` is removed if its the second character. 457 Otherwise, %s but with a single leading ``/`` removed. 458 %:S On Windows, %/S but a ``:`` is removed if its the second character. 459 Otherwise, %S but with a single leading ``/`` removed. 460 %:p On Windows, %/p but a ``:`` is removed if its the second character. 461 Otherwise, %p but with a single leading ``/`` removed. 462 %:t On Windows, %/t but a ``:`` is removed if its the second character. 463 Otherwise, %t but with a single leading ``/`` removed. 464 %:T On Windows, %/T but a ``:`` is removed if its the second character. 465 Otherwise, %T but with a single leading ``/`` removed. 466 ======================= ============== 467 468Other substitutions are provided that are variations on this base set and 469further substitution patterns can be defined by each test module. See the 470modules :ref:`local-configuration-files`. 471 472By default, substitutions are expanded exactly once, so that if e.g. a 473substitution ``%build`` is defined in top of another substitution ``%cxx``, 474``%build`` will expand to ``%cxx`` textually, not to what ``%cxx`` expands to. 475However, if the ``recursiveExpansionLimit`` property of the ``TestingConfig`` 476is set to a non-negative integer, substitutions will be expanded recursively 477until that limit is reached. It is an error if the limit is reached and 478expanding substitutions again would yield a different result. 479 480More detailed information on substitutions can be found in the 481:doc:`../TestingGuide`. 482 483TEST RUN OUTPUT FORMAT 484~~~~~~~~~~~~~~~~~~~~~~ 485 486The :program:`lit` output for a test run conforms to the following schema, in 487both short and verbose modes (although in short mode no PASS lines will be 488shown). This schema has been chosen to be relatively easy to reliably parse by 489a machine (for example in buildbot log scraping), and for other tools to 490generate. 491 492Each test result is expected to appear on a line that matches: 493 494.. code-block:: none 495 496 <result code>: <test name> (<progress info>) 497 498where ``<result-code>`` is a standard test result such as PASS, FAIL, XFAIL, 499XPASS, UNRESOLVED, or UNSUPPORTED. The performance result codes of IMPROVED and 500REGRESSED are also allowed. 501 502The ``<test name>`` field can consist of an arbitrary string containing no 503newline. 504 505The ``<progress info>`` field can be used to report progress information such 506as (1/300) or can be empty, but even when empty the parentheses are required. 507 508Each test result may include additional (multiline) log information in the 509following format: 510 511.. code-block:: none 512 513 <log delineator> TEST '(<test name>)' <trailing delineator> 514 ... log message ... 515 <log delineator> 516 517where ``<test name>`` should be the name of a preceding reported test, ``<log 518delineator>`` is a string of "*" characters *at least* four characters long 519(the recommended length is 20), and ``<trailing delineator>`` is an arbitrary 520(unparsed) string. 521 522The following is an example of a test run output which consists of four tests A, 523B, C, and D, and a log message for the failing test C: 524 525.. code-block:: none 526 527 PASS: A (1 of 4) 528 PASS: B (2 of 4) 529 FAIL: C (3 of 4) 530 ******************** TEST 'C' FAILED ******************** 531 Test 'C' failed as a result of exit code 1. 532 ******************** 533 PASS: D (4 of 4) 534 535LIT EXAMPLE TESTS 536~~~~~~~~~~~~~~~~~ 537 538The :program:`lit` distribution contains several example implementations of 539test suites in the *ExampleTests* directory. 540 541SEE ALSO 542-------- 543 544valgrind(1) 545