Skip to content

Running doctest examples on a class results in OSError in REPL #113329

@stenwessel

Description

@stenwessel

Bug report

Bug description:

In the REPL, running doctests contained in the docstring of a class is broken since version 3.10. Example:

import doctest

class A:
    """Docstring of A, with tests.
    >>> 1 + 2
    3
    """
    pass

doctest.run_docstring_examples(A, globals(), name='A', verbose=True)

In version 3.9, this code works and executes the doctest in the docstring of the class A. In version 3.10 (and onward), the call to doctest.run_docstring_examples fails with OSError: source code not available.

This only fails in the REPL and not in regular Python files. In particular, this also fails in (Jupyter) notebook environments.

Cause

This change in behavior is caused by 48a6255 as a fix for #88814. Previously, inspect.getsourcefile() could only fail with TypeError, but this can now also be OSError. The new exception type is not being handled by doctest, only TypeError is caught:

cpython/Lib/doctest.py

Lines 924 to 927 in 713e428

try:
file = inspect.getsourcefile(obj)
except TypeError:
source_lines = None

The call to inspect.getsourcefile() is only used by doctest to determine line numbers, if available. Thus, failing to find the source file can safely fail silently in environments where line numbers are not available (such as the REPL).

Proposed changes

  • Also catch OSError in the doctest finder (in the linked snippet).
  • Update the documentation to reflect that inspect.getsourcefile() can also fail with OSError.

An alternative would be to change the exception type in 48a6255 to also be TypeError in the case the source file is not available. I do not think this a desired change.

I am happy to contribute a pull request with these changes.

CPython versions tested on:

3.9, 3.10, 3.11

Operating systems tested on:

Linux

Linked PRs

Metadata

Metadata

Assignees

No one assigned

    Labels

    3.11only security fixes3.12only security fixes3.13bugs and security fixesstdlibPython modules in the Lib dirtopic-replRelated to the interactive shelltype-bugAn unexpected behavior, bug, or error

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions