]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
bpo-38932: Mock fully resets child objects on reset_mock(). (GH-17409)
authorVegard Stikbakke <vegard.stikbakke@gmail.com>
Sat, 25 Jan 2020 15:44:46 +0000 (16:44 +0100)
committerChris Withers <chris@withers.org>
Sat, 25 Jan 2020 15:44:46 +0000 (15:44 +0000)
Lib/unittest/mock.py
Lib/unittest/test/testmock/testmock.py
Misc/NEWS.d/next/Library/2020-01-25-13-41-27.bpo-38932.1pu_8I.rst [new file with mode: 0644]

index a97542a2ddf00d5b7403b52b0689e29be6a17731..beed717522bba3da0a14fe8ecf0591488b12df07 100644 (file)
@@ -592,7 +592,7 @@ class NonCallableMock(Base):
         for child in self._mock_children.values():
             if isinstance(child, _SpecState) or child is _deleted:
                 continue
-            child.reset_mock(visited)
+            child.reset_mock(visited, return_value=return_value, side_effect=side_effect)
 
         ret = self._mock_return_value
         if _is_instance_mock(ret) and ret is not self:
index 1030d12323d36f4fc7e41c5cab0d70406db51a5c..1329346ae7246f1812f8ca3e6b22b70d4aa1a36f 100644 (file)
@@ -1636,11 +1636,23 @@ class MockTest(unittest.TestCase):
         self.assertNotEqual(m.side_effect, None)
 
     def test_reset_sideeffect(self):
-        m = Mock(return_value=10, side_effect=[2,3])
+        m = Mock(return_value=10, side_effect=[2, 3])
         m.reset_mock(side_effect=True)
         self.assertEqual(m.return_value, 10)
         self.assertEqual(m.side_effect, None)
 
+    def test_reset_return_with_children(self):
+        m = MagicMock(f=MagicMock(return_value=1))
+        self.assertEqual(m.f(), 1)
+        m.reset_mock(return_value=True)
+        self.assertNotEqual(m.f(), 1)
+
+    def test_reset_return_with_children_side_effect(self):
+        m = MagicMock(f=MagicMock(side_effect=[2, 3]))
+        self.assertNotEqual(m.f.side_effect, None)
+        m.reset_mock(side_effect=True)
+        self.assertEqual(m.f.side_effect, None)
+
     def test_mock_add_spec(self):
         class _One(object):
             one = 1
diff --git a/Misc/NEWS.d/next/Library/2020-01-25-13-41-27.bpo-38932.1pu_8I.rst b/Misc/NEWS.d/next/Library/2020-01-25-13-41-27.bpo-38932.1pu_8I.rst
new file mode 100644 (file)
index 0000000..d9ce8e8
--- /dev/null
@@ -0,0 +1 @@
+Mock fully resets child objects on reset_mock(). Patch by Vegard Stikbakke