Patch #1504073: Fix tarfile.open() for mode "r" with a fileobj argument.

Will backport to 2.5.
This commit is contained in:
Lars Gustäbel 2006-12-27 10:30:46 +00:00
parent 7166232399
commit a7ba6fc548
3 changed files with 17 additions and 0 deletions

View file

@ -1141,9 +1141,13 @@ class TarFile(object):
# Find out which *open() is appropriate for opening the file. # Find out which *open() is appropriate for opening the file.
for comptype in cls.OPEN_METH: for comptype in cls.OPEN_METH:
func = getattr(cls, cls.OPEN_METH[comptype]) func = getattr(cls, cls.OPEN_METH[comptype])
if fileobj is not None:
saved_pos = fileobj.tell()
try: try:
return func(name, "r", fileobj) return func(name, "r", fileobj)
except (ReadError, CompressionError): except (ReadError, CompressionError):
if fileobj is not None:
fileobj.seek(saved_pos)
continue continue
raise ReadError("file could not be opened successfully") raise ReadError("file could not be opened successfully")

View file

@ -648,6 +648,16 @@ class HeaderErrorTest(unittest.TestCase):
b = "a" + buf[1:] # manipulate the buffer, so checksum won't match. b = "a" + buf[1:] # manipulate the buffer, so checksum won't match.
self.assertRaises(tarfile.HeaderError, tarfile.TarInfo.frombuf, b) self.assertRaises(tarfile.HeaderError, tarfile.TarInfo.frombuf, b)
class OpenFileobjTest(BaseTest):
# Test for SF bug #1496501.
def test_opener(self):
fobj = StringIO.StringIO("foo\n")
try:
tarfile.open("", "r", fileobj=fobj)
except tarfile.ReadError:
self.assertEqual(fobj.tell(), 0, "fileobj's position has moved")
if bz2: if bz2:
# Bzip2 TestCases # Bzip2 TestCases
class ReadTestBzip2(ReadTestGzip): class ReadTestBzip2(ReadTestGzip):
@ -693,6 +703,7 @@ def test_main():
tests = [ tests = [
FileModeTest, FileModeTest,
HeaderErrorTest, HeaderErrorTest,
OpenFileobjTest,
ReadTest, ReadTest,
ReadStreamTest, ReadStreamTest,
ReadDetectTest, ReadDetectTest,

View file

@ -103,6 +103,8 @@ Core and builtins
Library Library
------- -------
- Patch #1504073: Fix tarfile.open() for mode "r" with a fileobj argument.
- Patch #1182394 from Shane Holloway: speed up HMAC.hexdigest. - Patch #1182394 from Shane Holloway: speed up HMAC.hexdigest.
- Patch #1262036: Prevent TarFiles from being added to themselves under - Patch #1262036: Prevent TarFiles from being added to themselves under