mirror of
https://github.com/python/cpython.git
synced 2025-10-23 18:03:48 +00:00
Closes #21270 : We now override tuple methods in mock.call objects.
This commit is contained in:
parent
a0f33759fa
commit
a37b958d65
3 changed files with 19 additions and 0 deletions
|
@ -2035,6 +2035,12 @@ def __getattr__(self, attr):
|
||||||
return _Call(name=name, parent=self, from_kall=False)
|
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):
|
def __repr__(self):
|
||||||
if not self.from_kall:
|
if not self.from_kall:
|
||||||
name = self.name or 'call'
|
name = self.name or 'call'
|
||||||
|
|
|
@ -1213,6 +1213,16 @@ def test_sorted_call_signature(self):
|
||||||
text = "call(daddy='hero', name='hello')"
|
text = "call(daddy='hero', name='hello')"
|
||||||
self.assertEqual(repr(m.hello.call_args), text)
|
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):
|
def test_mock_add_spec(self):
|
||||||
class _One(object):
|
class _One(object):
|
||||||
one = 1
|
one = 1
|
||||||
|
|
|
@ -157,6 +157,9 @@ Library
|
||||||
- Issue #12410: imaplib.IMAP4 now supports the context management protocol.
|
- Issue #12410: imaplib.IMAP4 now supports the context management protocol.
|
||||||
Original patch by Tarek Ziadé.
|
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
|
- Issue #16662: load_tests() is now unconditionally run when it is present in
|
||||||
a package's __init__.py. TestLoader.loadTestsFromModule() still accepts
|
a package's __init__.py. TestLoader.loadTestsFromModule() still accepts
|
||||||
use_load_tests, but it is deprecated and ignored. A new keyword-only
|
use_load_tests, but it is deprecated and ignored. A new keyword-only
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue