| # Tests that the crashers in the Lib/test/crashers directory actually |
| # do crash the interpreter as expected |
| # |
| # If a crasher is fixed, it should be moved elsewhere in the test suite to |
| # ensure it continues to work correctly. |
| |
| import unittest |
| import glob |
| import os.path |
| import test.support |
| from test.script_helper import assert_python_failure |
| |
| CRASHER_DIR = os.path.join(os.path.dirname(__file__), "crashers") |
| CRASHER_FILES = os.path.join(CRASHER_DIR, "*.py") |
| |
| infinite_loops = ["infinite_loop_re.py", "nasty_eq_vs_dict.py"] |
| |
| class CrasherTest(unittest.TestCase): |
| |
| @unittest.skip("these tests are too fragile") |
| @test.support.cpython_only |
| def test_crashers_crash(self): |
| for fname in glob.glob(CRASHER_FILES): |
| if os.path.basename(fname) in infinite_loops: |
| continue |
| # Some "crashers" only trigger an exception rather than a |
| # segfault. Consider that an acceptable outcome. |
| if test.support.verbose: |
| print("Checking crasher:", fname) |
| assert_python_failure(fname) |
| |
| |
| def test_main(): |
| test.support.run_unittest(CrasherTest) |
| test.support.reap_children() |
| |
| if __name__ == "__main__": |
| test_main() |