summaryrefslogtreecommitdiff
path: root/coverage/collector.py
diff options
context:
space:
mode:
authorNed Batchelder <nedbat@gmail.com>2017-10-21 20:29:09 +0000
committerNed Batchelder <nedbat@gmail.com>2017-10-21 20:29:09 +0000
commit5e142b6c029f3a7672ff89a9883895622e8b57dc (patch)
treece0da676d10be369c077b7111787259af2f6f063 /coverage/collector.py
parent9e22cdaf8d1e1b39814d04c9b8badda4c0d4769a (diff)
parent6f79cf1d20452bfd6222410165e13a1b75e1b5bb (diff)
downloadpython-coveragepy-git-5e142b6c029f3a7672ff89a9883895622e8b57dc.tar.gz
Merged in ogrisel/coverage.py/fix-thread-safety (pull request #127)
FIX thread-safe Collector.save_data()
Diffstat (limited to 'coverage/collector.py')
-rw-r--r--coverage/collector.py5
1 files changed, 4 insertions, 1 deletions
diff --git a/coverage/collector.py b/coverage/collector.py
index 90c32756..cea341a1 100644
--- a/coverage/collector.py
+++ b/coverage/collector.py
@@ -375,7 +375,10 @@ class Collector(object):
def abs_file_dict(d):
"""Return a dict like d, but with keys modified by `abs_file`."""
- return dict((abs_file(k), v) for k, v in iitems(d))
+ # The call to list() ensures that the GIL protects the dictionary
+ # iterator against concurrent modifications by tracers running
+ # in other threads.
+ return dict((abs_file(k), v) for k, v in list(iitems(d)))
if self.branch:
covdata.add_arcs(abs_file_dict(self.data))