summaryrefslogtreecommitdiffstats
path: root/Help/prop_test/PASS_REGULAR_EXPRESSION.rst
blob: 9f92491d0fde6d1842688256428a523f7406a808 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
PASS_REGULAR_EXPRESSION
-----------------------

The test output (stdout or stderr) must match this regular expression
for the test to pass. The process exit code is ignored. Tests that exceed
the timeout specified by :prop_test:`TIMEOUT` still fail regardless of
``PASS_REGULAR_EXPRESSION``. System-level test failures including
segmentation faults, signal abort, or heap errors may fail the test even
if ``PASS_REGULAR_EXPRESSION`` is matched.

Example:

.. code-block:: cmake

  add_test(NAME mytest COMMAND ${CMAKE_COMMAND} -E echo "Passed this test")

  set_property(TEST mytest PROPERTY
    PASS_REGULAR_EXPRESSION "pass;Passed"
  )

``PASS_REGULAR_EXPRESSION`` expects a list of regular expressions.

To run a test that may have a system-level failure, but still pass if
``PASS_REGULAR_EXPRESSION`` matches, use a CMake command to wrap the
executable run. Note that this will prevent automatic handling of the
:prop_tgt:`CROSSCOMPILING_EMULATOR` target property.

.. code-block:: cmake

    add_executable(main main.c)

    add_test(NAME sigabrt COMMAND ${CMAKE_COMMAND} -E env $<TARGET_FILE:main>)

    set_property(TEST sigabrt PROPERTY PROPERTY_REGULAR_EXPRESSION "pass;Passed")

.. code-block:: c

    #include <signal.h>
    #include <stdio.h>

    int main(void){
        fprintf(stdout, "Passed\n");
        fflush(stdout);  /* ensure the output buffer is seen */
        raise(SIGABRT);
        return 0;
    }

See also the :prop_test:`FAIL_REGULAR_EXPRESSION` and
:prop_test:`SKIP_REGULAR_EXPRESSION` test properties.