2010-10-11 05:45:45 +08:00
|
|
|
|
2011-09-06 17:43:42 +08:00
|
|
|
Monkeypatching/mocking modules and environments
|
2010-10-11 05:45:45 +08:00
|
|
|
================================================================
|
|
|
|
|
2010-11-13 18:10:45 +08:00
|
|
|
.. currentmodule:: _pytest.monkeypatch
|
2010-10-11 05:45:45 +08:00
|
|
|
|
|
|
|
Sometimes tests need to invoke functionality which depends
|
|
|
|
on global settings or which invokes code which cannot be easily
|
|
|
|
tested such as network access. The ``monkeypatch`` function argument
|
|
|
|
helps you to safely set/delete an attribute, dictionary item or
|
|
|
|
environment variable or to modify ``sys.path`` for importing.
|
2011-03-04 06:40:38 +08:00
|
|
|
See the `monkeypatch blog post`_ for some introduction material
|
|
|
|
and a discussion of its motivation.
|
2010-10-11 05:45:45 +08:00
|
|
|
|
|
|
|
.. _`monkeypatch blog post`: http://tetamap.wordpress.com/2009/03/03/monkeypatching-in-unit-tests-done-right/
|
|
|
|
|
|
|
|
|
|
|
|
Simple example: patching ``os.path.expanduser``
|
|
|
|
---------------------------------------------------
|
|
|
|
|
2011-03-04 06:40:38 +08:00
|
|
|
If, for instance, you want to pretend that ``os.expanduser`` returns a certain
|
2010-10-11 05:45:45 +08:00
|
|
|
directory, you can use the :py:meth:`monkeypatch.setattr` method to
|
|
|
|
patch this function before calling into a function which uses it::
|
|
|
|
|
|
|
|
import os.path
|
|
|
|
def getssh(): # pseudo application code
|
2011-02-18 13:52:18 +08:00
|
|
|
return os.path.join(os.path.expanduser("~admin"), '.ssh')
|
2010-10-11 05:45:45 +08:00
|
|
|
|
|
|
|
def test_mytest(monkeypatch):
|
2010-10-11 16:07:14 +08:00
|
|
|
def mockreturn(path):
|
|
|
|
return '/abc'
|
|
|
|
monkeypatch.setattr(os.path, 'expanduser', mockreturn)
|
2010-10-11 05:45:45 +08:00
|
|
|
x = getssh()
|
2011-02-18 13:52:18 +08:00
|
|
|
assert x == '/abc/.ssh'
|
2010-10-11 05:45:45 +08:00
|
|
|
|
|
|
|
After the test function finishes the ``os.path.expanduser`` modification
|
|
|
|
will be undone.
|
|
|
|
|
2010-10-11 16:07:14 +08:00
|
|
|
.. background check:
|
|
|
|
$ py.test
|
2010-10-12 16:59:04 +08:00
|
|
|
=========================== test session starts ============================
|
2011-11-19 02:32:11 +08:00
|
|
|
platform darwin -- Python 2.7.1 -- pytest-2.2.0
|
2010-11-26 20:26:56 +08:00
|
|
|
collecting ... collected 0 items
|
2010-10-11 16:07:14 +08:00
|
|
|
|
2011-11-19 02:32:11 +08:00
|
|
|
============================= in 0.20 seconds =============================
|
2010-10-11 05:45:45 +08:00
|
|
|
|
|
|
|
Method reference of the monkeypatch function argument
|
|
|
|
-----------------------------------------------------
|
|
|
|
|
|
|
|
.. autoclass:: monkeypatch
|
|
|
|
:members: setattr, delattr, setitem, delitem, setenv, delenv, syspath_prepend, undo
|
|
|
|
|
|
|
|
``monkeypatch.setattr/delattr/delitem/delenv()`` all
|
|
|
|
by default raise an Exception if the target does not exist.
|
|
|
|
Pass ``raising=False`` if you want to skip this check.
|
|
|
|
|