f20adcde30
The silent and blacklisted selftests of testlib end in a qFatal(), to test its messaging is handled correctly. However, this prevents hooks in main() from saving coverage data when we're gathering that. So use a transient signal handler that longjmp()s back to a setjmp() just before the qFatal() to let the test complete normally (but, since qFatal() does something different on MS-Win, don't apply this to it). Note that testlib's internal FatalSignalHandler handles all fatal signals *except* SIGABRT, so this isn't over-riding it. (In any case, this restores the prior signal handler in setjmp()'s catch branch.) Added missing expected_silent.tap test output while checking that this change doesn't affect (the rest of) the test output. Change-Id: I7e460581ad93e26639c066b3229438a66fd299de Reviewed-by: Tor Arne Vestbø <tor.arne.vestbo@qt.io>
43 lines
1.4 KiB
Plaintext
43 lines
1.4 KiB
Plaintext
TAP version 13
|
|
# tst_Silent
|
|
ok 1 - initTestCase()
|
|
ok 2 - pass()
|
|
ok 3 - skip() # SKIP This test should skip
|
|
not ok 4 - fail()
|
|
---
|
|
type: QVERIFY
|
|
message: This test should fail
|
|
wanted: true (false)
|
|
found: false (false)
|
|
expected: true (false)
|
|
actual: false (false)
|
|
at: tst_Silent::fail() (qtbase/tests/auto/testlib/selftests/silent/tst_silent.cpp:60)
|
|
file: qtbase/tests/auto/testlib/selftests/silent/tst_silent.cpp
|
|
line: 60
|
|
...
|
|
not ok 5 - xfail() # TODO This test should XFAIL
|
|
---
|
|
at: tst_Silent::xfail() (qtbase/tests/auto/testlib/selftests/silent/tst_silent.cpp:66)
|
|
file: qtbase/tests/auto/testlib/selftests/silent/tst_silent.cpp
|
|
line: 66
|
|
...
|
|
ok 6 - xpass() # TODO 'true' returned TRUE unexpectedly. (This test should XPASS)
|
|
# This is a warning that should not appear in silent test output
|
|
# This is an internal testlib warning that should not appear in silent test output
|
|
# This is a debug message that should not appear in silent test output
|
|
# This is a critical message that should not appear in silent test output
|
|
# This is an info message that should not appear in silent test output
|
|
# This is an internal testlib info message that should not appear in silent test output
|
|
# This is a fatal error message that should still appear in silent test output
|
|
not ok 7 - messages()
|
|
---
|
|
# Received a fatal error.
|
|
at: tst_Silent::messages() (Unknown file:0)
|
|
file: Unknown file
|
|
line: 0
|
|
...
|
|
1..7
|
|
# tests 7
|
|
# pass 3
|
|
# fail 3
|