From: Lars Gustäbel Date: Thu, 29 Apr 2010 15:35:30 +0000 (+0000) Subject: Merged revisions 80616 via svnmerge from X-Git-Tag: v2.6.6rc1~384 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=b4a5bc9313b8838fb69ddc809b50b62f9494d4a9;p=python Merged revisions 80616 via svnmerge from svn+ssh://pythondev@svn.python.org/python/trunk ........ r80616 | lars.gustaebel | 2010-04-29 17:23:38 +0200 (Thu, 29 Apr 2010) | 4 lines Issue #8464: tarfile.open(name, mode="w|") no longer creates files with execute permissions set. ........ --- diff --git a/Lib/tarfile.py b/Lib/tarfile.py index 7643a0bc64..8c2d26b2e4 100644 --- a/Lib/tarfile.py +++ b/Lib/tarfile.py @@ -370,7 +370,7 @@ class _LowLevelFile: }[mode] if hasattr(os, "O_BINARY"): mode |= os.O_BINARY - self.fd = os.open(name, mode) + self.fd = os.open(name, mode, 0666) def close(self): os.close(self.fd) diff --git a/Lib/test/test_tarfile.py b/Lib/test/test_tarfile.py index e2682c44cc..786f57a914 100644 --- a/Lib/test/test_tarfile.py +++ b/Lib/test/test_tarfile.py @@ -703,6 +703,24 @@ class StreamWriteTest(WriteTestBase): self.assert_(data.count("\0") == tarfile.RECORDSIZE, "incorrect zero padding") + def test_file_mode(self): + # Test for issue #8464: Create files with correct + # permissions. + if sys.platform == "win32" or not hasattr(os, "umask"): + return + + if os.path.exists(tmpname): + os.remove(tmpname) + + original_umask = os.umask(0022) + try: + tar = tarfile.open(tmpname, self.mode) + tar.close() + mode = os.stat(tmpname).st_mode & 0777 + self.assertEqual(mode, 0644, "wrong file permissions") + finally: + os.umask(original_umask) + class GNUWriteTest(unittest.TestCase): # This testcase checks for correct creation of GNU Longname diff --git a/Misc/NEWS b/Misc/NEWS index af424706ca..16a419040d 100644 --- a/Misc/NEWS +++ b/Misc/NEWS @@ -33,6 +33,9 @@ Core and Builtins Library ------- +- Issue #8464: tarfile no longer creates files with execute permissions set + when mode="w|" is used. + - Issue #7834: Fix connect() of Bluetooth L2CAP sockets with recent versions of the Linux kernel. Patch by Yaniv Aknin.