gh-113329: Catch OSError in doctest finder and document that inspect.getsourcefile/getfile can raise OSError #113335
+7
−4
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Fixes #113329, which occurs when running doctests in a class docstring in a REPL environment. Since Python 3.10, an OSError is raised when the class source code cannot be found.
Just as
inspect.getsourcelines
, this PR adds documentation forinspect.getsourcefile
andinspect.getfile
that it can raise anOSError
when the source code cannot be found.Additionally, this PR now also catches
OSError
in the doctest finder. The source code is only necessary to discover line numbers, and is already ignored when aTypeError
occurs. This restores behavior from CPython version < 3.10 where doctests can be found on a class object in the REPL (and, in particular, also in notebook environments).📚 Documentation preview 📚: https://cpython-previews--113335.org.readthedocs.build/