diff options
author | Michael Foord <michael@voidspace.org.uk> | 2014-04-14 15:26:38 (GMT) |
---|---|---|
committer | Michael Foord <michael@voidspace.org.uk> | 2014-04-14 15:26:38 (GMT) |
commit | 1b16436c00aaabb3ec10c49ff4cc131c6aa9f4ca (patch) | |
tree | e0ee4e2fa3d824bf199322900017ff82a708bc06 | |
parent | abf079de2556578a4250c671ddbb83e7399b3e1d (diff) | |
parent | d2623d778663c1fee90a8835c00d0caa5690d2bd (diff) | |
download | cpython-1b16436c00aaabb3ec10c49ff4cc131c6aa9f4ca.zip cpython-1b16436c00aaabb3ec10c49ff4cc131c6aa9f4ca.tar.gz cpython-1b16436c00aaabb3ec10c49ff4cc131c6aa9f4ca.tar.bz2 |
Merge
-rw-r--r-- | Lib/unittest/mock.py | 4 | ||||
-rw-r--r-- | Lib/unittest/test/testmock/testmagicmethods.py | 25 | ||||
-rw-r--r-- | Misc/NEWS | 3 |
3 files changed, 31 insertions, 1 deletions
diff --git a/Lib/unittest/mock.py b/Lib/unittest/mock.py index 8b76503..a23df5a 100644 --- a/Lib/unittest/mock.py +++ b/Lib/unittest/mock.py @@ -1634,7 +1634,9 @@ magic_methods = ( "bool next " ) -numerics = "add sub mul div floordiv mod lshift rshift and xor or pow " +numerics = ( + "add sub mul div floordiv mod lshift rshift and xor or pow truediv" +) inplace = ' '.join('i%s' % n for n in numerics.split()) right = ' '.join('r%s' % n for n in numerics.split()) diff --git a/Lib/unittest/test/testmock/testmagicmethods.py b/Lib/unittest/test/testmock/testmagicmethods.py index 5ff158d..cc0e707 100644 --- a/Lib/unittest/test/testmock/testmagicmethods.py +++ b/Lib/unittest/test/testmock/testmagicmethods.py @@ -126,6 +126,31 @@ class TestMockingMagicMethods(unittest.TestCase): self.assertEqual(7 + mock, mock) self.assertEqual(mock.value, 16) + def test_division(self): + original = mock = Mock() + mock.value = 32 + self.assertRaises(TypeError, lambda: mock / 2) + + def truediv(self, other): + mock.value /= other + return self + mock.__truediv__ = truediv + self.assertEqual(mock / 2, mock) + self.assertEqual(mock.value, 16) + + del mock.__truediv__ + def itruediv(mock): + mock /= 4 + self.assertRaises(TypeError, itruediv, mock) + mock.__itruediv__ = truediv + mock /= 8 + self.assertEqual(mock, original) + self.assertEqual(mock.value, 2) + + self.assertRaises(TypeError, lambda: 8 / mock) + mock.__rtruediv__ = truediv + self.assertEqual(0.5 / mock, mock) + self.assertEqual(mock.value, 4) def test_hash(self): mock = Mock() @@ -30,6 +30,9 @@ Core and Builtins Library ------- +- Issue #20968: unittest.mock.MagicMock now supports division. + Patch by Johannes Baiter. + - Fix arbitrary memory access in JSONDecoder.raw_decode with a negative second parameter. Bug reported by Guido Vranken. |