diff options
author | Kushal Das <kushaldas@gmail.com> | 2014-09-16 13:03:37 (GMT) |
---|---|---|
committer | Kushal Das <kushaldas@gmail.com> | 2014-09-16 13:03:37 (GMT) |
commit | a37b958d6540be7bb3cf181e448f1267c0e2824c (patch) | |
tree | a249ea7a1698cfb67f5a3b3bb83d972280823600 | |
parent | a0f33759fa03a1801f25420e66fab3f2d938244d (diff) | |
download | cpython-a37b958d6540be7bb3cf181e448f1267c0e2824c.zip cpython-a37b958d6540be7bb3cf181e448f1267c0e2824c.tar.gz cpython-a37b958d6540be7bb3cf181e448f1267c0e2824c.tar.bz2 |
Closes #21270 : We now override tuple methods in mock.call objects.
-rw-r--r-- | Lib/unittest/mock.py | 6 | ||||
-rw-r--r-- | Lib/unittest/test/testmock/testmock.py | 10 | ||||
-rw-r--r-- | Misc/NEWS | 3 |
3 files changed, 19 insertions, 0 deletions
diff --git a/Lib/unittest/mock.py b/Lib/unittest/mock.py index d001976..1c2dd1c 100644 --- a/Lib/unittest/mock.py +++ b/Lib/unittest/mock.py @@ -2035,6 +2035,12 @@ class _Call(tuple): return _Call(name=name, parent=self, from_kall=False) + def count(self, *args, **kwargs): + return self.__getattr__('count')(*args, **kwargs) + + def index(self, *args, **kwargs): + return self.__getattr__('index')(*args, **kwargs) + def __repr__(self): if not self.from_kall: name = self.name or 'call' diff --git a/Lib/unittest/test/testmock/testmock.py b/Lib/unittest/test/testmock/testmock.py index a549973..3a104cb 100644 --- a/Lib/unittest/test/testmock/testmock.py +++ b/Lib/unittest/test/testmock/testmock.py @@ -1213,6 +1213,16 @@ class MockTest(unittest.TestCase): text = "call(daddy='hero', name='hello')" self.assertEqual(repr(m.hello.call_args), text) + #Issue21270 overrides tuple methods for mock.call objects + def test_override_tuple_methods(self): + c = call.count() + i = call.index(132,'hello') + m = Mock() + m.count() + m.index(132,"hello") + self.assertEqual(m.method_calls[0], c) + self.assertEqual(m.method_calls[1], i) + def test_mock_add_spec(self): class _One(object): one = 1 @@ -157,6 +157,9 @@ Library - Issue #12410: imaplib.IMAP4 now supports the context management protocol. Original patch by Tarek Ziadé. +- Issue #21270: We now override tuple methods in mock.call objects so that + they can be used as normal call attributes. + - Issue #16662: load_tests() is now unconditionally run when it is present in a package's __init__.py. TestLoader.loadTestsFromModule() still accepts use_load_tests, but it is deprecated and ignored. A new keyword-only |