##// END OF EJS Templates
Backport PR #4909: sort dictionary keys before comparison, ordering is not guaranteed...
Backport PR #4909: sort dictionary keys before comparison, ordering is not guaranteed failed for me on 1.x with nose.proxy.AssertionError: AssertionError: Lists differ: ['a', 'b'] != ['b', 'a'] (2to3 wraps a list around it)

File last commit:

r12204:f678391e
r14842:d84134e7
Show More
tempdir.py
148 lines | 4.7 KiB | text/x-python | PythonLexer
Fernando Perez
Add context manager for temporary directories from Python 3.2...
r3182 """TemporaryDirectory class, copied from Python 3.2.
This is copied from the stdlib and will be standard in Python 3.2 and onwards.
"""
MinRK
Backport PR #4018: Fix warning when running IPython.kernel tests...
r12204 from __future__ import print_function
Fernando Perez
Add context manager for temporary directories from Python 3.2...
r3182
Takafumi Arakaki
Do not use NamedTemporaryFile in handle_image_tempfile...
r8246 import os as _os
Fernando Perez
Add context manager for temporary directories from Python 3.2...
r3182 # This code should only be used in Python versions < 3.2, since after that we
# can rely on the stdlib itself.
try:
from tempfile import TemporaryDirectory
except ImportError:
from tempfile import mkdtemp, template
class TemporaryDirectory(object):
"""Create and return a temporary directory. This has the same
behavior as mkdtemp but can be used as a context manager. For
example:
with TemporaryDirectory() as tmpdir:
...
Upon exiting the context, the directory and everthing contained
in it are removed.
"""
def __init__(self, suffix="", prefix=template, dir=None):
self.name = mkdtemp(suffix, prefix, dir)
self._closed = False
def __enter__(self):
return self.name
MinRK
Backport PR #4018: Fix warning when running IPython.kernel tests...
r12204 def cleanup(self, _warn=False):
if self.name and not self._closed:
try:
self._rmtree(self.name)
except (TypeError, AttributeError) as ex:
# Issue #10188: Emit a warning on stderr
# if the directory could not be cleaned
# up due to missing globals
if "None" not in str(ex):
raise
print("ERROR: {!r} while cleaning up {!r}".format(ex, self,),
file=_sys.stderr)
return
Fernando Perez
Add context manager for temporary directories from Python 3.2...
r3182 self._closed = True
MinRK
Backport PR #4018: Fix warning when running IPython.kernel tests...
r12204 if _warn:
self._warn("Implicitly cleaning up {!r}".format(self),
ResourceWarning)
Fernando Perez
Add context manager for temporary directories from Python 3.2...
r3182
def __exit__(self, exc, value, tb):
self.cleanup()
MinRK
Backport PR #4018: Fix warning when running IPython.kernel tests...
r12204 def __del__(self):
# Issue a ResourceWarning if implicit cleanup needed
self.cleanup(_warn=True)
Fernando Perez
Add context manager for temporary directories from Python 3.2...
r3182
# XXX (ncoghlan): The following code attempts to make
# this class tolerant of the module nulling out process
# that happens during CPython interpreter shutdown
# Alas, it doesn't actually manage it. See issue #10188
_listdir = staticmethod(_os.listdir)
_path_join = staticmethod(_os.path.join)
_isdir = staticmethod(_os.path.isdir)
_remove = staticmethod(_os.remove)
_rmdir = staticmethod(_os.rmdir)
_os_error = _os.error
def _rmtree(self, path):
# Essentially a stripped down version of shutil.rmtree. We can't
# use globals because they may be None'ed out at shutdown.
for name in self._listdir(path):
fullname = self._path_join(path, name)
try:
isdir = self._isdir(fullname)
except self._os_error:
isdir = False
if isdir:
self._rmtree(fullname)
else:
try:
self._remove(fullname)
except self._os_error:
pass
try:
self._rmdir(path)
except self._os_error:
pass
Takafumi Arakaki
Do not use NamedTemporaryFile in handle_image_tempfile...
r8246
class NamedFileInTemporaryDirectory(object):
def __init__(self, filename, mode='w+b', bufsize=-1, **kwds):
"""
Open a file named `filename` in a temporary directory.
This context manager is preferred over `NamedTemporaryFile` in
stdlib `tempfile` when one needs to reopen the file.
Arguments `mode` and `bufsize` are passed to `open`.
Rest of the arguments are passed to `TemporaryDirectory`.
"""
self._tmpdir = TemporaryDirectory(**kwds)
path = _os.path.join(self._tmpdir.name, filename)
self.file = open(path, mode, bufsize)
def cleanup(self):
self.file.close()
self._tmpdir.cleanup()
__del__ = cleanup
def __enter__(self):
return self.file
def __exit__(self, type, value, traceback):
self.cleanup()
Paul Ivanov
moved TemporaryWorkingDir into utils.tempdir
r11873
class TemporaryWorkingDirectory(TemporaryDirectory):
"""
Creates a temporary directory and sets the cwd to that directory.
Automatically reverts to previous cwd upon cleanup.
Usage example:
with TemporaryWorakingDirectory() as tmpdir:
...
"""
def __init__(self, **kw):
super(TemporaryWorkingDirectory, self).__init__(**kw)
#Change cwd to new temp dir. Remember old cwd.
self.old_wd = _os.getcwd()
_os.chdir(self.name)
MinRK
Backport PR #4018: Fix warning when running IPython.kernel tests...
r12204 def cleanup(self, _warn=False):
Paul Ivanov
moved TemporaryWorkingDir into utils.tempdir
r11873 #Revert to old cwd.
_os.chdir(self.old_wd)
#Cleanup
MinRK
Backport PR #4018: Fix warning when running IPython.kernel tests...
r12204 super(TemporaryWorkingDirectory, self).cleanup(_warn=_warn)