Skip to main content

A flake8 plugin to ban PEP-420 implicit namespace packages.

Project description

https://img.shields.io/github/workflow/status/adamchainz/flake8-no-pep420/CI/main?style=for-the-badge https://img.shields.io/pypi/v/flake8-no-pep420.svg?style=for-the-badge https://img.shields.io/badge/code%20style-black-000000.svg?style=for-the-badge pre-commit

A flake8 plugin to ban PEP-420 implicit namespace packages.

Requirements

Python 3.6 to 3.10 supported.

Installation

First, install with pip:

python -m pip install flake8-no-pep420

Second, check that flake8 lists the plugin in its version line:

$ flake8 --version
3.8.4 (flake8-no-pep420: 1.0.0, mccabe: 0.6.1, pycodestyle: 2.5.0, pyflakes: 2.1.1) CPython 3.8.0 on Darwin

Third, add the INP prefix to your select list. For example, if you have your configuration in setup.cfg:

[flake8]
select = E,F,W,INP

Linting a Django project? Check out my book Speed Up Your Django Tests which covers loads of best practices so you can write faster, more accurate tests.


Rationale

Implicit namespace packages are folders of Python files without an __init__.py. They’re valid and importable, but unfortunately they’re not discovered by many code quality tools:

Such silent failure leads to a false sense of security. PEP-420’s algorithm is non-trivial which is probably why such tools haven’t (yet) implemented it.

Rules

INP001: File is part of an implicit namespace package.

flake8-no-pep420 will trigger this on the first line of any file that sits in a folder without a __init__.py file.

Often projects have a few root files not in packages, for which an __init__.py file should not be added. For example on a Django project there’s the manage.py file. In these cases you should add # noqa: INP001 on the first line of the file.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

flake8-no-pep420-1.2.0.tar.gz (5.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

flake8_no_pep420-1.2.0-py3-none-any.whl (4.6 kB view details)

Uploaded Python 3

File details

Details for the file flake8-no-pep420-1.2.0.tar.gz.

File metadata

  • Download URL: flake8-no-pep420-1.2.0.tar.gz
  • Upload date:
  • Size: 5.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.2 CPython/3.9.7

File hashes

Hashes for flake8-no-pep420-1.2.0.tar.gz
Algorithm Hash digest
SHA256 517f85b4030ccbd1bdab5dd5e4f9871d65ca24c1550da682434b5d5024c1a0d4
MD5 176952764c50840f5ae523d721c1bdc3
BLAKE2b-256 cbaf5bcfa6f379d875a2f627d69db25dee00576e3489adace07a18e46ecbf28f

See more details on using hashes here.

File details

Details for the file flake8_no_pep420-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: flake8_no_pep420-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 4.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.2 CPython/3.9.7

File hashes

Hashes for flake8_no_pep420-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 dbd2cd49597513be5ad4e057256fb633314fd602f3b4b35c0dcea0439facfb7c
MD5 ca11212820540d87e08b3ef230d346ca
BLAKE2b-256 4d98d5d96825527af3d06b393331523fb39bf789fc03d5104bb3bb3d657f8a83

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page