Skip to content

inspect.getfile doesn't properly handle PEP 420#92525

@TheTechRobo

Description

@TheTechRobo

Bug report

inspect.getfile handles all __file__ is None modules as built-in. Cf.

cpython/Lib/inspect.py

Lines 898 to 901 in f298ba1

ifismodule(object):
ifgetattr(object, '__file__', None):
returnobject.__file__
raiseTypeError('{!r} is a built-in module'.format(object))

This leads to PEP 420 packages being treated as built-in, as implicit namespaces have file set to None, but __path__ set to the actual path.

Creating PEP 420 directory:

~ ❯❯❯ mkdir python_test ~ ❯❯❯ vim python_test/hello.py

Python interpreter

Python 3.9.7 (default, Oct 10 2021, 14:08:54) [GCC 8.3.0] on linux Type "help", "copyright", "credits" or "license" for more information. >>> import python_test >>> import inspect >>> inspect.getfile(python_test) Traceback (most recent call last): File "<stdin>", line 1, in <module> File "/opt/python-3.9.7/lib/python3.9/inspect.py", line 660, in getfile raise TypeError('{!r} is a built-in module'.format(object)) TypeError: <module 'python_test' (namespace)> is a built-in module >>> print(python_test.__file__) None >>> print(python_test.__path__) _NamespacePath(['/home/thetechrobo/python_test']) 

Your environment

  • CPython versions tested on: 3.9.7
  • Operating system and architecture: Elive Linux 3.8.27 64-bit (Debian Bullseye); custom Python installation

Apologies if this is a duplicate. I've searched for any related issues, but I may have missed one.

Linked PRs

Metadata

Metadata

Assignees

No one assigned

    Labels

    stdlibStandard Library Python modules in the Lib/ directorytype-bugAn unexpected behavior, bug, or error

    Projects

    Status

    No status

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions