Issue 24298: Fix signature() to properly unwrap wrappers around bound methods
This commit is contained in:
parent
68fe9aa58c
commit
46c759d76d
|
@ -1911,6 +1911,14 @@ def _signature_internal(obj, follow_wrapper_chains=True, skip_bound_arg=True):
|
||||||
# Was this function wrapped by a decorator?
|
# Was this function wrapped by a decorator?
|
||||||
if follow_wrapper_chains:
|
if follow_wrapper_chains:
|
||||||
obj = unwrap(obj, stop=(lambda f: hasattr(f, "__signature__")))
|
obj = unwrap(obj, stop=(lambda f: hasattr(f, "__signature__")))
|
||||||
|
if isinstance(obj, types.MethodType):
|
||||||
|
# If the unwrapped object is a *method*, we might want to
|
||||||
|
# skip its first parameter (self).
|
||||||
|
# See test_signature_wrapped_bound_method for details.
|
||||||
|
return _signature_internal(
|
||||||
|
obj,
|
||||||
|
follow_wrapper_chains=follow_wrapper_chains,
|
||||||
|
skip_bound_arg=skip_bound_arg)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
sig = obj.__signature__
|
sig = obj.__signature__
|
||||||
|
|
|
@ -1939,6 +1939,19 @@ class TestSignatureObject(unittest.TestCase):
|
||||||
with self.assertRaisesRegex(ValueError, 'invalid method signature'):
|
with self.assertRaisesRegex(ValueError, 'invalid method signature'):
|
||||||
self.signature(Test())
|
self.signature(Test())
|
||||||
|
|
||||||
|
def test_signature_wrapped_bound_method(self):
|
||||||
|
# Issue 24298
|
||||||
|
class Test:
|
||||||
|
def m1(self, arg1, arg2=1) -> int:
|
||||||
|
pass
|
||||||
|
@functools.wraps(Test().m1)
|
||||||
|
def m1d(*args, **kwargs):
|
||||||
|
pass
|
||||||
|
self.assertEqual(self.signature(m1d),
|
||||||
|
((('arg1', ..., ..., "positional_or_keyword"),
|
||||||
|
('arg2', 1, ..., "positional_or_keyword")),
|
||||||
|
int))
|
||||||
|
|
||||||
def test_signature_on_classmethod(self):
|
def test_signature_on_classmethod(self):
|
||||||
class Test:
|
class Test:
|
||||||
@classmethod
|
@classmethod
|
||||||
|
|
|
@ -274,6 +274,9 @@ Library
|
||||||
- Issue #23898: Fix inspect.classify_class_attrs() to support attributes
|
- Issue #23898: Fix inspect.classify_class_attrs() to support attributes
|
||||||
with overloaded __eq__ and __bool__. Patch by Mike Bayer.
|
with overloaded __eq__ and __bool__. Patch by Mike Bayer.
|
||||||
|
|
||||||
|
- Issue #24298: Fix inspect.signature() to correctly unwrap wrappers
|
||||||
|
around bound methods.
|
||||||
|
|
||||||
IDLE
|
IDLE
|
||||||
----
|
----
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue