1:mod:`unittest.mock` --- getting started 2======================================== 3 4.. moduleauthor:: Michael Foord <michael@python.org> 5.. currentmodule:: unittest.mock 6 7.. versionadded:: 3.3 8 9 10.. _getting-started: 11 12 13.. testsetup:: 14 15 import asyncio 16 import unittest 17 from unittest.mock import Mock, MagicMock, AsyncMock, patch, call, sentinel 18 19 class SomeClass: 20 attribute = 'this is a doctest' 21 22 @staticmethod 23 def static_method(): 24 pass 25 26Using Mock 27---------- 28 29Mock Patching Methods 30~~~~~~~~~~~~~~~~~~~~~ 31 32Common uses for :class:`Mock` objects include: 33 34* Patching methods 35* Recording method calls on objects 36 37You might want to replace a method on an object to check that 38it is called with the correct arguments by another part of the system: 39 40 >>> real = SomeClass() 41 >>> real.method = MagicMock(name='method') 42 >>> real.method(3, 4, 5, key='value') 43 <MagicMock name='method()' id='...'> 44 45Once our mock has been used (``real.method`` in this example) it has methods 46and attributes that allow you to make assertions about how it has been used. 47 48.. note:: 49 50 In most of these examples the :class:`Mock` and :class:`MagicMock` classes 51 are interchangeable. As the ``MagicMock`` is the more capable class it makes 52 a sensible one to use by default. 53 54Once the mock has been called its :attr:`~Mock.called` attribute is set to 55``True``. More importantly we can use the :meth:`~Mock.assert_called_with` or 56:meth:`~Mock.assert_called_once_with` method to check that it was called with 57the correct arguments. 58 59This example tests that calling ``ProductionClass().method`` results in a call to 60the ``something`` method: 61 62 >>> class ProductionClass: 63 ... def method(self): 64 ... self.something(1, 2, 3) 65 ... def something(self, a, b, c): 66 ... pass 67 ... 68 >>> real = ProductionClass() 69 >>> real.something = MagicMock() 70 >>> real.method() 71 >>> real.something.assert_called_once_with(1, 2, 3) 72 73 74 75Mock for Method Calls on an Object 76~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 77 78In the last example we patched a method directly on an object to check that it 79was called correctly. Another common use case is to pass an object into a 80method (or some part of the system under test) and then check that it is used 81in the correct way. 82 83The simple ``ProductionClass`` below has a ``closer`` method. If it is called with 84an object then it calls ``close`` on it. 85 86 >>> class ProductionClass: 87 ... def closer(self, something): 88 ... something.close() 89 ... 90 91So to test it we need to pass in an object with a ``close`` method and check 92that it was called correctly. 93 94 >>> real = ProductionClass() 95 >>> mock = Mock() 96 >>> real.closer(mock) 97 >>> mock.close.assert_called_with() 98 99We don't have to do any work to provide the 'close' method on our mock. 100Accessing close creates it. So, if 'close' hasn't already been called then 101accessing it in the test will create it, but :meth:`~Mock.assert_called_with` 102will raise a failure exception. 103 104 105Mocking Classes 106~~~~~~~~~~~~~~~ 107 108A common use case is to mock out classes instantiated by your code under test. 109When you patch a class, then that class is replaced with a mock. Instances 110are created by *calling the class*. This means you access the "mock instance" 111by looking at the return value of the mocked class. 112 113In the example below we have a function ``some_function`` that instantiates ``Foo`` 114and calls a method on it. The call to :func:`patch` replaces the class ``Foo`` with a 115mock. The ``Foo`` instance is the result of calling the mock, so it is configured 116by modifying the mock :attr:`~Mock.return_value`. :: 117 118 >>> def some_function(): 119 ... instance = module.Foo() 120 ... return instance.method() 121 ... 122 >>> with patch('module.Foo') as mock: 123 ... instance = mock.return_value 124 ... instance.method.return_value = 'the result' 125 ... result = some_function() 126 ... assert result == 'the result' 127 128 129Naming your mocks 130~~~~~~~~~~~~~~~~~ 131 132It can be useful to give your mocks a name. The name is shown in the repr of 133the mock and can be helpful when the mock appears in test failure messages. The 134name is also propagated to attributes or methods of the mock: 135 136 >>> mock = MagicMock(name='foo') 137 >>> mock 138 <MagicMock name='foo' id='...'> 139 >>> mock.method 140 <MagicMock name='foo.method' id='...'> 141 142 143Tracking all Calls 144~~~~~~~~~~~~~~~~~~ 145 146Often you want to track more than a single call to a method. The 147:attr:`~Mock.mock_calls` attribute records all calls 148to child attributes of the mock - and also to their children. 149 150 >>> mock = MagicMock() 151 >>> mock.method() 152 <MagicMock name='mock.method()' id='...'> 153 >>> mock.attribute.method(10, x=53) 154 <MagicMock name='mock.attribute.method()' id='...'> 155 >>> mock.mock_calls 156 [call.method(), call.attribute.method(10, x=53)] 157 158If you make an assertion about ``mock_calls`` and any unexpected methods 159have been called, then the assertion will fail. This is useful because as well 160as asserting that the calls you expected have been made, you are also checking 161that they were made in the right order and with no additional calls: 162 163You use the :data:`call` object to construct lists for comparing with 164``mock_calls``: 165 166 >>> expected = [call.method(), call.attribute.method(10, x=53)] 167 >>> mock.mock_calls == expected 168 True 169 170However, parameters to calls that return mocks are not recorded, which means it is not 171possible to track nested calls where the parameters used to create ancestors are important: 172 173 >>> m = Mock() 174 >>> m.factory(important=True).deliver() 175 <Mock name='mock.factory().deliver()' id='...'> 176 >>> m.mock_calls[-1] == call.factory(important=False).deliver() 177 True 178 179 180Setting Return Values and Attributes 181~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 182 183Setting the return values on a mock object is trivially easy: 184 185 >>> mock = Mock() 186 >>> mock.return_value = 3 187 >>> mock() 188 3 189 190Of course you can do the same for methods on the mock: 191 192 >>> mock = Mock() 193 >>> mock.method.return_value = 3 194 >>> mock.method() 195 3 196 197The return value can also be set in the constructor: 198 199 >>> mock = Mock(return_value=3) 200 >>> mock() 201 3 202 203If you need an attribute setting on your mock, just do it: 204 205 >>> mock = Mock() 206 >>> mock.x = 3 207 >>> mock.x 208 3 209 210Sometimes you want to mock up a more complex situation, like for example 211``mock.connection.cursor().execute("SELECT 1")``. If we wanted this call to 212return a list, then we have to configure the result of the nested call. 213 214We can use :data:`call` to construct the set of calls in a "chained call" like 215this for easy assertion afterwards: 216 217 >>> mock = Mock() 218 >>> cursor = mock.connection.cursor.return_value 219 >>> cursor.execute.return_value = ['foo'] 220 >>> mock.connection.cursor().execute("SELECT 1") 221 ['foo'] 222 >>> expected = call.connection.cursor().execute("SELECT 1").call_list() 223 >>> mock.mock_calls 224 [call.connection.cursor(), call.connection.cursor().execute('SELECT 1')] 225 >>> mock.mock_calls == expected 226 True 227 228It is the call to ``.call_list()`` that turns our call object into a list of 229calls representing the chained calls. 230 231 232Raising exceptions with mocks 233~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 234 235A useful attribute is :attr:`~Mock.side_effect`. If you set this to an 236exception class or instance then the exception will be raised when the mock 237is called. 238 239 >>> mock = Mock(side_effect=Exception('Boom!')) 240 >>> mock() 241 Traceback (most recent call last): 242 ... 243 Exception: Boom! 244 245 246Side effect functions and iterables 247~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 248 249``side_effect`` can also be set to a function or an iterable. The use case for 250``side_effect`` as an iterable is where your mock is going to be called several 251times, and you want each call to return a different value. When you set 252``side_effect`` to an iterable every call to the mock returns the next value 253from the iterable: 254 255 >>> mock = MagicMock(side_effect=[4, 5, 6]) 256 >>> mock() 257 4 258 >>> mock() 259 5 260 >>> mock() 261 6 262 263 264For more advanced use cases, like dynamically varying the return values 265depending on what the mock is called with, ``side_effect`` can be a function. 266The function will be called with the same arguments as the mock. Whatever the 267function returns is what the call returns: 268 269 >>> vals = {(1, 2): 1, (2, 3): 2} 270 >>> def side_effect(*args): 271 ... return vals[args] 272 ... 273 >>> mock = MagicMock(side_effect=side_effect) 274 >>> mock(1, 2) 275 1 276 >>> mock(2, 3) 277 2 278 279 280Mocking asynchronous iterators 281~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 282 283Since Python 3.8, ``AsyncMock`` and ``MagicMock`` have support to mock 284:ref:`async-iterators` through ``__aiter__``. The :attr:`~Mock.return_value` 285attribute of ``__aiter__`` can be used to set the return values to be used for 286iteration. 287 288 >>> mock = MagicMock() # AsyncMock also works here 289 >>> mock.__aiter__.return_value = [1, 2, 3] 290 >>> async def main(): 291 ... return [i async for i in mock] 292 ... 293 >>> asyncio.run(main()) 294 [1, 2, 3] 295 296 297Mocking asynchronous context manager 298~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 299 300Since Python 3.8, ``AsyncMock`` and ``MagicMock`` have support to mock 301:ref:`async-context-managers` through ``__aenter__`` and ``__aexit__``. 302By default, ``__aenter__`` and ``__aexit__`` are ``AsyncMock`` instances that 303return an async function. 304 305 >>> class AsyncContextManager: 306 ... async def __aenter__(self): 307 ... return self 308 ... async def __aexit__(self, exc_type, exc, tb): 309 ... pass 310 ... 311 >>> mock_instance = MagicMock(AsyncContextManager()) # AsyncMock also works here 312 >>> async def main(): 313 ... async with mock_instance as result: 314 ... pass 315 ... 316 >>> asyncio.run(main()) 317 >>> mock_instance.__aenter__.assert_awaited_once() 318 >>> mock_instance.__aexit__.assert_awaited_once() 319 320 321Creating a Mock from an Existing Object 322~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 323 324One problem with over use of mocking is that it couples your tests to the 325implementation of your mocks rather than your real code. Suppose you have a 326class that implements ``some_method``. In a test for another class, you 327provide a mock of this object that *also* provides ``some_method``. If later 328you refactor the first class, so that it no longer has ``some_method`` - then 329your tests will continue to pass even though your code is now broken! 330 331:class:`Mock` allows you to provide an object as a specification for the mock, 332using the *spec* keyword argument. Accessing methods / attributes on the 333mock that don't exist on your specification object will immediately raise an 334attribute error. If you change the implementation of your specification, then 335tests that use that class will start failing immediately without you having to 336instantiate the class in those tests. 337 338 >>> mock = Mock(spec=SomeClass) 339 >>> mock.old_method() 340 Traceback (most recent call last): 341 ... 342 AttributeError: object has no attribute 'old_method' 343 344Using a specification also enables a smarter matching of calls made to the 345mock, regardless of whether some parameters were passed as positional or 346named arguments:: 347 348 >>> def f(a, b, c): pass 349 ... 350 >>> mock = Mock(spec=f) 351 >>> mock(1, 2, 3) 352 <Mock name='mock()' id='140161580456576'> 353 >>> mock.assert_called_with(a=1, b=2, c=3) 354 355If you want this smarter matching to also work with method calls on the mock, 356you can use :ref:`auto-speccing <auto-speccing>`. 357 358If you want a stronger form of specification that prevents the setting 359of arbitrary attributes as well as the getting of them then you can use 360*spec_set* instead of *spec*. 361 362 363 364Patch Decorators 365---------------- 366 367.. note:: 368 369 With :func:`patch` it matters that you patch objects in the namespace where 370 they are looked up. This is normally straightforward, but for a quick guide 371 read :ref:`where to patch <where-to-patch>`. 372 373 374A common need in tests is to patch a class attribute or a module attribute, 375for example patching a builtin or patching a class in a module to test that it 376is instantiated. Modules and classes are effectively global, so patching on 377them has to be undone after the test or the patch will persist into other 378tests and cause hard to diagnose problems. 379 380mock provides three convenient decorators for this: :func:`patch`, :func:`patch.object` and 381:func:`patch.dict`. ``patch`` takes a single string, of the form 382``package.module.Class.attribute`` to specify the attribute you are patching. It 383also optionally takes a value that you want the attribute (or class or 384whatever) to be replaced with. 'patch.object' takes an object and the name of 385the attribute you would like patched, plus optionally the value to patch it 386with. 387 388``patch.object``:: 389 390 >>> original = SomeClass.attribute 391 >>> @patch.object(SomeClass, 'attribute', sentinel.attribute) 392 ... def test(): 393 ... assert SomeClass.attribute == sentinel.attribute 394 ... 395 >>> test() 396 >>> assert SomeClass.attribute == original 397 398 >>> @patch('package.module.attribute', sentinel.attribute) 399 ... def test(): 400 ... from package.module import attribute 401 ... assert attribute is sentinel.attribute 402 ... 403 >>> test() 404 405If you are patching a module (including :mod:`builtins`) then use :func:`patch` 406instead of :func:`patch.object`: 407 408 >>> mock = MagicMock(return_value=sentinel.file_handle) 409 >>> with patch('builtins.open', mock): 410 ... handle = open('filename', 'r') 411 ... 412 >>> mock.assert_called_with('filename', 'r') 413 >>> assert handle == sentinel.file_handle, "incorrect file handle returned" 414 415The module name can be 'dotted', in the form ``package.module`` if needed:: 416 417 >>> @patch('package.module.ClassName.attribute', sentinel.attribute) 418 ... def test(): 419 ... from package.module import ClassName 420 ... assert ClassName.attribute == sentinel.attribute 421 ... 422 >>> test() 423 424A nice pattern is to actually decorate test methods themselves: 425 426 >>> class MyTest(unittest.TestCase): 427 ... @patch.object(SomeClass, 'attribute', sentinel.attribute) 428 ... def test_something(self): 429 ... self.assertEqual(SomeClass.attribute, sentinel.attribute) 430 ... 431 >>> original = SomeClass.attribute 432 >>> MyTest('test_something').test_something() 433 >>> assert SomeClass.attribute == original 434 435If you want to patch with a Mock, you can use :func:`patch` with only one argument 436(or :func:`patch.object` with two arguments). The mock will be created for you and 437passed into the test function / method: 438 439 >>> class MyTest(unittest.TestCase): 440 ... @patch.object(SomeClass, 'static_method') 441 ... def test_something(self, mock_method): 442 ... SomeClass.static_method() 443 ... mock_method.assert_called_with() 444 ... 445 >>> MyTest('test_something').test_something() 446 447You can stack up multiple patch decorators using this pattern:: 448 449 >>> class MyTest(unittest.TestCase): 450 ... @patch('package.module.ClassName1') 451 ... @patch('package.module.ClassName2') 452 ... def test_something(self, MockClass2, MockClass1): 453 ... self.assertIs(package.module.ClassName1, MockClass1) 454 ... self.assertIs(package.module.ClassName2, MockClass2) 455 ... 456 >>> MyTest('test_something').test_something() 457 458When you nest patch decorators the mocks are passed in to the decorated 459function in the same order they applied (the normal *Python* order that 460decorators are applied). This means from the bottom up, so in the example 461above the mock for ``test_module.ClassName2`` is passed in first. 462 463There is also :func:`patch.dict` for setting values in a dictionary just 464during a scope and restoring the dictionary to its original state when the test 465ends: 466 467 >>> foo = {'key': 'value'} 468 >>> original = foo.copy() 469 >>> with patch.dict(foo, {'newkey': 'newvalue'}, clear=True): 470 ... assert foo == {'newkey': 'newvalue'} 471 ... 472 >>> assert foo == original 473 474``patch``, ``patch.object`` and ``patch.dict`` can all be used as context managers. 475 476Where you use :func:`patch` to create a mock for you, you can get a reference to the 477mock using the "as" form of the with statement: 478 479 >>> class ProductionClass: 480 ... def method(self): 481 ... pass 482 ... 483 >>> with patch.object(ProductionClass, 'method') as mock_method: 484 ... mock_method.return_value = None 485 ... real = ProductionClass() 486 ... real.method(1, 2, 3) 487 ... 488 >>> mock_method.assert_called_with(1, 2, 3) 489 490 491As an alternative ``patch``, ``patch.object`` and ``patch.dict`` can be used as 492class decorators. When used in this way it is the same as applying the 493decorator individually to every method whose name starts with "test". 494 495 496.. _further-examples: 497 498Further Examples 499---------------- 500 501 502Here are some more examples for some slightly more advanced scenarios. 503 504 505Mocking chained calls 506~~~~~~~~~~~~~~~~~~~~~ 507 508Mocking chained calls is actually straightforward with mock once you 509understand the :attr:`~Mock.return_value` attribute. When a mock is called for 510the first time, or you fetch its ``return_value`` before it has been called, a 511new :class:`Mock` is created. 512 513This means that you can see how the object returned from a call to a mocked 514object has been used by interrogating the ``return_value`` mock: 515 516 >>> mock = Mock() 517 >>> mock().foo(a=2, b=3) 518 <Mock name='mock().foo()' id='...'> 519 >>> mock.return_value.foo.assert_called_with(a=2, b=3) 520 521From here it is a simple step to configure and then make assertions about 522chained calls. Of course another alternative is writing your code in a more 523testable way in the first place... 524 525So, suppose we have some code that looks a little bit like this: 526 527 >>> class Something: 528 ... def __init__(self): 529 ... self.backend = BackendProvider() 530 ... def method(self): 531 ... response = self.backend.get_endpoint('foobar').create_call('spam', 'eggs').start_call() 532 ... # more code 533 534Assuming that ``BackendProvider`` is already well tested, how do we test 535``method()``? Specifically, we want to test that the code section ``# more 536code`` uses the response object in the correct way. 537 538As this chain of calls is made from an instance attribute we can monkey patch 539the ``backend`` attribute on a ``Something`` instance. In this particular case 540we are only interested in the return value from the final call to 541``start_call`` so we don't have much configuration to do. Let's assume the 542object it returns is 'file-like', so we'll ensure that our response object 543uses the builtin :func:`open` as its ``spec``. 544 545To do this we create a mock instance as our mock backend and create a mock 546response object for it. To set the response as the return value for that final 547``start_call`` we could do this:: 548 549 mock_backend.get_endpoint.return_value.create_call.return_value.start_call.return_value = mock_response 550 551We can do that in a slightly nicer way using the :meth:`~Mock.configure_mock` 552method to directly set the return value for us:: 553 554 >>> something = Something() 555 >>> mock_response = Mock(spec=open) 556 >>> mock_backend = Mock() 557 >>> config = {'get_endpoint.return_value.create_call.return_value.start_call.return_value': mock_response} 558 >>> mock_backend.configure_mock(**config) 559 560With these we monkey patch the "mock backend" in place and can make the real 561call:: 562 563 >>> something.backend = mock_backend 564 >>> something.method() 565 566Using :attr:`~Mock.mock_calls` we can check the chained call with a single 567assert. A chained call is several calls in one line of code, so there will be 568several entries in ``mock_calls``. We can use :meth:`call.call_list` to create 569this list of calls for us:: 570 571 >>> chained = call.get_endpoint('foobar').create_call('spam', 'eggs').start_call() 572 >>> call_list = chained.call_list() 573 >>> assert mock_backend.mock_calls == call_list 574 575 576Partial mocking 577~~~~~~~~~~~~~~~ 578 579In some tests I wanted to mock out a call to :meth:`datetime.date.today` 580to return a known date, but I didn't want to prevent the code under test from 581creating new date objects. Unfortunately :class:`datetime.date` is written in C, and 582so I couldn't just monkey-patch out the static :meth:`date.today` method. 583 584I found a simple way of doing this that involved effectively wrapping the date 585class with a mock, but passing through calls to the constructor to the real 586class (and returning real instances). 587 588The :func:`patch decorator <patch>` is used here to 589mock out the ``date`` class in the module under test. The :attr:`side_effect` 590attribute on the mock date class is then set to a lambda function that returns 591a real date. When the mock date class is called a real date will be 592constructed and returned by ``side_effect``. :: 593 594 >>> from datetime import date 595 >>> with patch('mymodule.date') as mock_date: 596 ... mock_date.today.return_value = date(2010, 10, 8) 597 ... mock_date.side_effect = lambda *args, **kw: date(*args, **kw) 598 ... 599 ... assert mymodule.date.today() == date(2010, 10, 8) 600 ... assert mymodule.date(2009, 6, 8) == date(2009, 6, 8) 601 602Note that we don't patch :class:`datetime.date` globally, we patch ``date`` in the 603module that *uses* it. See :ref:`where to patch <where-to-patch>`. 604 605When ``date.today()`` is called a known date is returned, but calls to the 606``date(...)`` constructor still return normal dates. Without this you can find 607yourself having to calculate an expected result using exactly the same 608algorithm as the code under test, which is a classic testing anti-pattern. 609 610Calls to the date constructor are recorded in the ``mock_date`` attributes 611(``call_count`` and friends) which may also be useful for your tests. 612 613An alternative way of dealing with mocking dates, or other builtin classes, 614is discussed in `this blog entry 615<https://williambert.online/2011/07/how-to-unit-testing-in-django-with-mocking-and-patching/>`_. 616 617 618Mocking a Generator Method 619~~~~~~~~~~~~~~~~~~~~~~~~~~ 620 621A Python generator is a function or method that uses the :keyword:`yield` statement 622to return a series of values when iterated over [#]_. 623 624A generator method / function is called to return the generator object. It is 625the generator object that is then iterated over. The protocol method for 626iteration is :meth:`~container.__iter__`, so we can 627mock this using a :class:`MagicMock`. 628 629Here's an example class with an "iter" method implemented as a generator: 630 631 >>> class Foo: 632 ... def iter(self): 633 ... for i in [1, 2, 3]: 634 ... yield i 635 ... 636 >>> foo = Foo() 637 >>> list(foo.iter()) 638 [1, 2, 3] 639 640 641How would we mock this class, and in particular its "iter" method? 642 643To configure the values returned from the iteration (implicit in the call to 644:class:`list`), we need to configure the object returned by the call to ``foo.iter()``. 645 646 >>> mock_foo = MagicMock() 647 >>> mock_foo.iter.return_value = iter([1, 2, 3]) 648 >>> list(mock_foo.iter()) 649 [1, 2, 3] 650 651.. [#] There are also generator expressions and more `advanced uses 652 <http://www.dabeaz.com/coroutines/index.html>`_ of generators, but we aren't 653 concerned about them here. A very good introduction to generators and how 654 powerful they are is: `Generator Tricks for Systems Programmers 655 <http://www.dabeaz.com/generators/>`_. 656 657 658Applying the same patch to every test method 659~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 660 661If you want several patches in place for multiple test methods the obvious way 662is to apply the patch decorators to every method. This can feel like unnecessary 663repetition. For Python 2.6 or more recent you can use :func:`patch` (in all its 664various forms) as a class decorator. This applies the patches to all test 665methods on the class. A test method is identified by methods whose names start 666with ``test``:: 667 668 >>> @patch('mymodule.SomeClass') 669 ... class MyTest(unittest.TestCase): 670 ... 671 ... def test_one(self, MockSomeClass): 672 ... self.assertIs(mymodule.SomeClass, MockSomeClass) 673 ... 674 ... def test_two(self, MockSomeClass): 675 ... self.assertIs(mymodule.SomeClass, MockSomeClass) 676 ... 677 ... def not_a_test(self): 678 ... return 'something' 679 ... 680 >>> MyTest('test_one').test_one() 681 >>> MyTest('test_two').test_two() 682 >>> MyTest('test_two').not_a_test() 683 'something' 684 685An alternative way of managing patches is to use the :ref:`start-and-stop`. 686These allow you to move the patching into your ``setUp`` and ``tearDown`` methods. 687:: 688 689 >>> class MyTest(unittest.TestCase): 690 ... def setUp(self): 691 ... self.patcher = patch('mymodule.foo') 692 ... self.mock_foo = self.patcher.start() 693 ... 694 ... def test_foo(self): 695 ... self.assertIs(mymodule.foo, self.mock_foo) 696 ... 697 ... def tearDown(self): 698 ... self.patcher.stop() 699 ... 700 >>> MyTest('test_foo').run() 701 702If you use this technique you must ensure that the patching is "undone" by 703calling ``stop``. This can be fiddlier than you might think, because if an 704exception is raised in the setUp then tearDown is not called. 705:meth:`unittest.TestCase.addCleanup` makes this easier:: 706 707 >>> class MyTest(unittest.TestCase): 708 ... def setUp(self): 709 ... patcher = patch('mymodule.foo') 710 ... self.addCleanup(patcher.stop) 711 ... self.mock_foo = patcher.start() 712 ... 713 ... def test_foo(self): 714 ... self.assertIs(mymodule.foo, self.mock_foo) 715 ... 716 >>> MyTest('test_foo').run() 717 718 719Mocking Unbound Methods 720~~~~~~~~~~~~~~~~~~~~~~~ 721 722Whilst writing tests today I needed to patch an *unbound method* (patching the 723method on the class rather than on the instance). I needed self to be passed 724in as the first argument because I want to make asserts about which objects 725were calling this particular method. The issue is that you can't patch with a 726mock for this, because if you replace an unbound method with a mock it doesn't 727become a bound method when fetched from the instance, and so it doesn't get 728self passed in. The workaround is to patch the unbound method with a real 729function instead. The :func:`patch` decorator makes it so simple to 730patch out methods with a mock that having to create a real function becomes a 731nuisance. 732 733If you pass ``autospec=True`` to patch then it does the patching with a 734*real* function object. This function object has the same signature as the one 735it is replacing, but delegates to a mock under the hood. You still get your 736mock auto-created in exactly the same way as before. What it means though, is 737that if you use it to patch out an unbound method on a class the mocked 738function will be turned into a bound method if it is fetched from an instance. 739It will have ``self`` passed in as the first argument, which is exactly what I 740wanted: 741 742 >>> class Foo: 743 ... def foo(self): 744 ... pass 745 ... 746 >>> with patch.object(Foo, 'foo', autospec=True) as mock_foo: 747 ... mock_foo.return_value = 'foo' 748 ... foo = Foo() 749 ... foo.foo() 750 ... 751 'foo' 752 >>> mock_foo.assert_called_once_with(foo) 753 754If we don't use ``autospec=True`` then the unbound method is patched out 755with a Mock instance instead, and isn't called with ``self``. 756 757 758Checking multiple calls with mock 759~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 760 761mock has a nice API for making assertions about how your mock objects are used. 762 763 >>> mock = Mock() 764 >>> mock.foo_bar.return_value = None 765 >>> mock.foo_bar('baz', spam='eggs') 766 >>> mock.foo_bar.assert_called_with('baz', spam='eggs') 767 768If your mock is only being called once you can use the 769:meth:`assert_called_once_with` method that also asserts that the 770:attr:`call_count` is one. 771 772 >>> mock.foo_bar.assert_called_once_with('baz', spam='eggs') 773 >>> mock.foo_bar() 774 >>> mock.foo_bar.assert_called_once_with('baz', spam='eggs') 775 Traceback (most recent call last): 776 ... 777 AssertionError: Expected to be called once. Called 2 times. 778 779Both ``assert_called_with`` and ``assert_called_once_with`` make assertions about 780the *most recent* call. If your mock is going to be called several times, and 781you want to make assertions about *all* those calls you can use 782:attr:`~Mock.call_args_list`: 783 784 >>> mock = Mock(return_value=None) 785 >>> mock(1, 2, 3) 786 >>> mock(4, 5, 6) 787 >>> mock() 788 >>> mock.call_args_list 789 [call(1, 2, 3), call(4, 5, 6), call()] 790 791The :data:`call` helper makes it easy to make assertions about these calls. You 792can build up a list of expected calls and compare it to ``call_args_list``. This 793looks remarkably similar to the repr of the ``call_args_list``: 794 795 >>> expected = [call(1, 2, 3), call(4, 5, 6), call()] 796 >>> mock.call_args_list == expected 797 True 798 799 800Coping with mutable arguments 801~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 802 803Another situation is rare, but can bite you, is when your mock is called with 804mutable arguments. ``call_args`` and ``call_args_list`` store *references* to the 805arguments. If the arguments are mutated by the code under test then you can no 806longer make assertions about what the values were when the mock was called. 807 808Here's some example code that shows the problem. Imagine the following functions 809defined in 'mymodule':: 810 811 def frob(val): 812 pass 813 814 def grob(val): 815 "First frob and then clear val" 816 frob(val) 817 val.clear() 818 819When we try to test that ``grob`` calls ``frob`` with the correct argument look 820what happens:: 821 822 >>> with patch('mymodule.frob') as mock_frob: 823 ... val = {6} 824 ... mymodule.grob(val) 825 ... 826 >>> val 827 set() 828 >>> mock_frob.assert_called_with({6}) 829 Traceback (most recent call last): 830 ... 831 AssertionError: Expected: (({6},), {}) 832 Called with: ((set(),), {}) 833 834One possibility would be for mock to copy the arguments you pass in. This 835could then cause problems if you do assertions that rely on object identity 836for equality. 837 838Here's one solution that uses the :attr:`side_effect` 839functionality. If you provide a ``side_effect`` function for a mock then 840``side_effect`` will be called with the same args as the mock. This gives us an 841opportunity to copy the arguments and store them for later assertions. In this 842example I'm using *another* mock to store the arguments so that I can use the 843mock methods for doing the assertion. Again a helper function sets this up for 844me. :: 845 846 >>> from copy import deepcopy 847 >>> from unittest.mock import Mock, patch, DEFAULT 848 >>> def copy_call_args(mock): 849 ... new_mock = Mock() 850 ... def side_effect(*args, **kwargs): 851 ... args = deepcopy(args) 852 ... kwargs = deepcopy(kwargs) 853 ... new_mock(*args, **kwargs) 854 ... return DEFAULT 855 ... mock.side_effect = side_effect 856 ... return new_mock 857 ... 858 >>> with patch('mymodule.frob') as mock_frob: 859 ... new_mock = copy_call_args(mock_frob) 860 ... val = {6} 861 ... mymodule.grob(val) 862 ... 863 >>> new_mock.assert_called_with({6}) 864 >>> new_mock.call_args 865 call({6}) 866 867``copy_call_args`` is called with the mock that will be called. It returns a new 868mock that we do the assertion on. The ``side_effect`` function makes a copy of 869the args and calls our ``new_mock`` with the copy. 870 871.. note:: 872 873 If your mock is only going to be used once there is an easier way of 874 checking arguments at the point they are called. You can simply do the 875 checking inside a ``side_effect`` function. 876 877 >>> def side_effect(arg): 878 ... assert arg == {6} 879 ... 880 >>> mock = Mock(side_effect=side_effect) 881 >>> mock({6}) 882 >>> mock(set()) 883 Traceback (most recent call last): 884 ... 885 AssertionError 886 887An alternative approach is to create a subclass of :class:`Mock` or 888:class:`MagicMock` that copies (using :func:`copy.deepcopy`) the arguments. 889Here's an example implementation: 890 891 >>> from copy import deepcopy 892 >>> class CopyingMock(MagicMock): 893 ... def __call__(self, /, *args, **kwargs): 894 ... args = deepcopy(args) 895 ... kwargs = deepcopy(kwargs) 896 ... return super().__call__(*args, **kwargs) 897 ... 898 >>> c = CopyingMock(return_value=None) 899 >>> arg = set() 900 >>> c(arg) 901 >>> arg.add(1) 902 >>> c.assert_called_with(set()) 903 >>> c.assert_called_with(arg) 904 Traceback (most recent call last): 905 ... 906 AssertionError: Expected call: mock({1}) 907 Actual call: mock(set()) 908 >>> c.foo 909 <CopyingMock name='mock.foo' id='...'> 910 911When you subclass ``Mock`` or ``MagicMock`` all dynamically created attributes, 912and the ``return_value`` will use your subclass automatically. That means all 913children of a ``CopyingMock`` will also have the type ``CopyingMock``. 914 915 916Nesting Patches 917~~~~~~~~~~~~~~~ 918 919Using patch as a context manager is nice, but if you do multiple patches you 920can end up with nested with statements indenting further and further to the 921right:: 922 923 >>> class MyTest(unittest.TestCase): 924 ... 925 ... def test_foo(self): 926 ... with patch('mymodule.Foo') as mock_foo: 927 ... with patch('mymodule.Bar') as mock_bar: 928 ... with patch('mymodule.Spam') as mock_spam: 929 ... assert mymodule.Foo is mock_foo 930 ... assert mymodule.Bar is mock_bar 931 ... assert mymodule.Spam is mock_spam 932 ... 933 >>> original = mymodule.Foo 934 >>> MyTest('test_foo').test_foo() 935 >>> assert mymodule.Foo is original 936 937With unittest ``cleanup`` functions and the :ref:`start-and-stop` we can 938achieve the same effect without the nested indentation. A simple helper 939method, ``create_patch``, puts the patch in place and returns the created mock 940for us:: 941 942 >>> class MyTest(unittest.TestCase): 943 ... 944 ... def create_patch(self, name): 945 ... patcher = patch(name) 946 ... thing = patcher.start() 947 ... self.addCleanup(patcher.stop) 948 ... return thing 949 ... 950 ... def test_foo(self): 951 ... mock_foo = self.create_patch('mymodule.Foo') 952 ... mock_bar = self.create_patch('mymodule.Bar') 953 ... mock_spam = self.create_patch('mymodule.Spam') 954 ... 955 ... assert mymodule.Foo is mock_foo 956 ... assert mymodule.Bar is mock_bar 957 ... assert mymodule.Spam is mock_spam 958 ... 959 >>> original = mymodule.Foo 960 >>> MyTest('test_foo').run() 961 >>> assert mymodule.Foo is original 962 963 964Mocking a dictionary with MagicMock 965~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 966 967You may want to mock a dictionary, or other container object, recording all 968access to it whilst having it still behave like a dictionary. 969 970We can do this with :class:`MagicMock`, which will behave like a dictionary, 971and using :data:`~Mock.side_effect` to delegate dictionary access to a real 972underlying dictionary that is under our control. 973 974When the :meth:`__getitem__` and :meth:`__setitem__` methods of our ``MagicMock`` are called 975(normal dictionary access) then ``side_effect`` is called with the key (and in 976the case of ``__setitem__`` the value too). We can also control what is returned. 977 978After the ``MagicMock`` has been used we can use attributes like 979:data:`~Mock.call_args_list` to assert about how the dictionary was used: 980 981 >>> my_dict = {'a': 1, 'b': 2, 'c': 3} 982 >>> def getitem(name): 983 ... return my_dict[name] 984 ... 985 >>> def setitem(name, val): 986 ... my_dict[name] = val 987 ... 988 >>> mock = MagicMock() 989 >>> mock.__getitem__.side_effect = getitem 990 >>> mock.__setitem__.side_effect = setitem 991 992.. note:: 993 994 An alternative to using ``MagicMock`` is to use ``Mock`` and *only* provide 995 the magic methods you specifically want: 996 997 >>> mock = Mock() 998 >>> mock.__getitem__ = Mock(side_effect=getitem) 999 >>> mock.__setitem__ = Mock(side_effect=setitem) 1000 1001 A *third* option is to use ``MagicMock`` but passing in ``dict`` as the *spec* 1002 (or *spec_set*) argument so that the ``MagicMock`` created only has 1003 dictionary magic methods available: 1004 1005 >>> mock = MagicMock(spec_set=dict) 1006 >>> mock.__getitem__.side_effect = getitem 1007 >>> mock.__setitem__.side_effect = setitem 1008 1009With these side effect functions in place, the ``mock`` will behave like a normal 1010dictionary but recording the access. It even raises a :exc:`KeyError` if you try 1011to access a key that doesn't exist. 1012 1013 >>> mock['a'] 1014 1 1015 >>> mock['c'] 1016 3 1017 >>> mock['d'] 1018 Traceback (most recent call last): 1019 ... 1020 KeyError: 'd' 1021 >>> mock['b'] = 'fish' 1022 >>> mock['d'] = 'eggs' 1023 >>> mock['b'] 1024 'fish' 1025 >>> mock['d'] 1026 'eggs' 1027 1028After it has been used you can make assertions about the access using the normal 1029mock methods and attributes: 1030 1031 >>> mock.__getitem__.call_args_list 1032 [call('a'), call('c'), call('d'), call('b'), call('d')] 1033 >>> mock.__setitem__.call_args_list 1034 [call('b', 'fish'), call('d', 'eggs')] 1035 >>> my_dict 1036 {'a': 1, 'b': 'fish', 'c': 3, 'd': 'eggs'} 1037 1038 1039Mock subclasses and their attributes 1040~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 1041 1042There are various reasons why you might want to subclass :class:`Mock`. One 1043reason might be to add helper methods. Here's a silly example: 1044 1045 >>> class MyMock(MagicMock): 1046 ... def has_been_called(self): 1047 ... return self.called 1048 ... 1049 >>> mymock = MyMock(return_value=None) 1050 >>> mymock 1051 <MyMock id='...'> 1052 >>> mymock.has_been_called() 1053 False 1054 >>> mymock() 1055 >>> mymock.has_been_called() 1056 True 1057 1058The standard behaviour for ``Mock`` instances is that attributes and the return 1059value mocks are of the same type as the mock they are accessed on. This ensures 1060that ``Mock`` attributes are ``Mocks`` and ``MagicMock`` attributes are ``MagicMocks`` 1061[#]_. So if you're subclassing to add helper methods then they'll also be 1062available on the attributes and return value mock of instances of your 1063subclass. 1064 1065 >>> mymock.foo 1066 <MyMock name='mock.foo' id='...'> 1067 >>> mymock.foo.has_been_called() 1068 False 1069 >>> mymock.foo() 1070 <MyMock name='mock.foo()' id='...'> 1071 >>> mymock.foo.has_been_called() 1072 True 1073 1074Sometimes this is inconvenient. For example, `one user 1075<https://code.google.com/archive/p/mock/issues/105>`_ is subclassing mock to 1076created a `Twisted adaptor 1077<https://twistedmatrix.com/documents/11.0.0/api/twisted.python.components.html>`_. 1078Having this applied to attributes too actually causes errors. 1079 1080``Mock`` (in all its flavours) uses a method called ``_get_child_mock`` to create 1081these "sub-mocks" for attributes and return values. You can prevent your 1082subclass being used for attributes by overriding this method. The signature is 1083that it takes arbitrary keyword arguments (``**kwargs``) which are then passed 1084onto the mock constructor: 1085 1086 >>> class Subclass(MagicMock): 1087 ... def _get_child_mock(self, /, **kwargs): 1088 ... return MagicMock(**kwargs) 1089 ... 1090 >>> mymock = Subclass() 1091 >>> mymock.foo 1092 <MagicMock name='mock.foo' id='...'> 1093 >>> assert isinstance(mymock, Subclass) 1094 >>> assert not isinstance(mymock.foo, Subclass) 1095 >>> assert not isinstance(mymock(), Subclass) 1096 1097.. [#] An exception to this rule are the non-callable mocks. Attributes use the 1098 callable variant because otherwise non-callable mocks couldn't have callable 1099 methods. 1100 1101 1102Mocking imports with patch.dict 1103~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 1104 1105One situation where mocking can be hard is where you have a local import inside 1106a function. These are harder to mock because they aren't using an object from 1107the module namespace that we can patch out. 1108 1109Generally local imports are to be avoided. They are sometimes done to prevent 1110circular dependencies, for which there is *usually* a much better way to solve 1111the problem (refactor the code) or to prevent "up front costs" by delaying the 1112import. This can also be solved in better ways than an unconditional local 1113import (store the module as a class or module attribute and only do the import 1114on first use). 1115 1116That aside there is a way to use ``mock`` to affect the results of an import. 1117Importing fetches an *object* from the :data:`sys.modules` dictionary. Note that it 1118fetches an *object*, which need not be a module. Importing a module for the 1119first time results in a module object being put in `sys.modules`, so usually 1120when you import something you get a module back. This need not be the case 1121however. 1122 1123This means you can use :func:`patch.dict` to *temporarily* put a mock in place 1124in :data:`sys.modules`. Any imports whilst this patch is active will fetch the mock. 1125When the patch is complete (the decorated function exits, the with statement 1126body is complete or ``patcher.stop()`` is called) then whatever was there 1127previously will be restored safely. 1128 1129Here's an example that mocks out the 'fooble' module. 1130 1131 >>> import sys 1132 >>> mock = Mock() 1133 >>> with patch.dict('sys.modules', {'fooble': mock}): 1134 ... import fooble 1135 ... fooble.blob() 1136 ... 1137 <Mock name='mock.blob()' id='...'> 1138 >>> assert 'fooble' not in sys.modules 1139 >>> mock.blob.assert_called_once_with() 1140 1141As you can see the ``import fooble`` succeeds, but on exit there is no 'fooble' 1142left in :data:`sys.modules`. 1143 1144This also works for the ``from module import name`` form: 1145 1146 >>> mock = Mock() 1147 >>> with patch.dict('sys.modules', {'fooble': mock}): 1148 ... from fooble import blob 1149 ... blob.blip() 1150 ... 1151 <Mock name='mock.blob.blip()' id='...'> 1152 >>> mock.blob.blip.assert_called_once_with() 1153 1154With slightly more work you can also mock package imports: 1155 1156 >>> mock = Mock() 1157 >>> modules = {'package': mock, 'package.module': mock.module} 1158 >>> with patch.dict('sys.modules', modules): 1159 ... from package.module import fooble 1160 ... fooble() 1161 ... 1162 <Mock name='mock.module.fooble()' id='...'> 1163 >>> mock.module.fooble.assert_called_once_with() 1164 1165 1166Tracking order of calls and less verbose call assertions 1167~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 1168 1169The :class:`Mock` class allows you to track the *order* of method calls on 1170your mock objects through the :attr:`~Mock.method_calls` attribute. This 1171doesn't allow you to track the order of calls between separate mock objects, 1172however we can use :attr:`~Mock.mock_calls` to achieve the same effect. 1173 1174Because mocks track calls to child mocks in ``mock_calls``, and accessing an 1175arbitrary attribute of a mock creates a child mock, we can create our separate 1176mocks from a parent one. Calls to those child mock will then all be recorded, 1177in order, in the ``mock_calls`` of the parent: 1178 1179 >>> manager = Mock() 1180 >>> mock_foo = manager.foo 1181 >>> mock_bar = manager.bar 1182 1183 >>> mock_foo.something() 1184 <Mock name='mock.foo.something()' id='...'> 1185 >>> mock_bar.other.thing() 1186 <Mock name='mock.bar.other.thing()' id='...'> 1187 1188 >>> manager.mock_calls 1189 [call.foo.something(), call.bar.other.thing()] 1190 1191We can then assert about the calls, including the order, by comparing with 1192the ``mock_calls`` attribute on the manager mock: 1193 1194 >>> expected_calls = [call.foo.something(), call.bar.other.thing()] 1195 >>> manager.mock_calls == expected_calls 1196 True 1197 1198If ``patch`` is creating, and putting in place, your mocks then you can attach 1199them to a manager mock using the :meth:`~Mock.attach_mock` method. After 1200attaching calls will be recorded in ``mock_calls`` of the manager. :: 1201 1202 >>> manager = MagicMock() 1203 >>> with patch('mymodule.Class1') as MockClass1: 1204 ... with patch('mymodule.Class2') as MockClass2: 1205 ... manager.attach_mock(MockClass1, 'MockClass1') 1206 ... manager.attach_mock(MockClass2, 'MockClass2') 1207 ... MockClass1().foo() 1208 ... MockClass2().bar() 1209 <MagicMock name='mock.MockClass1().foo()' id='...'> 1210 <MagicMock name='mock.MockClass2().bar()' id='...'> 1211 >>> manager.mock_calls 1212 [call.MockClass1(), 1213 call.MockClass1().foo(), 1214 call.MockClass2(), 1215 call.MockClass2().bar()] 1216 1217If many calls have been made, but you're only interested in a particular 1218sequence of them then an alternative is to use the 1219:meth:`~Mock.assert_has_calls` method. This takes a list of calls (constructed 1220with the :data:`call` object). If that sequence of calls are in 1221:attr:`~Mock.mock_calls` then the assert succeeds. 1222 1223 >>> m = MagicMock() 1224 >>> m().foo().bar().baz() 1225 <MagicMock name='mock().foo().bar().baz()' id='...'> 1226 >>> m.one().two().three() 1227 <MagicMock name='mock.one().two().three()' id='...'> 1228 >>> calls = call.one().two().three().call_list() 1229 >>> m.assert_has_calls(calls) 1230 1231Even though the chained call ``m.one().two().three()`` aren't the only calls that 1232have been made to the mock, the assert still succeeds. 1233 1234Sometimes a mock may have several calls made to it, and you are only interested 1235in asserting about *some* of those calls. You may not even care about the 1236order. In this case you can pass ``any_order=True`` to ``assert_has_calls``: 1237 1238 >>> m = MagicMock() 1239 >>> m(1), m.two(2, 3), m.seven(7), m.fifty('50') 1240 (...) 1241 >>> calls = [call.fifty('50'), call(1), call.seven(7)] 1242 >>> m.assert_has_calls(calls, any_order=True) 1243 1244 1245More complex argument matching 1246~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 1247 1248Using the same basic concept as :data:`ANY` we can implement matchers to do more 1249complex assertions on objects used as arguments to mocks. 1250 1251Suppose we expect some object to be passed to a mock that by default 1252compares equal based on object identity (which is the Python default for user 1253defined classes). To use :meth:`~Mock.assert_called_with` we would need to pass 1254in the exact same object. If we are only interested in some of the attributes 1255of this object then we can create a matcher that will check these attributes 1256for us. 1257 1258You can see in this example how a 'standard' call to ``assert_called_with`` isn't 1259sufficient: 1260 1261 >>> class Foo: 1262 ... def __init__(self, a, b): 1263 ... self.a, self.b = a, b 1264 ... 1265 >>> mock = Mock(return_value=None) 1266 >>> mock(Foo(1, 2)) 1267 >>> mock.assert_called_with(Foo(1, 2)) 1268 Traceback (most recent call last): 1269 ... 1270 AssertionError: Expected: call(<__main__.Foo object at 0x...>) 1271 Actual call: call(<__main__.Foo object at 0x...>) 1272 1273A comparison function for our ``Foo`` class might look something like this: 1274 1275 >>> def compare(self, other): 1276 ... if not type(self) == type(other): 1277 ... return False 1278 ... if self.a != other.a: 1279 ... return False 1280 ... if self.b != other.b: 1281 ... return False 1282 ... return True 1283 ... 1284 1285And a matcher object that can use comparison functions like this for its 1286equality operation would look something like this: 1287 1288 >>> class Matcher: 1289 ... def __init__(self, compare, some_obj): 1290 ... self.compare = compare 1291 ... self.some_obj = some_obj 1292 ... def __eq__(self, other): 1293 ... return self.compare(self.some_obj, other) 1294 ... 1295 1296Putting all this together: 1297 1298 >>> match_foo = Matcher(compare, Foo(1, 2)) 1299 >>> mock.assert_called_with(match_foo) 1300 1301The ``Matcher`` is instantiated with our compare function and the ``Foo`` object 1302we want to compare against. In ``assert_called_with`` the ``Matcher`` equality 1303method will be called, which compares the object the mock was called with 1304against the one we created our matcher with. If they match then 1305``assert_called_with`` passes, and if they don't an :exc:`AssertionError` is raised: 1306 1307 >>> match_wrong = Matcher(compare, Foo(3, 4)) 1308 >>> mock.assert_called_with(match_wrong) 1309 Traceback (most recent call last): 1310 ... 1311 AssertionError: Expected: ((<Matcher object at 0x...>,), {}) 1312 Called with: ((<Foo object at 0x...>,), {}) 1313 1314With a bit of tweaking you could have the comparison function raise the 1315:exc:`AssertionError` directly and provide a more useful failure message. 1316 1317As of version 1.5, the Python testing library `PyHamcrest 1318<https://pyhamcrest.readthedocs.io/>`_ provides similar functionality, 1319that may be useful here, in the form of its equality matcher 1320(`hamcrest.library.integration.match_equality 1321<https://pyhamcrest.readthedocs.io/en/release-1.8/integration/#module-hamcrest.library.integration.match_equality>`_). 1322