2010-07-27 03:15:15 +08:00
|
|
|
"""provide temporary directories to test functions.
|
2009-02-27 18:18:27 +08:00
|
|
|
|
2009-11-05 10:18:55 +08:00
|
|
|
usage example::
|
2009-02-27 18:18:27 +08:00
|
|
|
|
|
|
|
def test_plugin(tmpdir):
|
|
|
|
tmpdir.join("hello").write("hello")
|
|
|
|
|
2009-11-05 10:18:55 +08:00
|
|
|
.. _`py.path.local`: ../../path.html
|
|
|
|
|
2009-02-27 18:18:27 +08:00
|
|
|
"""
|
2010-10-21 22:10:37 +08:00
|
|
|
import pytest, py
|
2010-10-10 19:48:49 +08:00
|
|
|
|
|
|
|
def pytest_configure(config):
|
|
|
|
def ensuretemp(string, dir=1):
|
|
|
|
""" (deprecated) return temporary directory path with
|
|
|
|
the given string as the trailing part. It is usually
|
|
|
|
better to use the 'tmpdir' function argument which will
|
|
|
|
take care to provide empty unique directories for each
|
|
|
|
test call even if the test is called multiple times.
|
|
|
|
"""
|
|
|
|
#py.log._apiwarn(">1.1", "use tmpdir function argument")
|
|
|
|
return config.ensuretemp(string, dir=dir)
|
|
|
|
pytest.ensuretemp = ensuretemp
|
2009-02-27 18:18:27 +08:00
|
|
|
|
2009-05-19 05:26:16 +08:00
|
|
|
def pytest_funcarg__tmpdir(request):
|
2009-11-05 10:18:55 +08:00
|
|
|
"""return a temporary directory path object
|
|
|
|
unique to each test function invocation,
|
|
|
|
created as a sub directory of the base temporary
|
|
|
|
directory. The returned object is a `py.path.local`_
|
2010-07-27 03:15:15 +08:00
|
|
|
path object.
|
2009-11-05 10:18:55 +08:00
|
|
|
"""
|
2010-10-17 06:24:59 +08:00
|
|
|
name = request._pyfuncitem.name
|
2010-10-21 22:10:37 +08:00
|
|
|
name = py.std.re.sub("[\W]", "_", name)
|
2009-11-13 04:15:59 +08:00
|
|
|
x = request.config.mktemp(name, numbered=True)
|
|
|
|
return x.realpath()
|