CLI tool used for running linter on project configured with CERT-Polska/lint-python-action
Project description
lint-python-action
Tool that runs common linters on CERT Polska projects written in Python.
Includes GitHub Actions custom action.
Used linters and auto-formatters are:
pip install -U isort==5.10.1 black==22.6.0 flake8==4.0.1 mypy==0.971
Installation
$ pip install lint-python
How to configure lint-python?
Provide configuration in pyproject.toml file.
[tool.lint-python]
lint-version = "2"
source = "lint_python/" # Put your source directory
extra-requirements = "types-requests" # Provide additional typing requirements if needed
use-mypy = false # Turn off any tool you don't want to use
Tools are opt-out, so if you don't use static typing in your project, you can turn off any tool from linting.
If you use Github Actions, you can add it to any steps of the workflow e.g. .github/workflows/test.yml
name: Test the code
on:
push:
branches:
- master
pull_request:
branches:
- master
jobs:
lint:
runs-on: ubuntu-latest
steps:
- uses: CERT-Polska/lint-python-action@v2
with:
source: karton/
Tool can be configured via with
parameters, but they must be provided directly.
Don't use any expansion because lint-python tool parses the workflow file on its own.
How to use it?
$ lint-python
INFO:root:Linting with isort
INFO:root:Linting with black
All done! ✨ 🍰 ✨
3 files left unchanged.
INFO:root:Linting with flake8
INFO:root:Linting with mypy
Success: no issues found in 3 source files
If you want to only perform a check without modifying files, use --check
flag
$ lint-python --check
If you have not installed packages and tools required for linting, use --install
flag or --install-only
flag if
you don't want to lint immediately after successful installation.
$ lint-python --install
Try --help
for more settings.
Tips for linting your own project
If you want to introduce these linters into your project, some tools need to be preconfigured to cooperate correctly. Check https://black.readthedocs.io/en/stable/guides/using_black_with_other_tools.html for more information.
Our recommended settings are:
# in pyproject.toml file:
[tool.isort]
multi_line_output = 3
include_trailing_comma = true
force_grid_wrap = 0
use_parentheses = true
ensure_newline_before_comments = true
line_length = 88
# in .flake8, setup.cfg or tox.ini file:
[flake8]
max-line-length = 88
extend-ignore = E203, W503
Read more
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
Built Distribution
File details
Details for the file lint-python-2.2.1.tar.gz
.
File metadata
- Download URL: lint-python-2.2.1.tar.gz
- Upload date:
- Size: 4.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.8.19
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2b9a5541f721d1a8f3445b9a518a6cb07bf97b2f89714c54899d51caac3eda64 |
|
MD5 | e3e5b0eda4adb512c97fbc11e765c0c7 |
|
BLAKE2b-256 | a901196b8397481b2766ccefa63e5edd941d2cc2f05fdf9922c8f61ca76a2a9c |
File details
Details for the file lint_python-2.2.1-py3-none-any.whl
.
File metadata
- Download URL: lint_python-2.2.1-py3-none-any.whl
- Upload date:
- Size: 5.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.8.19
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f31f3d5f8d866317656353637888198f4e655275a98c192b68baaa271c59c903 |
|
MD5 | 5a015f4f970d47a467cafa6136d3a69a |
|
BLAKE2b-256 | bd7cd5efe26bac842576bdf9e713827c42dadada97b135d079918a9275d0f55a |