Merged revisions 81663 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r81663 | lars.gustaebel | 2010-06-03 11:56:22 +0200 (Thu, 03 Jun 2010) | 4 lines Issue #8833: tarfile created hard link entries with a size field != 0 by mistake. The associated testcase did not expose this bug because it was broken too. ........
This commit is contained in:
parent
e036af0ce5
commit
9bcbe49ba1
|
@ -1880,7 +1880,7 @@ class TarFile(object):
|
|||
tarinfo.mode = stmd
|
||||
tarinfo.uid = statres.st_uid
|
||||
tarinfo.gid = statres.st_gid
|
||||
if stat.S_ISREG(stmd):
|
||||
if type == REGTYPE:
|
||||
tarinfo.size = statres.st_size
|
||||
else:
|
||||
tarinfo.size = 0L
|
||||
|
|
|
@ -617,10 +617,14 @@ class WriteTest(WriteTestBase):
|
|||
if hasattr(os, "link"):
|
||||
link = os.path.join(TEMPDIR, "link")
|
||||
target = os.path.join(TEMPDIR, "link_target")
|
||||
open(target, "wb").close()
|
||||
fobj = open(target, "wb")
|
||||
fobj.write("aaa")
|
||||
fobj.close()
|
||||
os.link(target, link)
|
||||
try:
|
||||
tar = tarfile.open(tmpname, self.mode)
|
||||
# Record the link target in the inodes list.
|
||||
tar.gettarinfo(target)
|
||||
tarinfo = tar.gettarinfo(link)
|
||||
self.assertEqual(tarinfo.size, 0)
|
||||
finally:
|
||||
|
|
Loading…
Reference in New Issue