mirror of
https://github.com/crystalidea/qt6windows7.git
synced 2024-11-23 20:10:48 +08:00
72 lines
2.7 KiB
Plaintext
72 lines
2.7 KiB
Plaintext
|
||
Running the QtTestLib selftests with Catch2
|
||
===========================================
|
||
|
||
Catch2 [1] is a header only test framework that we use to allow
|
||
testing QtTestLib without relying on any part of testlib itself.
|
||
|
||
To run the test suite, execute 'make check' or './tst_selftests'
|
||
as normal. This should print:
|
||
|
||
===================================================================
|
||
All tests passed (2453 assertions in 5 test cases)
|
||
|
||
To run specific tests, first lists the available tests:
|
||
|
||
❯ ./tst_selftests -l
|
||
All available test cases:
|
||
Loggers support both old and new style arguments
|
||
Loggers can output to both file and stdout
|
||
Logging to file and stdout at the same time
|
||
All loggers can be enabled at the same time
|
||
Scenario: Test output of the loggers is as expected
|
||
5 test cases
|
||
|
||
Then pass the name of the test in quotes as the first argument:
|
||
|
||
❯ ./tst_selftests "Loggers support both old and new style arguments"
|
||
Filters: Loggers support both old and new style arguments
|
||
==================================================================
|
||
All tests passed (96 assertions in 1 test case)
|
||
|
||
You can find the tests in the sources as individual TEST_CASE
|
||
entries. Note that each of these tests run the tests once per
|
||
logger, and in the case of the test log check also all sub tests,
|
||
so the amount of actual test assertions is much higher than the
|
||
five tests listed above.
|
||
|
||
To see what the tests is actually doing, pass the -s option.
|
||
This will result in very verbose output. Each leaf test is
|
||
prefixed with a heading:
|
||
|
||
---------------------------------------------------------------
|
||
Given: The QTestLog::TAP logger
|
||
When: Passing arguments with new style
|
||
---------------------------------------------------------------
|
||
|
||
You can choose a specific subtest by passing the -c option:
|
||
|
||
❯ ./tst_selftests "Scenario: Test output of the loggers is as expected" \
|
||
-c "Given: The QTestLog::Plain logger" \
|
||
-c 'And given: The "skip" subtest'
|
||
|
||
It's possible to pass only the first -c options, to e.g. run all
|
||
tests with the Plain logger, but it's unfortunately not possible
|
||
to pass only the last -c option, to run the 'skip' subtest with
|
||
all loggers.
|
||
|
||
If a test fails it will print the expected, actual, and difference.
|
||
The test results are also left in a temporary directory for closer
|
||
inspection.
|
||
|
||
Add new tests by modifying selftest.pri and CMakeLists.txt, adding
|
||
a new subprogram.
|
||
|
||
Generating new test expectations is done using the python script
|
||
in this directory (generate_expected_output.py). In the future this
|
||
will be done with the --rebase option to ./tst_selftest, but this
|
||
is not fleshed out yet.
|
||
|
||
[1] https://github.com/catchorg/Catch2
|
||
|