|  | The Mock Class | 
|  | ============== | 
|  |  | 
|  | .. currentmodule:: mock | 
|  |  | 
|  | .. testsetup:: | 
|  |  | 
|  | class SomeClass: | 
|  | pass | 
|  |  | 
|  |  | 
|  | `Mock` is a flexible mock object intended to replace the use of stubs and | 
|  | test doubles throughout your code. Mocks are callable and create attributes as | 
|  | new mocks when you access them [#]_. Accessing the same attribute will always | 
|  | return the same mock. Mocks record how you use them, allowing you to make | 
|  | assertions about what your code has done to them. | 
|  |  | 
|  | :class:`MagicMock` is a subclass of `Mock` with all the magic methods | 
|  | pre-created and ready to use. There are also non-callable variants, useful | 
|  | when you are mocking out objects that aren't callable: | 
|  | :class:`NonCallableMock` and :class:`NonCallableMagicMock` | 
|  |  | 
|  | The :func:`patch` decorators makes it easy to temporarily replace classes | 
|  | in a particular module with a `Mock` object. By default `patch` will create | 
|  | a `MagicMock` for you. You can specify an alternative class of `Mock` using | 
|  | the `new_callable` argument to `patch`. | 
|  |  | 
|  |  | 
|  | .. index:: side_effect | 
|  | .. index:: return_value | 
|  | .. index:: wraps | 
|  | .. index:: name | 
|  | .. index:: spec | 
|  |  | 
|  | .. class:: Mock(spec=None, side_effect=None, return_value=DEFAULT, wraps=None, name=None, spec_set=None, **kwargs) | 
|  |  | 
|  | Create a new `Mock` object. `Mock` takes several optional arguments | 
|  | that specify the behaviour of the Mock object: | 
|  |  | 
|  | * `spec`: This can be either a list of strings or an existing object (a | 
|  | class or instance) that acts as the specification for the mock object. If | 
|  | you pass in an object then a list of strings is formed by calling dir on | 
|  | the object (excluding unsupported magic attributes and methods). | 
|  | Accessing any attribute not in this list will raise an `AttributeError`. | 
|  |  | 
|  | If `spec` is an object (rather than a list of strings) then | 
|  | :attr:`__class__` returns the class of the spec object. This allows mocks | 
|  | to pass `isinstance` tests. | 
|  |  | 
|  | * `spec_set`: A stricter variant of `spec`. If used, attempting to *set* | 
|  | or get an attribute on the mock that isn't on the object passed as | 
|  | `spec_set` will raise an `AttributeError`. | 
|  |  | 
|  | * `side_effect`: A function to be called whenever the Mock is called. See | 
|  | the :attr:`~Mock.side_effect` attribute. Useful for raising exceptions or | 
|  | dynamically changing return values. The function is called with the same | 
|  | arguments as the mock, and unless it returns :data:`DEFAULT`, the return | 
|  | value of this function is used as the return value. | 
|  |  | 
|  | Alternatively `side_effect` can be an exception class or instance. In | 
|  | this case the exception will be raised when the mock is called. | 
|  |  | 
|  | If `side_effect` is an iterable then each call to the mock will return | 
|  | the next value from the iterable. If any of the members of the iterable | 
|  | are exceptions they will be raised instead of returned. | 
|  |  | 
|  | A `side_effect` can be cleared by setting it to `None`. | 
|  |  | 
|  | * `return_value`: The value returned when the mock is called. By default | 
|  | this is a new Mock (created on first access). See the | 
|  | :attr:`return_value` attribute. | 
|  |  | 
|  | * `wraps`: Item for the mock object to wrap. If `wraps` is not None then | 
|  | calling the Mock will pass the call through to the wrapped object | 
|  | (returning the real result and ignoring `return_value`). Attribute access | 
|  | on the mock will return a Mock object that wraps the corresponding | 
|  | attribute of the wrapped object (so attempting to access an attribute | 
|  | that doesn't exist will raise an `AttributeError`). | 
|  |  | 
|  | If the mock has an explicit `return_value` set then calls are not passed | 
|  | to the wrapped object and the `return_value` is returned instead. | 
|  |  | 
|  | * `name`: If the mock has a name then it will be used in the repr of the | 
|  | mock. This can be useful for debugging. The name is propagated to child | 
|  | mocks. | 
|  |  | 
|  | Mocks can also be called with arbitrary keyword arguments. These will be | 
|  | used to set attributes on the mock after it is created. See the | 
|  | :meth:`configure_mock` method for details. | 
|  |  | 
|  |  | 
|  | .. method:: assert_called_with(*args, **kwargs) | 
|  |  | 
|  | This method is a convenient way of asserting that calls are made in a | 
|  | particular way: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = Mock() | 
|  | >>> mock.method(1, 2, 3, test='wow') | 
|  | <Mock name='mock.method()' id='...'> | 
|  | >>> mock.method.assert_called_with(1, 2, 3, test='wow') | 
|  |  | 
|  |  | 
|  | .. method:: assert_called_once_with(*args, **kwargs) | 
|  |  | 
|  | Assert that the mock was called exactly once and with the specified | 
|  | arguments. | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = Mock(return_value=None) | 
|  | >>> mock('foo', bar='baz') | 
|  | >>> mock.assert_called_once_with('foo', bar='baz') | 
|  | >>> mock('foo', bar='baz') | 
|  | >>> mock.assert_called_once_with('foo', bar='baz') | 
|  | Traceback (most recent call last): | 
|  | ... | 
|  | AssertionError: Expected to be called once. Called 2 times. | 
|  |  | 
|  |  | 
|  | .. method:: assert_any_call(*args, **kwargs) | 
|  |  | 
|  | assert the mock has been called with the specified arguments. | 
|  |  | 
|  | The assert passes if the mock has *ever* been called, unlike | 
|  | :meth:`assert_called_with` and :meth:`assert_called_once_with` that | 
|  | only pass if the call is the most recent one. | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = Mock(return_value=None) | 
|  | >>> mock(1, 2, arg='thing') | 
|  | >>> mock('some', 'thing', 'else') | 
|  | >>> mock.assert_any_call(1, 2, arg='thing') | 
|  |  | 
|  |  | 
|  | .. method:: assert_has_calls(calls, any_order=False) | 
|  |  | 
|  | assert the mock has been called with the specified calls. | 
|  | The `mock_calls` list is checked for the calls. | 
|  |  | 
|  | If `any_order` is False (the default) then the calls must be | 
|  | sequential. There can be extra calls before or after the | 
|  | specified calls. | 
|  |  | 
|  | If `any_order` is True then the calls can be in any order, but | 
|  | they must all appear in :attr:`mock_calls`. | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = Mock(return_value=None) | 
|  | >>> mock(1) | 
|  | >>> mock(2) | 
|  | >>> mock(3) | 
|  | >>> mock(4) | 
|  | >>> calls = [call(2), call(3)] | 
|  | >>> mock.assert_has_calls(calls) | 
|  | >>> calls = [call(4), call(2), call(3)] | 
|  | >>> mock.assert_has_calls(calls, any_order=True) | 
|  |  | 
|  |  | 
|  | .. method:: reset_mock() | 
|  |  | 
|  | The reset_mock method resets all the call attributes on a mock object: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = Mock(return_value=None) | 
|  | >>> mock('hello') | 
|  | >>> mock.called | 
|  | True | 
|  | >>> mock.reset_mock() | 
|  | >>> mock.called | 
|  | False | 
|  |  | 
|  | This can be useful where you want to make a series of assertions that | 
|  | reuse the same object. Note that `reset_mock` *doesn't* clear the | 
|  | return value, :attr:`side_effect` or any child attributes you have | 
|  | set using normal assignment. Child mocks and the return value mock | 
|  | (if any) are reset as well. | 
|  |  | 
|  |  | 
|  | .. method:: mock_add_spec(spec, spec_set=False) | 
|  |  | 
|  | Add a spec to a mock. `spec` can either be an object or a | 
|  | list of strings. Only attributes on the `spec` can be fetched as | 
|  | attributes from the mock. | 
|  |  | 
|  | If `spec_set` is `True` then only attributes on the spec can be set. | 
|  |  | 
|  |  | 
|  | .. method:: attach_mock(mock, attribute) | 
|  |  | 
|  | Attach a mock as an attribute of this one, replacing its name and | 
|  | parent. Calls to the attached mock will be recorded in the | 
|  | :attr:`method_calls` and :attr:`mock_calls` attributes of this one. | 
|  |  | 
|  |  | 
|  | .. method:: configure_mock(**kwargs) | 
|  |  | 
|  | Set attributes on the mock through keyword arguments. | 
|  |  | 
|  | Attributes plus return values and side effects can be set on child | 
|  | mocks using standard dot notation and unpacking a dictionary in the | 
|  | method call: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = Mock() | 
|  | >>> attrs = {'method.return_value': 3, 'other.side_effect': KeyError} | 
|  | >>> mock.configure_mock(**attrs) | 
|  | >>> mock.method() | 
|  | 3 | 
|  | >>> mock.other() | 
|  | Traceback (most recent call last): | 
|  | ... | 
|  | KeyError | 
|  |  | 
|  | The same thing can be achieved in the constructor call to mocks: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> attrs = {'method.return_value': 3, 'other.side_effect': KeyError} | 
|  | >>> mock = Mock(some_attribute='eggs', **attrs) | 
|  | >>> mock.some_attribute | 
|  | 'eggs' | 
|  | >>> mock.method() | 
|  | 3 | 
|  | >>> mock.other() | 
|  | Traceback (most recent call last): | 
|  | ... | 
|  | KeyError | 
|  |  | 
|  | `configure_mock` exists to make it easier to do configuration | 
|  | after the mock has been created. | 
|  |  | 
|  |  | 
|  | .. method:: __dir__() | 
|  |  | 
|  | `Mock` objects limit the results of `dir(some_mock)` to useful results. | 
|  | For mocks with a `spec` this includes all the permitted attributes | 
|  | for the mock. | 
|  |  | 
|  | See :data:`FILTER_DIR` for what this filtering does, and how to | 
|  | switch it off. | 
|  |  | 
|  |  | 
|  | .. method:: _get_child_mock(**kw) | 
|  |  | 
|  | Create the child mocks for attributes and return value. | 
|  | By default child mocks will be the same type as the parent. | 
|  | Subclasses of Mock may want to override this to customize the way | 
|  | child mocks are made. | 
|  |  | 
|  | For non-callable mocks the callable variant will be used (rather than | 
|  | any custom subclass). | 
|  |  | 
|  |  | 
|  | .. attribute:: called | 
|  |  | 
|  | A boolean representing whether or not the mock object has been called: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = Mock(return_value=None) | 
|  | >>> mock.called | 
|  | False | 
|  | >>> mock() | 
|  | >>> mock.called | 
|  | True | 
|  |  | 
|  | .. attribute:: call_count | 
|  |  | 
|  | An integer telling you how many times the mock object has been called: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = Mock(return_value=None) | 
|  | >>> mock.call_count | 
|  | 0 | 
|  | >>> mock() | 
|  | >>> mock() | 
|  | >>> mock.call_count | 
|  | 2 | 
|  |  | 
|  |  | 
|  | .. attribute:: return_value | 
|  |  | 
|  | Set this to configure the value returned by calling the mock: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = Mock() | 
|  | >>> mock.return_value = 'fish' | 
|  | >>> mock() | 
|  | 'fish' | 
|  |  | 
|  | The default return value is a mock object and you can configure it in | 
|  | the normal way: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = Mock() | 
|  | >>> mock.return_value.attribute = sentinel.Attribute | 
|  | >>> mock.return_value() | 
|  | <Mock name='mock()()' id='...'> | 
|  | >>> mock.return_value.assert_called_with() | 
|  |  | 
|  | `return_value` can also be set in the constructor: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = Mock(return_value=3) | 
|  | >>> mock.return_value | 
|  | 3 | 
|  | >>> mock() | 
|  | 3 | 
|  |  | 
|  |  | 
|  | .. attribute:: side_effect | 
|  |  | 
|  | This can either be a function to be called when the mock is called, | 
|  | or an exception (class or instance) to be raised. | 
|  |  | 
|  | If you pass in a function it will be called with same arguments as the | 
|  | mock and unless the function returns the :data:`DEFAULT` singleton the | 
|  | call to the mock will then return whatever the function returns. If the | 
|  | function returns :data:`DEFAULT` then the mock will return its normal | 
|  | value (from the :attr:`return_value`. | 
|  |  | 
|  | An example of a mock that raises an exception (to test exception | 
|  | handling of an API): | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = Mock() | 
|  | >>> mock.side_effect = Exception('Boom!') | 
|  | >>> mock() | 
|  | Traceback (most recent call last): | 
|  | ... | 
|  | Exception: Boom! | 
|  |  | 
|  | Using `side_effect` to return a sequence of values: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = Mock() | 
|  | >>> mock.side_effect = [3, 2, 1] | 
|  | >>> mock(), mock(), mock() | 
|  | (3, 2, 1) | 
|  |  | 
|  | The `side_effect` function is called with the same arguments as the | 
|  | mock (so it is wise for it to take arbitrary args and keyword | 
|  | arguments) and whatever it returns is used as the return value for | 
|  | the call. The exception is if `side_effect` returns :data:`DEFAULT`, | 
|  | in which case the normal :attr:`return_value` is used. | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = Mock(return_value=3) | 
|  | >>> def side_effect(*args, **kwargs): | 
|  | ...     return DEFAULT | 
|  | ... | 
|  | >>> mock.side_effect = side_effect | 
|  | >>> mock() | 
|  | 3 | 
|  |  | 
|  | `side_effect` can be set in the constructor. Here's an example that | 
|  | adds one to the value the mock is called with and returns it: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> side_effect = lambda value: value + 1 | 
|  | >>> mock = Mock(side_effect=side_effect) | 
|  | >>> mock(3) | 
|  | 4 | 
|  | >>> mock(-8) | 
|  | -7 | 
|  |  | 
|  | Setting `side_effect` to `None` clears it: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> from mock import Mock | 
|  | >>> m = Mock(side_effect=KeyError, return_value=3) | 
|  | >>> m() | 
|  | Traceback (most recent call last): | 
|  | ... | 
|  | KeyError | 
|  | >>> m.side_effect = None | 
|  | >>> m() | 
|  | 3 | 
|  |  | 
|  |  | 
|  | .. attribute:: call_args | 
|  |  | 
|  | This is either `None` (if the mock hasn't been called), or the | 
|  | arguments that the mock was last called with. This will be in the | 
|  | form of a tuple: the first member is any ordered arguments the mock | 
|  | was called with (or an empty tuple) and the second member is any | 
|  | keyword arguments (or an empty dictionary). | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = Mock(return_value=None) | 
|  | >>> print mock.call_args | 
|  | None | 
|  | >>> mock() | 
|  | >>> mock.call_args | 
|  | call() | 
|  | >>> mock.call_args == () | 
|  | True | 
|  | >>> mock(3, 4) | 
|  | >>> mock.call_args | 
|  | call(3, 4) | 
|  | >>> mock.call_args == ((3, 4),) | 
|  | True | 
|  | >>> mock(3, 4, 5, key='fish', next='w00t!') | 
|  | >>> mock.call_args | 
|  | call(3, 4, 5, key='fish', next='w00t!') | 
|  |  | 
|  | `call_args`, along with members of the lists :attr:`call_args_list`, | 
|  | :attr:`method_calls` and :attr:`mock_calls` are :data:`call` objects. | 
|  | These are tuples, so they can be unpacked to get at the individual | 
|  | arguments and make more complex assertions. See | 
|  | :ref:`calls as tuples <calls-as-tuples>`. | 
|  |  | 
|  |  | 
|  | .. attribute:: call_args_list | 
|  |  | 
|  | This is a list of all the calls made to the mock object in sequence | 
|  | (so the length of the list is the number of times it has been | 
|  | called). Before any calls have been made it is an empty list. The | 
|  | :data:`call` object can be used for conveniently constructing lists of | 
|  | calls to compare with `call_args_list`. | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = Mock(return_value=None) | 
|  | >>> mock() | 
|  | >>> mock(3, 4) | 
|  | >>> mock(key='fish', next='w00t!') | 
|  | >>> mock.call_args_list | 
|  | [call(), call(3, 4), call(key='fish', next='w00t!')] | 
|  | >>> expected = [(), ((3, 4),), ({'key': 'fish', 'next': 'w00t!'},)] | 
|  | >>> mock.call_args_list == expected | 
|  | True | 
|  |  | 
|  | Members of `call_args_list` are :data:`call` objects. These can be | 
|  | unpacked as tuples to get at the individual arguments. See | 
|  | :ref:`calls as tuples <calls-as-tuples>`. | 
|  |  | 
|  |  | 
|  | .. attribute:: method_calls | 
|  |  | 
|  | As well as tracking calls to themselves, mocks also track calls to | 
|  | methods and attributes, and *their* methods and attributes: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = Mock() | 
|  | >>> mock.method() | 
|  | <Mock name='mock.method()' id='...'> | 
|  | >>> mock.property.method.attribute() | 
|  | <Mock name='mock.property.method.attribute()' id='...'> | 
|  | >>> mock.method_calls | 
|  | [call.method(), call.property.method.attribute()] | 
|  |  | 
|  | Members of `method_calls` are :data:`call` objects. These can be | 
|  | unpacked as tuples to get at the individual arguments. See | 
|  | :ref:`calls as tuples <calls-as-tuples>`. | 
|  |  | 
|  |  | 
|  | .. attribute:: mock_calls | 
|  |  | 
|  | `mock_calls` records *all* calls to the mock object, its methods, magic | 
|  | methods *and* return value mocks. | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = MagicMock() | 
|  | >>> result = mock(1, 2, 3) | 
|  | >>> mock.first(a=3) | 
|  | <MagicMock name='mock.first()' id='...'> | 
|  | >>> mock.second() | 
|  | <MagicMock name='mock.second()' id='...'> | 
|  | >>> int(mock) | 
|  | 1 | 
|  | >>> result(1) | 
|  | <MagicMock name='mock()()' id='...'> | 
|  | >>> expected = [call(1, 2, 3), call.first(a=3), call.second(), | 
|  | ... call.__int__(), call()(1)] | 
|  | >>> mock.mock_calls == expected | 
|  | True | 
|  |  | 
|  | Members of `mock_calls` are :data:`call` objects. These can be | 
|  | unpacked as tuples to get at the individual arguments. See | 
|  | :ref:`calls as tuples <calls-as-tuples>`. | 
|  |  | 
|  |  | 
|  | .. attribute:: __class__ | 
|  |  | 
|  | Normally the `__class__` attribute of an object will return its type. | 
|  | For a mock object with a `spec` `__class__` returns the spec class | 
|  | instead. This allows mock objects to pass `isinstance` tests for the | 
|  | object they are replacing / masquerading as: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = Mock(spec=3) | 
|  | >>> isinstance(mock, int) | 
|  | True | 
|  |  | 
|  | `__class__` is assignable to, this allows a mock to pass an | 
|  | `isinstance` check without forcing you to use a spec: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = Mock() | 
|  | >>> mock.__class__ = dict | 
|  | >>> isinstance(mock, dict) | 
|  | True | 
|  |  | 
|  | .. class:: NonCallableMock(spec=None, wraps=None, name=None, spec_set=None, **kwargs) | 
|  |  | 
|  | A non-callable version of `Mock`. The constructor parameters have the same | 
|  | meaning of `Mock`, with the exception of `return_value` and `side_effect` | 
|  | which have no meaning on a non-callable mock. | 
|  |  | 
|  | Mock objects that use a class or an instance as a `spec` or `spec_set` are able | 
|  | to pass `isintance` tests: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = Mock(spec=SomeClass) | 
|  | >>> isinstance(mock, SomeClass) | 
|  | True | 
|  | >>> mock = Mock(spec_set=SomeClass()) | 
|  | >>> isinstance(mock, SomeClass) | 
|  | True | 
|  |  | 
|  | The `Mock` classes have support for mocking magic methods. See :ref:`magic | 
|  | methods <magic-methods>` for the full details. | 
|  |  | 
|  | The mock classes and the :func:`patch` decorators all take arbitrary keyword | 
|  | arguments for configuration. For the `patch` decorators the keywords are | 
|  | passed to the constructor of the mock being created. The keyword arguments | 
|  | are for configuring attributes of the mock: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> m = MagicMock(attribute=3, other='fish') | 
|  | >>> m.attribute | 
|  | 3 | 
|  | >>> m.other | 
|  | 'fish' | 
|  |  | 
|  | The return value and side effect of child mocks can be set in the same way, | 
|  | using dotted notation. As you can't use dotted names directly in a call you | 
|  | have to create a dictionary and unpack it using `**`: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> attrs = {'method.return_value': 3, 'other.side_effect': KeyError} | 
|  | >>> mock = Mock(some_attribute='eggs', **attrs) | 
|  | >>> mock.some_attribute | 
|  | 'eggs' | 
|  | >>> mock.method() | 
|  | 3 | 
|  | >>> mock.other() | 
|  | Traceback (most recent call last): | 
|  | ... | 
|  | KeyError | 
|  |  | 
|  |  | 
|  | .. class:: PropertyMock(*args, **kwargs) | 
|  |  | 
|  | A mock intended to be used as a property, or other descriptor, on a class. | 
|  | `PropertyMock` provides `__get__` and `__set__` methods so you can specify | 
|  | a return value when it is fetched. | 
|  |  | 
|  | Fetching a `PropertyMock` instance from an object calls the mock, with | 
|  | no args. Setting it calls the mock with the value being set. | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> class Foo(object): | 
|  | ...     @property | 
|  | ...     def foo(self): | 
|  | ...         return 'something' | 
|  | ...     @foo.setter | 
|  | ...     def foo(self, value): | 
|  | ...         pass | 
|  | ... | 
|  | >>> with patch('__main__.Foo.foo', new_callable=PropertyMock) as mock_foo: | 
|  | ...     mock_foo.return_value = 'mockity-mock' | 
|  | ...     this_foo = Foo() | 
|  | ...     print this_foo.foo | 
|  | ...     this_foo.foo = 6 | 
|  | ... | 
|  | mockity-mock | 
|  | >>> mock_foo.mock_calls | 
|  | [call(), call(6)] | 
|  |  | 
|  | Because of the way mock attributes are stored you can't directly attach a | 
|  | `PropertyMock` to a mock object. Instead you can attach it to the mock type | 
|  | object: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> m = MagicMock() | 
|  | >>> p = PropertyMock(return_value=3) | 
|  | >>> type(m).foo = p | 
|  | >>> m.foo | 
|  | 3 | 
|  | >>> p.assert_called_once_with() | 
|  |  | 
|  |  | 
|  | .. index:: __call__ | 
|  | .. index:: calling | 
|  |  | 
|  | Calling | 
|  | ======= | 
|  |  | 
|  | Mock objects are callable. The call will return the value set as the | 
|  | :attr:`~Mock.return_value` attribute. The default return value is a new Mock | 
|  | object; it is created the first time the return value is accessed (either | 
|  | explicitly or by calling the Mock) - but it is stored and the same one | 
|  | returned each time. | 
|  |  | 
|  | Calls made to the object will be recorded in the attributes | 
|  | like :attr:`~Mock.call_args` and :attr:`~Mock.call_args_list`. | 
|  |  | 
|  | If :attr:`~Mock.side_effect` is set then it will be called after the call has | 
|  | been recorded, so if `side_effect` raises an exception the call is still | 
|  | recorded. | 
|  |  | 
|  | The simplest way to make a mock raise an exception when called is to make | 
|  | :attr:`~Mock.side_effect` an exception class or instance: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> m = MagicMock(side_effect=IndexError) | 
|  | >>> m(1, 2, 3) | 
|  | Traceback (most recent call last): | 
|  | ... | 
|  | IndexError | 
|  | >>> m.mock_calls | 
|  | [call(1, 2, 3)] | 
|  | >>> m.side_effect = KeyError('Bang!') | 
|  | >>> m('two', 'three', 'four') | 
|  | Traceback (most recent call last): | 
|  | ... | 
|  | KeyError: 'Bang!' | 
|  | >>> m.mock_calls | 
|  | [call(1, 2, 3), call('two', 'three', 'four')] | 
|  |  | 
|  | If `side_effect` is a function then whatever that function returns is what | 
|  | calls to the mock return. The `side_effect` function is called with the | 
|  | same arguments as the mock. This allows you to vary the return value of the | 
|  | call dynamically, based on the input: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> def side_effect(value): | 
|  | ...     return value + 1 | 
|  | ... | 
|  | >>> m = MagicMock(side_effect=side_effect) | 
|  | >>> m(1) | 
|  | 2 | 
|  | >>> m(2) | 
|  | 3 | 
|  | >>> m.mock_calls | 
|  | [call(1), call(2)] | 
|  |  | 
|  | If you want the mock to still return the default return value (a new mock), or | 
|  | any set return value, then there are two ways of doing this. Either return | 
|  | `mock.return_value` from inside `side_effect`, or return :data:`DEFAULT`: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> m = MagicMock() | 
|  | >>> def side_effect(*args, **kwargs): | 
|  | ...     return m.return_value | 
|  | ... | 
|  | >>> m.side_effect = side_effect | 
|  | >>> m.return_value = 3 | 
|  | >>> m() | 
|  | 3 | 
|  | >>> def side_effect(*args, **kwargs): | 
|  | ...     return DEFAULT | 
|  | ... | 
|  | >>> m.side_effect = side_effect | 
|  | >>> m() | 
|  | 3 | 
|  |  | 
|  | To remove a `side_effect`, and return to the default behaviour, set the | 
|  | `side_effect` to `None`: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> m = MagicMock(return_value=6) | 
|  | >>> def side_effect(*args, **kwargs): | 
|  | ...     return 3 | 
|  | ... | 
|  | >>> m.side_effect = side_effect | 
|  | >>> m() | 
|  | 3 | 
|  | >>> m.side_effect = None | 
|  | >>> m() | 
|  | 6 | 
|  |  | 
|  | The `side_effect` can also be any iterable object. Repeated calls to the mock | 
|  | will return values from the iterable (until the iterable is exhausted and | 
|  | a `StopIteration` is raised): | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> m = MagicMock(side_effect=[1, 2, 3]) | 
|  | >>> m() | 
|  | 1 | 
|  | >>> m() | 
|  | 2 | 
|  | >>> m() | 
|  | 3 | 
|  | >>> m() | 
|  | Traceback (most recent call last): | 
|  | ... | 
|  | StopIteration | 
|  |  | 
|  | If any members of the iterable are exceptions they will be raised instead of | 
|  | returned: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> iterable = (33, ValueError, 66) | 
|  | >>> m = MagicMock(side_effect=iterable) | 
|  | >>> m() | 
|  | 33 | 
|  | >>> m() | 
|  | Traceback (most recent call last): | 
|  | ... | 
|  | ValueError | 
|  | >>> m() | 
|  | 66 | 
|  |  | 
|  |  | 
|  | .. _deleting-attributes: | 
|  |  | 
|  | Deleting Attributes | 
|  | =================== | 
|  |  | 
|  | Mock objects create attributes on demand. This allows them to pretend to be | 
|  | objects of any type. | 
|  |  | 
|  | You may want a mock object to return `False` to a `hasattr` call, or raise an | 
|  | `AttributeError` when an attribute is fetched. You can do this by providing | 
|  | an object as a `spec` for a mock, but that isn't always convenient. | 
|  |  | 
|  | You "block" attributes by deleting them. Once deleted, accessing an attribute | 
|  | will raise an `AttributeError`. | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = MagicMock() | 
|  | >>> hasattr(mock, 'm') | 
|  | True | 
|  | >>> del mock.m | 
|  | >>> hasattr(mock, 'm') | 
|  | False | 
|  | >>> del mock.f | 
|  | >>> mock.f | 
|  | Traceback (most recent call last): | 
|  | ... | 
|  | AttributeError: f | 
|  |  | 
|  |  | 
|  | Attaching Mocks as Attributes | 
|  | ============================= | 
|  |  | 
|  | When you attach a mock as an attribute of another mock (or as the return | 
|  | value) it becomes a "child" of that mock. Calls to the child are recorded in | 
|  | the :attr:`~Mock.method_calls` and :attr:`~Mock.mock_calls` attributes of the | 
|  | parent. This is useful for configuring child mocks and then attaching them to | 
|  | the parent, or for attaching mocks to a parent that records all calls to the | 
|  | children and allows you to make assertions about the order of calls between | 
|  | mocks: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> parent = MagicMock() | 
|  | >>> child1 = MagicMock(return_value=None) | 
|  | >>> child2 = MagicMock(return_value=None) | 
|  | >>> parent.child1 = child1 | 
|  | >>> parent.child2 = child2 | 
|  | >>> child1(1) | 
|  | >>> child2(2) | 
|  | >>> parent.mock_calls | 
|  | [call.child1(1), call.child2(2)] | 
|  |  | 
|  | The exception to this is if the mock has a name. This allows you to prevent | 
|  | the "parenting" if for some reason you don't want it to happen. | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> mock = MagicMock() | 
|  | >>> not_a_child = MagicMock(name='not-a-child') | 
|  | >>> mock.attribute = not_a_child | 
|  | >>> mock.attribute() | 
|  | <MagicMock name='not-a-child()' id='...'> | 
|  | >>> mock.mock_calls | 
|  | [] | 
|  |  | 
|  | Mocks created for you by :func:`patch` are automatically given names. To | 
|  | attach mocks that have names to a parent you use the :meth:`~Mock.attach_mock` | 
|  | method: | 
|  |  | 
|  | .. doctest:: | 
|  |  | 
|  | >>> thing1 = object() | 
|  | >>> thing2 = object() | 
|  | >>> parent = MagicMock() | 
|  | >>> with patch('__main__.thing1', return_value=None) as child1: | 
|  | ...     with patch('__main__.thing2', return_value=None) as child2: | 
|  | ...         parent.attach_mock(child1, 'child1') | 
|  | ...         parent.attach_mock(child2, 'child2') | 
|  | ...         child1('one') | 
|  | ...         child2('two') | 
|  | ... | 
|  | >>> parent.mock_calls | 
|  | [call.child1('one'), call.child2('two')] | 
|  |  | 
|  |  | 
|  | ----- | 
|  |  | 
|  | .. [#] The only exceptions are magic methods and attributes (those that have | 
|  | leading and trailing double underscores). Mock doesn't create these but | 
|  | instead of raises an ``AttributeError``. This is because the interpreter | 
|  | will often implicitly request these methods, and gets *very* confused to | 
|  | get a new Mock object when it expects a magic method. If you need magic | 
|  | method support see :ref:`magic methods <magic-methods>`. |