Flake8 Type Annotation Checks
Project description
flake8-annotations
flake8-annotations
is a plugin for Flake8 that detects the absence of PEP 3107-style function annotations and PEP 484-style type comments (see: Caveats).
What this won't do: Check variable annotations (see: PEP 526), respect stub files, or replace mypy's static type checking.
Installation
Install from PyPi with your favorite pip
invocation:
$ pip install flake8-annotations
It will then be run automatically as part of Flake8.
You can verify it's being picked up by invoking the following in your shell:
$ flake8 --version
3.7.8 (flake8-annotations: 1.1.2, mccabe: 0.6.1, pycodestyle: 2.5.0, pyflakes: 2.1.1) CPython 3.7.4 on Darwin
Table of Warnings
Function Annotations
ID | Description |
---|---|
TYP001 |
Missing type annotation for function argument |
TYP002 |
Missing type annotation for *args |
TYP003 |
Missing type annotation for **kwargs |
Method Annotations
ID | Description |
---|---|
TYP101 |
Missing type annotation for self in method |
TYP102 |
Missing type annotation for cls in classmethod |
Return Annotations
ID | Description |
---|---|
TYP201 |
Missing return type annotation for public function |
TYP202 |
Missing return type annotation for protected function |
TYP203 |
Missing return type annotation for secret function |
TYP204 |
Missing return type annotation for special method |
TYP205 |
Missing return type annotation for staticmethod |
TYP206 |
Missing return type annotation for classmethod |
Type Comments
ID | Description |
---|---|
TYP301 |
PEP 484 disallows both type annotations and type comments |
Caveats for PEP 484-style Type Comments
Function type comments
Function type comments are assumed to contain both argument and return type hints
Yes:
# type: (int, int) -> bool
No:
# type: (int, int)
Python cannot parse the latter and will raise SyntaxError: unexpected EOF while parsing
Mixing argument type comments and function type comments
Support is provided for mixing argument and function type comments, provided that the function type comment use an Ellipsis for the arguments.
def foo(
arg1, # type: bool
arg2, # type: bool
): # type: (...) -> bool
pass
Ellipes are ignored by flake8-annotations
parser.
Note: If present, function type comments will override any argument type comments.
Partial type comments
Partially type hinted functions are supported
For example:
def foo(arg1, arg2):
# type: (bool) -> bool
pass
Will show arg2
as missing a type hint.
def foo(arg1, arg2):
# type: (..., bool) -> bool
pass
Will show arg1
as missing a type hint.
Contributing
Please take some time to read through our contributing guidelines before helping us with this project.
Development Environment
This project uses Pipenv to manage dependencies. With your fork cloned to your local machine, you can create a developer environment using:
$ pipenv sync --dev
Note: flake8-annotations is included in the Pipfile as an editable dependency so it will be included when flake8 is invoked in your developer environment.
A pre-commit installation script and configuration is also provided to create a pre-commit hook so linting errors aren't committed:
$ pipenv run precommit
Testing
A pytest suite is provided for testing across multiple Python environments via tox:
$ pipenv run test
Coverage
Test coverage is provided by pytest-cov via a pipenv script:
$ pipenv run coverage
When running via pipenv, details on missing coverage is provided in the report to allow the user to generate additional tests for full coverage.
e.g.
----------- coverage: platform win32, python 3.7.4-final-0 -----------
Name Stmts Miss Branch BrPart Cover Missing
-------------------------------------------------------------------------------
flake8_annotations\__init__.py 108 0 38 0 99% 164
flake8_annotations\checker.py 57 0 30 0 100%
flake8_annotations\enums.py 15 0 0 0 100%
flake8_annotations\error_codes.py 85 0 0 0 100%
-------------------------------------------------------------------------------
TOTAL 265 0 68 0 99%
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file flake8-annotations-1.1.2.tar.gz
.
File metadata
- Download URL: flake8-annotations-1.1.2.tar.gz
- Upload date:
- Size: 12.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.6.0 requests-toolbelt/0.9.1 tqdm/4.40.2 CPython/3.7.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | fdd6a47cc0e877c4e97bc2865b6521edde221220acc8b72ed6715d14b3f142ee |
|
MD5 | 68836d2b6832811b9c2f3982aa5ef22e |
|
BLAKE2b-256 | 2177bfb3b1d6aefacb05c35747196d10fe4b1d40f96aee9af1c95fc60cd824d1 |
File details
Details for the file flake8_annotations-1.1.2-py3-none-any.whl
.
File metadata
- Download URL: flake8_annotations-1.1.2-py3-none-any.whl
- Upload date:
- Size: 12.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.6.0 requests-toolbelt/0.9.1 tqdm/4.40.2 CPython/3.7.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 520f6845ce19cbf938dc59d0890c6ad2faa647773ce5ff2d64b4aac15288e712 |
|
MD5 | 3e0bf2eb036d1588428eade374064647 |
|
BLAKE2b-256 | 699a0b96e0f089a5548154e40cff77789653e57d12d0f0fbe92f8cf6fb1fe69c |