summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorYury Selivanov <yselivanov@sprymix.com>2015-05-30 21:08:36 (GMT)
committerYury Selivanov <yselivanov@sprymix.com>2015-05-30 21:08:36 (GMT)
commitbf304fcb3255d6fe52f83c120feccdf64f5a9715 (patch)
tree6bdb8df43c8e4bfc5a2fc2ef802daee0b24cdb2e /Lib
parentdce09c34a0a5d3ba5ddb2a948f3d0aa55ae3e9c4 (diff)
downloadcpython-bf304fcb3255d6fe52f83c120feccdf64f5a9715.zip
cpython-bf304fcb3255d6fe52f83c120feccdf64f5a9715.tar.gz
cpython-bf304fcb3255d6fe52f83c120feccdf64f5a9715.tar.bz2
Issue #23934: Fix inspect.signature to fail correctly for builtin types.
Initial patch by James Powell.
Diffstat (limited to 'Lib')
-rw-r--r--Lib/inspect.py6
-rw-r--r--Lib/test/test_inspect.py7
2 files changed, 11 insertions, 2 deletions
diff --git a/Lib/inspect.py b/Lib/inspect.py
index 57cb3dc..25ddd26 100644
--- a/Lib/inspect.py
+++ b/Lib/inspect.py
@@ -2255,9 +2255,13 @@ def _signature_from_callable(obj, *,
if type not in obj.__mro__:
# We have a class (not metaclass), but no user-defined
# __init__ or __new__ for it
- if obj.__init__ is object.__init__:
+ if (obj.__init__ is object.__init__ and
+ obj.__new__ is object.__new__):
# Return a signature of 'object' builtin.
return signature(object)
+ else:
+ raise ValueError(
+ 'no signature found for builtin type {!r}'.format(obj))
elif not isinstance(obj, _NonUserDefinedCallables):
# An object with __call__
diff --git a/Lib/test/test_inspect.py b/Lib/test/test_inspect.py
index 9f09b83..4695da8 100644
--- a/Lib/test/test_inspect.py
+++ b/Lib/test/test_inspect.py
@@ -1980,9 +1980,14 @@ class TestSignatureObject(unittest.TestCase):
@cpython_only
def test_signature_on_builtins_no_signature(self):
import _testcapi
- with self.assertRaisesRegex(ValueError, 'no signature found for builtin'):
+ with self.assertRaisesRegex(ValueError,
+ 'no signature found for builtin'):
inspect.signature(_testcapi.docstring_no_signature)
+ with self.assertRaisesRegex(ValueError,
+ 'no signature found for builtin'):
+ inspect.signature(str)
+
def test_signature_on_non_function(self):
with self.assertRaisesRegex(TypeError, 'is not a callable object'):
inspect.signature(42)