mirror of
https://github.com/python/cpython.git
synced 2025-07-29 06:05:00 +00:00
Patch #1504073: Fix tarfile.open() for mode "r" with a fileobj argument.
Will backport to 2.5.
This commit is contained in:
parent
7166232399
commit
a7ba6fc548
3 changed files with 17 additions and 0 deletions
|
@ -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")
|
||||||
|
|
||||||
|
|
|
@ -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,
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue