[ci skip] add test framework reformat to .git-blame-ignore-revs
[scons.git] / test / runtest / print_time.py
blob3d49a97025d2c8decabe02f92be3d50071e86483
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 combination of a passing test, failing test, and no-result
28 test with no argument on the command line.
29 """
31 import os
32 import re
34 import TestCmd
35 import TestRuntest
37 pythonstring = re.escape(TestRuntest.pythonstring)
38 pythonflags = TestRuntest.pythonflags
39 test_fail_py = re.escape(os.path.join('test', 'fail.py'))
40 test_no_result_py = re.escape(os.path.join('test', 'no_result.py'))
41 test_pass_py = re.escape(os.path.join('test', 'pass.py'))
43 test = TestRuntest.TestRuntest(match=TestCmd.match_re)
44 test.subdir('test')
45 test.write_failing_test(['test', 'fail.py'])
46 test.write_no_result_test(['test', 'no_result.py'])
47 test.write_passing_test(['test', 'pass.py'])
49 expect_stdout = f"""\
50 {pythonstring}{pythonflags} {test_fail_py}
51 FAILING TEST STDOUT
52 Test execution time: \\d+.\\d seconds
53 {pythonstring}{pythonflags} {test_no_result_py}
54 NO RESULT TEST STDOUT
55 Test execution time: \\d+.\\d seconds
56 {pythonstring}{pythonflags} {test_pass_py}
57 PASSING TEST STDOUT
58 Test execution time: \\d+.\\d seconds
59 Total execution time for all tests: \\d+.\\d seconds
61 Failed the following test:
62 \t{test_fail_py}
64 NO RESULT from the following test:
65 \t{test_no_result_py}
66 """
68 expect_stderr = """\
69 FAILING TEST STDERR
70 NO RESULT TEST STDERR
71 PASSING TEST STDERR
72 """
74 test.run(arguments='-k -t test', status=1, stdout=expect_stdout, stderr=expect_stderr)
76 test.pass_test()
78 # Local Variables:
79 # tab-width:4
80 # indent-tabs-mode:nil
81 # End:
82 # vim: set expandtab tabstop=4 shiftwidth=4: