From 41fa1065c69f55def87e3fcecad602076d7cd790 Mon Sep 17 00:00:00 2001 From: Ned Batchelder Date: Sun, 25 Oct 2009 09:38:58 -0400 Subject: Treat missing source files nicer. --- test/test_coverage.py | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) (limited to 'test/test_coverage.py') diff --git a/test/test_coverage.py b/test/test_coverage.py index b4d5752..92aef08 100644 --- a/test/test_coverage.py +++ b/test/test_coverage.py @@ -1725,6 +1725,28 @@ class ProcessTest(CoverageTest): data.read_file(".coverage") self.assertEqual(data.summary()['b_or_c.py'], 7) + def test_missing_source_file(self): + # Check what happens if the source is missing when reporting happens. + self.make_file("fleeting.py", """\ + s = 'goodbye, cruel world!' + """) + + self.run_command("coverage run fleeting.py") + os.remove("fleeting.py") + out = self.run_command("coverage html -d htmlcov") + self.assert_matches(out, "No source for code: '.*fleeting.py'") + self.assert_("Traceback" not in out) + + # It happens that the code paths are different for *.py and other files. + self.make_file("fleeting", """\ + s = 'goodbye, cruel world!' + """) + + self.run_command("coverage run fleeting") + os.remove("fleeting") + out = self.run_command("coverage html -d htmlcov") + self.assert_matches(out, "No source for code: '.*fleeting'") + self.assert_("Traceback" not in out) class RecursionTest(CoverageTest): """Check what happens when recursive code gets near limits.""" -- cgit v1.2.1