Merged revisions 84861 via svnmerge from

svn+ssh://pythondev@svn.python.org/python/branches/py3k

........
  r84861 | senthil.kumaran | 2010-09-17 22:05:37 +0530 (Fri, 17 Sep 2010) | 3 lines

  Fix Issue2236: Distutils' mkpath implementation ignoring the "mode" parameter
........
This commit is contained in:
Senthil Kumaran 2010-09-17 16:42:05 +00:00
parent ef1166ee81
commit d0ca013f25
2 changed files with 8 additions and 1 deletions

View File

@ -68,7 +68,7 @@ def mkpath(name, mode=0o777, verbose=1, dry_run=0):
if not dry_run: if not dry_run:
try: try:
os.mkdir(head) os.mkdir(head, mode)
created_dirs.append(head) created_dirs.append(head)
except OSError as exc: except OSError as exc:
raise DistutilsFileError( raise DistutilsFileError(

View File

@ -1,6 +1,7 @@
"""Tests for distutils.dir_util.""" """Tests for distutils.dir_util."""
import unittest import unittest
import os import os
import stat
import shutil import shutil
from distutils.dir_util import (mkpath, remove_tree, create_tree, copy_tree, from distutils.dir_util import (mkpath, remove_tree, create_tree, copy_tree,
@ -48,6 +49,12 @@ class DirUtilTestCase(support.TempdirManager, unittest.TestCase):
wanted = ["removing '%s' (and everything under it)" % self.root_target] wanted = ["removing '%s' (and everything under it)" % self.root_target]
self.assertEquals(self._logs, wanted) self.assertEquals(self._logs, wanted)
def test_mkpath_with_custom_mode(self):
mkpath(self.target, 0o700)
self.assertEqual(stat.S_IMODE(os.stat(self.target).st_mode), 0o700)
mkpath(self.target2, 0o555)
self.assertEqual(stat.S_IMODE(os.stat(self.target2).st_mode), 0o555)
def test_create_tree_verbosity(self): def test_create_tree_verbosity(self):
create_tree(self.root_target, ['one', 'two', 'three'], verbose=0) create_tree(self.root_target, ['one', 'two', 'three'], verbose=0)