summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>2024-04-10 14:17:15 (GMT)
committerGitHub <noreply@github.com>2024-04-10 14:17:15 (GMT)
commit653ed76442d2988e587f4da1fc1cf1bd2bb51fbb (patch)
tree132dd6626296683c13cab7e58832cbe0a39d8d53
parent559b25fcc82d476bbab96cac7d67a253c4ed0ed9 (diff)
downloadcpython-653ed76442d2988e587f4da1fc1cf1bd2bb51fbb.zip
cpython-653ed76442d2988e587f4da1fc1cf1bd2bb51fbb.tar.gz
cpython-653ed76442d2988e587f4da1fc1cf1bd2bb51fbb.tar.bz2
[3.12] gh-117692: Fix `AttributeError` in `DocTestFinder` on wrapped `builtin_or_method` (GH-117699) (#117708)
* gh-117692: Fix `AttributeError` in `DocTestFinder` on wrapped `builtin_or_method` (GH-117699) (cherry picked from commit 4bb7d121bc0a3fd00a3c72cd915b5dd8fac5616e) Co-authored-by: Nikita Sobolev <mail@sobolevn.me> Co-authored-by: Alex Waygood <Alex.Waygood@Gmail.com>
-rw-r--r--Lib/doctest.py9
-rw-r--r--Lib/test/test_doctest/test_doctest.py14
-rw-r--r--Misc/NEWS.d/next/Library/2024-04-09-23-22-21.gh-issue-117692.EciInD.rst2
3 files changed, 24 insertions, 1 deletions
diff --git a/Lib/doctest.py b/Lib/doctest.py
index 696bb96..d617d96 100644
--- a/Lib/doctest.py
+++ b/Lib/doctest.py
@@ -1124,7 +1124,14 @@ class DocTestFinder:
obj = obj.fget
if inspect.isfunction(obj) and getattr(obj, '__doc__', None):
# We don't use `docstring` var here, because `obj` can be changed.
- obj = inspect.unwrap(obj).__code__
+ obj = inspect.unwrap(obj)
+ try:
+ obj = obj.__code__
+ except AttributeError:
+ # Functions implemented in C don't necessarily
+ # have a __code__ attribute.
+ # If there's no code, there's no lineno
+ return None
if inspect.istraceback(obj): obj = obj.tb_frame
if inspect.isframe(obj): obj = obj.f_code
if inspect.iscode(obj):
diff --git a/Lib/test/test_doctest/test_doctest.py b/Lib/test/test_doctest/test_doctest.py
index 9c8a8ba..2722661 100644
--- a/Lib/test/test_doctest/test_doctest.py
+++ b/Lib/test/test_doctest/test_doctest.py
@@ -2496,6 +2496,20 @@ def test_look_in_unwrapped():
'one other test'
"""
+if support.check_impl_detail(cpython=True):
+ def test_wrapped_c_func():
+ """
+ # https://github.com/python/cpython/issues/117692
+ >>> import binascii
+ >>> from test.test_doctest.decorator_mod import decorator
+
+ >>> c_func_wrapped = decorator(binascii.b2a_hex)
+ >>> tests = doctest.DocTestFinder(exclude_empty=False).find(c_func_wrapped)
+ >>> for test in tests:
+ ... print(test.lineno, test.name)
+ None b2a_hex
+ """
+
def test_unittest_reportflags():
"""Default unittest reporting flags can be set to control reporting
diff --git a/Misc/NEWS.d/next/Library/2024-04-09-23-22-21.gh-issue-117692.EciInD.rst b/Misc/NEWS.d/next/Library/2024-04-09-23-22-21.gh-issue-117692.EciInD.rst
new file mode 100644
index 0000000..98a6e12
--- /dev/null
+++ b/Misc/NEWS.d/next/Library/2024-04-09-23-22-21.gh-issue-117692.EciInD.rst
@@ -0,0 +1,2 @@
+Fixes a bug when :class:`doctest.DocTestFinder` was failing on wrapped
+``builtin_function_or_method``.