From: Serhiy Storchaka Date: Tue, 11 Feb 2014 08:30:06 +0000 (+0200) Subject: Issue #19856: shutil.move() failed to move a directory to other directory X-Git-Tag: v2.7.7rc1~184 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=a4b9c878e41adcd057e8610c5847c7db0a614a6a;p=python Issue #19856: shutil.move() failed to move a directory to other directory on Windows if source name ends with os.altsep. --- diff --git a/Lib/shutil.py b/Lib/shutil.py index f8f0b7d843..e12f791fd1 100644 --- a/Lib/shutil.py +++ b/Lib/shutil.py @@ -259,7 +259,8 @@ def rmtree(path, ignore_errors=False, onerror=None): def _basename(path): # A basename() variant which first strips the trailing slash, if present. # Thus we always get the last component of the path, even for directories. - return os.path.basename(path.rstrip(os.path.sep)) + sep = os.path.sep + (os.path.altsep or '') + return os.path.basename(path.rstrip(sep)) def move(src, dst): """Recursively move a file or directory to another location. This is diff --git a/Lib/test/test_shutil.py b/Lib/test/test_shutil.py index 8160f41bff..0e811459fc 100644 --- a/Lib/test/test_shutil.py +++ b/Lib/test/test_shutil.py @@ -698,6 +698,15 @@ class TestMove(unittest.TestCase): self._check_move_dir(self.src_dir, self.dir_other_fs, os.path.join(self.dir_other_fs, os.path.basename(self.src_dir))) + def test_move_dir_sep_to_dir(self): + self._check_move_dir(self.src_dir + os.path.sep, self.dst_dir, + os.path.join(self.dst_dir, os.path.basename(self.src_dir))) + + @unittest.skipUnless(os.path.altsep, 'requires os.path.altsep') + def test_move_dir_altsep_to_dir(self): + self._check_move_dir(self.src_dir + os.path.altsep, self.dst_dir, + os.path.join(self.dst_dir, os.path.basename(self.src_dir))) + def test_existing_file_inside_dest_dir(self): # A file with the same name inside the destination dir already exists. with open(self.dst_file, "wb"): diff --git a/Misc/NEWS b/Misc/NEWS index f63d2a6c60..38d863081c 100644 --- a/Misc/NEWS +++ b/Misc/NEWS @@ -44,6 +44,9 @@ Core and Builtins Library ------- +- Issue #19856: shutil.move() failed to move a directory to other directory + on Windows if source name ends with os.altsep. + - Issue #14983: email.generator now always adds a line end after each MIME boundary marker, instead of doing so only when there is an epilogue. This fixes an RFC compliance bug and solves an issue with signed MIME parts.