diff options
author | Antoine Pitrou <solipsis@pitrou.net> | 2010-09-23 20:15:14 (GMT) |
---|---|---|
committer | Antoine Pitrou <solipsis@pitrou.net> | 2010-09-23 20:15:14 (GMT) |
commit | 605c29303133987a5a97f3ceb4a369e9771676b0 (patch) | |
tree | 6d14f8ca8548f2696b8fd026c2bce94801975a5b | |
parent | b09a3d69a614c767653a12428d1ac816f516f36e (diff) | |
download | cpython-605c29303133987a5a97f3ceb4a369e9771676b0.zip cpython-605c29303133987a5a97f3ceb4a369e9771676b0.tar.gz cpython-605c29303133987a5a97f3ceb4a369e9771676b0.tar.bz2 |
Further tarfile / test_tarfile cleanup
-rw-r--r-- | Lib/tarfile.py | 57 | ||||
-rw-r--r-- | Lib/test/test_tarfile.py | 3 |
2 files changed, 35 insertions, 25 deletions
diff --git a/Lib/tarfile.py b/Lib/tarfile.py index bfdba58..40109cd 100644 --- a/Lib/tarfile.py +++ b/Lib/tarfile.py @@ -410,28 +410,34 @@ class _Stream: self.pos = 0 self.closed = False - if comptype == "gz": - try: - import zlib - except ImportError: - raise CompressionError("zlib module is not available") - self.zlib = zlib - self.crc = zlib.crc32(b"") - if mode == "r": - self._init_read_gz() - else: - self._init_write_gz() + try: + if comptype == "gz": + try: + import zlib + except ImportError: + raise CompressionError("zlib module is not available") + self.zlib = zlib + self.crc = zlib.crc32(b"") + if mode == "r": + self._init_read_gz() + else: + self._init_write_gz() - if comptype == "bz2": - try: - import bz2 - except ImportError: - raise CompressionError("bz2 module is not available") - if mode == "r": - self.dbuf = b"" - self.cmp = bz2.BZ2Decompressor() - else: - self.cmp = bz2.BZ2Compressor() + if comptype == "bz2": + try: + import bz2 + except ImportError: + raise CompressionError("bz2 module is not available") + if mode == "r": + self.dbuf = b"" + self.cmp = bz2.BZ2Decompressor() + else: + self.cmp = bz2.BZ2Compressor() + except: + if not self._extfileobj: + self.fileobj.close() + self.closed = True + raise def __del__(self): if hasattr(self, "closed") and not self.closed: @@ -1729,9 +1735,12 @@ class TarFile(object): if filemode not in "rw": raise ValueError("mode must be 'r' or 'w'") - t = cls(name, filemode, - _Stream(name, filemode, comptype, fileobj, bufsize), - **kwargs) + stream = _Stream(name, filemode, comptype, fileobj, bufsize) + try: + t = cls(name, filemode, stream, **kwargs) + except: + stream.close() + raise t._extfileobj = False return t diff --git a/Lib/test/test_tarfile.py b/Lib/test/test_tarfile.py index a51b512..3a217dc 100644 --- a/Lib/test/test_tarfile.py +++ b/Lib/test/test_tarfile.py @@ -423,7 +423,8 @@ class DetectReadTest(unittest.TestCase): def _testfunc_fileobj(self, name, mode): try: - tar = tarfile.open(name, mode, fileobj=open(name, "rb")) + with open(name, "rb") as f: + tar = tarfile.open(name, mode, fileobj=f) except tarfile.ReadError as e: self.fail() else: |