[ci skip] add test framework reformat to .git-blame-ignore-revs
[scons.git] / test / runtest / faillog.py
blobf23b90bc714bc0dbab709ec929ca19e2e65a14d4
1 #!/usr/bin/env python
3 # MIT License
5 # Copyright The SCons Foundation
7 # Permission is hereby granted, free of charge, to any person obtaining
8 # a copy of this software and associated documentation files (the
9 # "Software"), to deal in the Software without restriction, including
10 # without limitation the rights to use, copy, modify, merge, publish,
11 # distribute, sublicense, and/or sell copies of the Software, and to
12 # permit persons to whom the Software is furnished to do so, subject to
13 # the following conditions:
15 # The above copyright notice and this permission notice shall be included
16 # in all copies or substantial portions of the Software.
18 # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY
19 # KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
20 # WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
21 # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
22 # LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
23 # OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
24 # WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
26 """
27 Test a list of tests in failed_tests.log to run with the --retry option
28 """
30 import os.path
32 import TestRuntest
34 pythonstring = TestRuntest.pythonstring
35 pythonflags = TestRuntest.pythonflags
36 test_fail_py = os.path.join('test', 'fail.py')
37 test_pass_py = os.path.join('test', 'pass.py')
39 test = TestRuntest.TestRuntest()
40 test.subdir('test')
41 test.write_failing_test(test_fail_py)
42 test.write_passing_test(test_pass_py)
44 expect_stdout = f"""\
45 {pythonstring}{pythonflags} {test_fail_py}
46 FAILING TEST STDOUT
47 {pythonstring}{pythonflags} {test_pass_py}
48 PASSING TEST STDOUT
50 Failed the following test:
51 \t{test_fail_py}
52 """
54 expect_stderr = """\
55 FAILING TEST STDERR
56 PASSING TEST STDERR
57 """
59 testlist = [
60 test_fail_py,
61 test_pass_py,
64 test.run(
65 arguments='-k --faillog=fail.log %s' % ' '.join(testlist),
66 status=1,
67 stdout=expect_stdout,
68 stderr=expect_stderr,
70 test.must_exist('fail.log')
71 test.must_contain('fail.log', test_fail_py)
72 test.must_not_exist('failed_tests.log')
74 test.pass_test()
76 # Local Variables:
77 # tab-width:4
78 # indent-tabs-mode:nil
79 # End:
80 # vim: set expandtab tabstop=4 shiftwidth=4: