summaryrefslogtreecommitdiff
path: root/tests/test_debug.py
diff options
context:
space:
mode:
authorNed Batchelder <ned@nedbatchelder.com>2016-09-24 20:39:22 -0400
committerNed Batchelder <ned@nedbatchelder.com>2016-09-24 20:39:22 -0400
commit9be9c3d671b6af10ab2c7d2c3cacf72074b51ce0 (patch)
treec97fd823a38eaf60445b8bb98a369c0c430a8152 /tests/test_debug.py
parent0c642aea0842b72868293b2e9bbb34ed2aecb6ff (diff)
downloadpython-coveragepy-git-9be9c3d671b6af10ab2c7d2c3cacf72074b51ce0.tar.gz
Change the debug=callers test to something that will be coverable
Diffstat (limited to 'tests/test_debug.py')
-rw-r--r--tests/test_debug.py27
1 files changed, 15 insertions, 12 deletions
diff --git a/tests/test_debug.py b/tests/test_debug.py
index e80beecf..04d37d30 100644
--- a/tests/test_debug.py
+++ b/tests/test_debug.py
@@ -68,6 +68,7 @@ class DebugTraceTest(CoverageTest):
cov = coverage.Coverage(debug=debug)
cov._debug_file = debug_out
self.start_import_stop(cov, "f1")
+ cov.save()
out_lines = debug_out.getvalue().splitlines()
return out_lines
@@ -103,18 +104,20 @@ class DebugTraceTest(CoverageTest):
self.assertTrue(lines_matching(out_lines, pid_prefix + "Tracing "))
self.assertTrue(lines_matching(out_lines, pid_prefix + "Not tracing "))
- def test_debug_trace_callers(self):
- out_lines = self.f1_debug_output(["trace", "callers"])
-
- # For every "Tracing" or "Not tracing" message, there should be a stack
- # trace with a line like "_should_trace : /Users/ned/coverage/control.py @616"
- trace_messages = lines_matching(out_lines, r"^(T|Not t)racing ")
- should_trace_pattern = r"\s+_should_trace : .*coverage[/\\]control.py @\d+$"
- should_trace_frames = lines_matching(out_lines, should_trace_pattern)
- self.assertEqual(len(trace_messages), len(should_trace_frames))
-
- # The very last line should be a _should_trace frame.
- self.assertRegex(out_lines[-1], should_trace_pattern)
+ def test_debug_callers(self):
+ out_lines = self.f1_debug_output(["pid", "dataop", "dataio", "callers"])
+ print("\n".join(out_lines))
+ # For every real message, there should be a stack
+ # trace with a line like "f1_debug_output : /Users/ned/coverage/tests/test_debug.py @71"
+ real_messages = lines_matching(out_lines, r"^pid \d+: ")
+ frame_pattern = r"\s+f1_debug_output : .*tests[/\\]test_debug.py @\d+$"
+ frames = lines_matching(out_lines, frame_pattern)
+ self.assertEqual(len(real_messages), len(frames))
+
+ # The last message should be "Writing data", and the last frame should
+ # be write_file in data.py.
+ self.assertRegex(real_messages[-1], r"^pid \d+: Writing data")
+ self.assertRegex(out_lines[-1], r"\s+write_file : .*coverage[/\\]data.py @\d+$")
def test_debug_config(self):
out_lines = self.f1_debug_output(["config"])