diff options
author | Ned Batchelder <ned@nedbatchelder.com> | 2016-01-31 18:39:49 -0500 |
---|---|---|
committer | Ned Batchelder <ned@nedbatchelder.com> | 2016-01-31 18:39:49 -0500 |
commit | 6395e5ca5120712b36269c549ea1ac82ca4b8e60 (patch) | |
tree | c08794892157e2b867f71217eeb6d07b69b2c355 /coverage/data.py | |
parent | 7d1cf64be239124befc698a696771a842be17794 (diff) | |
download | python-coveragepy-6395e5ca5120712b36269c549ea1ac82ca4b8e60.tar.gz |
Yield statements that are not resumed shouldn't be marked as missing. #440
Diffstat (limited to 'coverage/data.py')
-rw-r--r-- | coverage/data.py | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/coverage/data.py b/coverage/data.py index 17cf73c..60e104d 100644 --- a/coverage/data.py +++ b/coverage/data.py @@ -4,6 +4,7 @@ """Coverage data for coverage.py.""" import glob +import itertools import json import optparse import os @@ -178,11 +179,12 @@ class CoverageData(object): """ if self._arcs is not None: - if filename in self._arcs: - return [s for s, __ in self._arcs[filename] if s > 0] + arcs = self._arcs.get(filename) + if arcs is not None: + all_lines = itertools.chain.from_iterable(arcs) + return list(set(l for l in all_lines if l > 0)) elif self._lines is not None: - if filename in self._lines: - return self._lines[filename] + return self._lines.get(filename) return None def arcs(self, filename): |