summaryrefslogtreecommitdiffstats
path: root/Lib/test
diff options
context:
space:
mode:
authorEli Bendersky <eliben@gmail.com>2013-09-15 19:08:14 (GMT)
committerEli Bendersky <eliben@gmail.com>2013-09-15 19:08:14 (GMT)
commite207e38c5354489520be72460e6dcad11d76f937 (patch)
tree36b76de62cdd4a7995a3623fe8f8b3fe3430a7f6 /Lib/test
parent35532c86f540983d6a2d476722bd0bfc8af35434 (diff)
downloadcpython-e207e38c5354489520be72460e6dcad11d76f937.zip
cpython-e207e38c5354489520be72460e6dcad11d76f937.tar.gz
cpython-e207e38c5354489520be72460e6dcad11d76f937.tar.bz2
Close #18945: Add tests for tempfile name collision handling.
Patch by Vlad Shcherbina
Diffstat (limited to 'Lib/test')
-rw-r--r--Lib/test/test_tempfile.py87
1 files changed, 65 insertions, 22 deletions
diff --git a/Lib/test/test_tempfile.py b/Lib/test/test_tempfile.py
index eb3e2b9..011e7d0 100644
--- a/Lib/test/test_tempfile.py
+++ b/Lib/test/test_tempfile.py
@@ -8,6 +8,7 @@ import shutil
import sys
import re
import warnings
+import contextlib
import unittest
from test import test_support as support
@@ -270,6 +271,22 @@ class test__get_candidate_names(TC):
test_classes.append(test__get_candidate_names)
+@contextlib.contextmanager
+def _inside_empty_temp_dir():
+ dir = tempfile.mkdtemp()
+ try:
+ with support.swap_attr(tempfile, 'tempdir', dir):
+ yield
+ finally:
+ support.rmtree(dir)
+
+
+def _mock_candidate_names(*names):
+ return support.swap_attr(tempfile,
+ '_get_candidate_names',
+ lambda: iter(names))
+
+
class test__mkstemp_inner(TC):
"""Test the internal function _mkstemp_inner."""
@@ -386,31 +403,36 @@ class test__mkstemp_inner(TC):
self.do_create(bin=0).write("blat\n")
# XXX should test that the file really is a text file
+ def default_mkstemp_inner(self):
+ return tempfile._mkstemp_inner(tempfile.gettempdir(),
+ tempfile.template,
+ '',
+ tempfile._bin_openflags)
+
+ def test_collision_with_existing_file(self):
+ # _mkstemp_inner tries another name when a file with
+ # the chosen name already exists
+ with _inside_empty_temp_dir(), \
+ _mock_candidate_names('aaa', 'aaa', 'bbb'):
+ (fd1, name1) = self.default_mkstemp_inner()
+ os.close(fd1)
+ self.assertTrue(name1.endswith('aaa'))
+
+ (fd2, name2) = self.default_mkstemp_inner()
+ os.close(fd2)
+ self.assertTrue(name2.endswith('bbb'))
+
def test_collision_with_existing_directory(self):
# _mkstemp_inner tries another name when a directory with
# the chosen name already exists
- container_dir = tempfile.mkdtemp()
- try:
- def mock_get_candidate_names():
- return iter(['aaa', 'aaa', 'bbb'])
- with support.swap_attr(tempfile,
- '_get_candidate_names',
- mock_get_candidate_names):
- dir = tempfile.mkdtemp(dir=container_dir)
- self.assertTrue(dir.endswith('aaa'))
-
- flags = tempfile._bin_openflags
- (fd, name) = tempfile._mkstemp_inner(container_dir,
- tempfile.template,
- '',
- flags)
- try:
- self.assertTrue(name.endswith('bbb'))
- finally:
- os.close(fd)
- os.unlink(name)
- finally:
- support.rmtree(container_dir)
+ with _inside_empty_temp_dir(), \
+ _mock_candidate_names('aaa', 'aaa', 'bbb'):
+ dir = tempfile.mkdtemp()
+ self.assertTrue(dir.endswith('aaa'))
+
+ (fd, name) = self.default_mkstemp_inner()
+ os.close(fd)
+ self.assertTrue(name.endswith('bbb'))
test_classes.append(test__mkstemp_inner)
@@ -587,6 +609,27 @@ class test_mkdtemp(TC):
finally:
os.rmdir(dir)
+ def test_collision_with_existing_file(self):
+ # mkdtemp tries another name when a file with
+ # the chosen name already exists
+ with _inside_empty_temp_dir(), \
+ _mock_candidate_names('aaa', 'aaa', 'bbb'):
+ file = tempfile.NamedTemporaryFile(delete=False)
+ file.close()
+ self.assertTrue(file.name.endswith('aaa'))
+ dir = tempfile.mkdtemp()
+ self.assertTrue(dir.endswith('bbb'))
+
+ def test_collision_with_existing_directory(self):
+ # mkdtemp tries another name when a directory with
+ # the chosen name already exists
+ with _inside_empty_temp_dir(), \
+ _mock_candidate_names('aaa', 'aaa', 'bbb'):
+ dir1 = tempfile.mkdtemp()
+ self.assertTrue(dir1.endswith('aaa'))
+ dir2 = tempfile.mkdtemp()
+ self.assertTrue(dir2.endswith('bbb'))
+
test_classes.append(test_mkdtemp)