inspect.signature: Check for function-like objects before builtins. Issue #17159
This commit is contained in:
parent
8c8b4e0ebf
commit
a773de040d
|
@ -1911,15 +1911,15 @@ def _signature_internal(obj, follow_wrapper_chains=True, skip_bound_arg=True):
|
|||
|
||||
return sig.replace(parameters=new_params)
|
||||
|
||||
if _signature_is_builtin(obj):
|
||||
return _signature_from_builtin(Signature, obj,
|
||||
skip_bound_arg=skip_bound_arg)
|
||||
|
||||
if isfunction(obj) or _signature_is_functionlike(obj):
|
||||
# If it's a pure Python function, or an object that is duck type
|
||||
# of a Python function (Cython functions, for instance), then:
|
||||
return Signature.from_function(obj)
|
||||
|
||||
if _signature_is_builtin(obj):
|
||||
return _signature_from_builtin(Signature, obj,
|
||||
skip_bound_arg=skip_bound_arg)
|
||||
|
||||
if isinstance(obj, functools.partial):
|
||||
wrapped_sig = _signature_internal(obj.func,
|
||||
follow_wrapper_chains,
|
||||
|
|
|
@ -14,6 +14,7 @@ import sys
|
|||
import types
|
||||
import unicodedata
|
||||
import unittest
|
||||
import unittest.mock
|
||||
|
||||
try:
|
||||
from concurrent.futures import ThreadPoolExecutor
|
||||
|
@ -1836,6 +1837,21 @@ class TestSignatureObject(unittest.TestCase):
|
|||
('kwargs', ..., ..., "var_keyword")),
|
||||
...))
|
||||
|
||||
# Test with cython-like builtins:
|
||||
_orig_isdesc = inspect.ismethoddescriptor
|
||||
def _isdesc(obj):
|
||||
if hasattr(obj, '_builtinmock'):
|
||||
return True
|
||||
return _orig_isdesc(obj)
|
||||
|
||||
with unittest.mock.patch('inspect.ismethoddescriptor', _isdesc):
|
||||
builtin_func = funclike(func)
|
||||
# Make sure that our mock setup is working
|
||||
self.assertFalse(inspect.ismethoddescriptor(builtin_func))
|
||||
builtin_func._builtinmock = True
|
||||
self.assertTrue(inspect.ismethoddescriptor(builtin_func))
|
||||
self.assertEqual(inspect.signature(builtin_func), sig_func)
|
||||
|
||||
def test_signature_functionlike_class(self):
|
||||
# We only want to duck type function-like objects,
|
||||
# not classes.
|
||||
|
|
Loading…
Reference in New Issue