Issue #20238: TarFile opened with external fileobj and "w:gz" mode didn't

write complete output on close.
This commit is contained in:
Serhiy Storchaka 2014-01-18 15:53:39 +02:00
commit 7d68a1c921
3 changed files with 10 additions and 1 deletions

View File

@ -1618,7 +1618,7 @@ class TarFile(object):
if not extfileobj and fileobj is not None:
fileobj.close()
raise
t._extfileobj = extfileobj
t._extfileobj = False
return t
@classmethod

View File

@ -857,6 +857,12 @@ class WriteTestBase(TarTest):
tar.addfile(tarfile.TarInfo("foo"))
tar.close()
self.assertFalse(fobj.closed, "external fileobjs must never closed")
# Issue #20238: Incomplete gzip output with mode="w:gz"
data = fobj.getvalue()
del tar
support.gc_collect()
self.assertFalse(fobj.closed)
self.assertEqual(data, fobj.getvalue())
class WriteTest(WriteTestBase, unittest.TestCase):

View File

@ -25,6 +25,9 @@ Core and Builtins
Library
-------
- Issue #20238: TarFile opened with external fileobj and "w:gz" mode didn't
write complete output on close.
- Issue #20245: The open functions in the tarfile module now correctly handle
empty mode.