- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 3k
Description
Bug Report
If you have a library that creates a namespace package (say ns_package) with a regular type-hinted package inside it (say reg_package), and you import the regular package as from ns_package import reg_package, mypy sometimes gives the following error:
script.py:1: error: Skipping analyzing 'ns_package': found module but no type hints or library stubs
script.py:1: note: See https://mypy.readthedocs.io/en/latest/running_mypy.html#missing-imports
Found 1 error in 1 file (checked 1 source file)
The error only shows up intermittently. More details below.
To Reproduce
- Create the following directory tree:
.
├── lib/
│   ├── ns_package/
│   │   └── reg_package/
│   │       ├── __init__.py
│   │       └── py.typed
│   └── setup.py
└── script.py
3 directories, 4 files
with content
# lib/ns_package/reg_package/__init__.py
SOMETHING: int = 345
# lib/setup.py
from setuptools import setup, find_namespace_packages
setup(
    name="ns_package.reg_package",
    description="",
    version="1.0",
    packages=find_namespace_packages(),
    zip_safe=False,
    package_data={"": ["py.typed"]},
)
# script.py
from ns_package import reg_package
a = reg_package.SOMETHING
print(a)- Create venv, activate and install the lib and mypy: python3.8 -m venv .venv; . .venv/bin/activate; python3.8 -m pip install -e ./lib/ mypy
- Run mypy against script.pywithpython3.8 -m mypy -p script
Expected Behavior
Mypy should report no errors since the library has a py.typed file and type annotations.
Actual Behavior
Mypy's result changes with every run. Sometimes no error is reported. Sometimes the following error is reported:
script.py:1: error: Skipping analyzing 'ns_package': found module but no type hints or library stubs
script.py:1: note: See https://mypy.readthedocs.io/en/latest/running_mypy.html#missing-imports
Found 1 error in 1 file (checked 1 source file)
From what I can tell, the error is always reported in every other run, consistently. Meaning if I run mypy twice in a row, one of them always fails and one of them always succeeds. This seems to suggest that mypy somehow maintains state from one run to the next?
Couple of points to note:
- If the import statement is changed to import ns_package.reg_package as reg_packageorfrom ns_package.reg_package import SOMETHING, the error is gone.
- Adding the --namespace-packagesCLI flag doesn't change the result.
- Whether the lib is installed as an editable package doesnt change the result.
- Whether its installed from local dir or PyPi doesn't change the result.
- If ns_packageis just a directory in the cwd instead of an installed package, and the--namespace-packagesCLI flag is passed, the error is gone.
Your Environment
- Mypy version used: 0.800
- Mypy command-line flags: -p script
- Mypy configuration options from mypy.ini(and other config files): None
- Python version used: 3.8.6
- Operating system and version: Red Hat Enterprise Linux Server 7.9 (Maipo)