diff options
Diffstat (limited to 'Lib/unittest/mock.py')
| -rw-r--r-- | Lib/unittest/mock.py | 15 | 
1 files changed, 10 insertions, 5 deletions
| diff --git a/Lib/unittest/mock.py b/Lib/unittest/mock.py index 13fd7b1af0..5555774467 100644 --- a/Lib/unittest/mock.py +++ b/Lib/unittest/mock.py @@ -1050,7 +1050,7 @@ def _is_started(patcher):  class _patch(object):      attribute_name = None -    _active_patches = set() +    _active_patches = []      def __init__(              self, getter, attribute, new, spec, create, @@ -1323,13 +1323,18 @@ class _patch(object):      def start(self):          """Activate a patch, returning any created mock."""          result = self.__enter__() -        self._active_patches.add(self) +        self._active_patches.append(self)          return result      def stop(self):          """Stop an active patch.""" -        self._active_patches.discard(self) +        try: +            self._active_patches.remove(self) +        except ValueError: +            # If the patch hasn't been started this will fail +            pass +          return self.__exit__() @@ -1622,8 +1627,8 @@ def _clear_dict(in_dict):  def _patch_stopall(): -    """Stop all active patches.""" -    for patch in list(_patch._active_patches): +    """Stop all active patches. LIFO to unroll nested patches.""" +    for patch in reversed(_patch._active_patches):          patch.stop() | 
