diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2009-10-27 17:47:14 (GMT) |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2009-10-27 17:47:14 (GMT) |
commit | c66363f5e0c38aeeeeb706cf0fa93fa1e63f53ee (patch) | |
tree | c384e3f018e105d6910b05d6269173b68281b4c1 /Lib | |
parent | 495f7b5adbe798447f12139ce7f870b7b4c06a6c (diff) | |
download | cpython-c66363f5e0c38aeeeeb706cf0fa93fa1e63f53ee.zip cpython-c66363f5e0c38aeeeeb706cf0fa93fa1e63f53ee.tar.gz cpython-c66363f5e0c38aeeeeb706cf0fa93fa1e63f53ee.tar.bz2 |
Merged revisions 75818 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r75818 | antoine.pitrou | 2009-10-27 18:41:58 +0100 (mar., 27 oct. 2009) | 3 lines
Issue #7205: Fix a possible deadlock when using a BZ2File object from several threads at once.
........
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/test/test_bz2.py | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/Lib/test/test_bz2.py b/Lib/test/test_bz2.py index 6715a02..9a9afa6 100644 --- a/Lib/test/test_bz2.py +++ b/Lib/test/test_bz2.py @@ -7,6 +7,7 @@ from io import BytesIO import os import subprocess import sys +import threading # Skip tests if the bz2 module doesn't exist. bz2 = support.import_module('bz2') @@ -282,6 +283,23 @@ class BZ2FileTest(BaseTest): else: self.fail("1/0 didn't raise an exception") + def testThreading(self): + # Using a BZ2File from several threads doesn't deadlock (issue #7205). + data = b"1" * 2**20 + nthreads = 10 + f = bz2.BZ2File(self.filename, 'wb') + try: + def comp(): + for i in range(5): + f.write(data) + threads = [threading.Thread(target=comp) for i in range(nthreads)] + for t in threads: + t.start() + for t in threads: + t.join() + finally: + f.close() + class BZ2CompressorTest(BaseTest): def testCompress(self): |