diff options
author | Ned Batchelder <ned@nedbatchelder.com> | 2011-08-08 20:37:38 -0400 |
---|---|---|
committer | Ned Batchelder <ned@nedbatchelder.com> | 2011-08-08 20:37:38 -0400 |
commit | 829215d157dca64cd1d88be27908e73a084715a7 (patch) | |
tree | 4ea73ce6678a4ebd4be47e23ee58ae4603bedd70 /test/test_process.py | |
parent | cbf42dc7273bfb828c8124c7b7229be15c15b202 (diff) | |
download | python-coveragepy-git-829215d157dca64cd1d88be27908e73a084715a7.tar.gz |
A fullcoverage tracer that works. Events are stashed, then replayed when coverage is started.
Diffstat (limited to 'test/test_process.py')
-rw-r--r-- | test/test_process.py | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/test/test_process.py b/test/test_process.py index c32868be..e62fce22 100644 --- a/test/test_process.py +++ b/test/test_process.py @@ -292,3 +292,23 @@ class ProcessTest(CoverageTest): self.assertTrue("No module named no_such_module" in out) self.assertTrue("warning" not in out) + if sys.version_info >= (2, 7): # Need coverage runnable as a module. + def test_fullcoverage(self): + # fullcoverage is a trick to get stdlib modules measured from the + # very beginning of the process. Here we import os and then check + # how many lines are measured. + self.make_file("getenv.py", """\ + import os + print("FOOEY == %s" % os.getenv("FOOEY")) + """) + + fullcov = os.path.join(os.path.dirname(coverage.__file__), "fullcoverage") + self.set_environ("FOOEY", "BOO") + self.set_environ("PYTHONPATH", fullcov) + out = self.run_command("python -m coverage run -L getenv.py") + self.assertEqual(out, "FOOEY == BOO\n") + data = coverage.CoverageData() + data.read_file(".coverage") + # The actual number of lines in os.py executed when it is imported + # is 120 or so. Just running os.getenv executes about 5. + self.assertGreater(data.summary()['os.py'], 50) |