mirror of
https://github.com/python/cpython.git
synced 2025-09-27 10:50:04 +00:00
Adding patch.stopall method to unittest.mock
This commit is contained in:
parent
bfcb42936b
commit
f7c4158057
3 changed files with 44 additions and 4 deletions
|
@ -1354,8 +1354,12 @@ method of a `TestCase`:
|
||||||
As an added bonus you no longer need to keep a reference to the `patcher`
|
As an added bonus you no longer need to keep a reference to the `patcher`
|
||||||
object.
|
object.
|
||||||
|
|
||||||
In fact `start` and `stop` are just aliases for the context manager
|
It is also possible to stop all patches which have been started by using
|
||||||
`__enter__` and `__exit__` methods.
|
`patch.stopall`.
|
||||||
|
|
||||||
|
.. function:: patch.stopall
|
||||||
|
|
||||||
|
Stop all active patches.
|
||||||
|
|
||||||
|
|
||||||
TEST_PREFIX
|
TEST_PREFIX
|
||||||
|
|
|
@ -1002,6 +1002,7 @@ def _is_started(patcher):
|
||||||
class _patch(object):
|
class _patch(object):
|
||||||
|
|
||||||
attribute_name = None
|
attribute_name = None
|
||||||
|
_active_patches = set()
|
||||||
|
|
||||||
def __init__(
|
def __init__(
|
||||||
self, getter, attribute, new, spec, create,
|
self, getter, attribute, new, spec, create,
|
||||||
|
@ -1270,8 +1271,18 @@ class _patch(object):
|
||||||
if _is_started(patcher):
|
if _is_started(patcher):
|
||||||
patcher.__exit__(*exc_info)
|
patcher.__exit__(*exc_info)
|
||||||
|
|
||||||
start = __enter__
|
|
||||||
stop = __exit__
|
def start(self):
|
||||||
|
"""Activate a patch, returning any created mock."""
|
||||||
|
result = self.__enter__()
|
||||||
|
self._active_patches.add(self)
|
||||||
|
return result
|
||||||
|
|
||||||
|
|
||||||
|
def stop(self):
|
||||||
|
"""Stop an active patch."""
|
||||||
|
self._active_patches.discard(self)
|
||||||
|
return self.__exit__()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -1562,9 +1573,16 @@ def _clear_dict(in_dict):
|
||||||
del in_dict[key]
|
del in_dict[key]
|
||||||
|
|
||||||
|
|
||||||
|
def _patch_stopall():
|
||||||
|
"""Stop all active patches."""
|
||||||
|
for patch in list(_patch._active_patches):
|
||||||
|
patch.stop()
|
||||||
|
|
||||||
|
|
||||||
patch.object = _patch_object
|
patch.object = _patch_object
|
||||||
patch.dict = _patch_dict
|
patch.dict = _patch_dict
|
||||||
patch.multiple = _patch_multiple
|
patch.multiple = _patch_multiple
|
||||||
|
patch.stopall = _patch_stopall
|
||||||
patch.TEST_PREFIX = 'test'
|
patch.TEST_PREFIX = 'test'
|
||||||
|
|
||||||
magic_methods = (
|
magic_methods = (
|
||||||
|
|
|
@ -1762,6 +1762,24 @@ class PatchTest(unittest.TestCase):
|
||||||
p.stop()
|
p.stop()
|
||||||
|
|
||||||
|
|
||||||
|
def test_patch_stopall(self):
|
||||||
|
unlink = os.unlink
|
||||||
|
chdir = os.chdir
|
||||||
|
path = os.path
|
||||||
|
patch('os.unlink', something).start()
|
||||||
|
patch('os.chdir', something_else).start()
|
||||||
|
|
||||||
|
@patch('os.path')
|
||||||
|
def patched(mock_path):
|
||||||
|
patch.stopall()
|
||||||
|
self.assertIs(os.path, mock_path)
|
||||||
|
self.assertIs(os.unlink, unlink)
|
||||||
|
self.assertIs(os.chdir, chdir)
|
||||||
|
|
||||||
|
patched()
|
||||||
|
self.assertIs(os.path, path)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
unittest.main()
|
unittest.main()
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue