Skip to main content

pre-commit hooks for python projects using pyproject.toml.

Project description

pyproject-pre-commit

test test coverage

pre-commit hooks for python projects.

.pre-commit-hooks.yaml provides pre-defined ids which you just need to add these ids to your .pre-commit-config.yaml.

By installing pyproject-pre-commit package, all necessary tools are installed as dependencies.

Requirement

  • Python >= 3.9.0
  • Poetry (For development)

Usage

Install pyproject-pre-commit

If your project uses poetry, do:

$ poetry add --group dev pyproject-pre-commit

Otherwise, install the package in your working environment.

If you use pip, do:

$ pip install pyproject-pre-commit

This will install tools for pre-commit hooks in your working environment, so that you can use these tools, such as black, directly.

Install pyproject-pre-commit with ruff

If you want to use ruff, you can install pyproject-pre-commit with ruff option.

$ poetry add --group dev "pyproject-pre-commit[ruff]"
$ pip install pyproject-pre-commit[ruff]

Prepare .pre-commit-config.yaml

Add https://github.com/rcmdnk/pyproject-pre-commit to your .pre-commit-config.yaml, like:

repos:
  - repo: https://github.com/rcmdnk/pyproject-pre-commit
    rev: v0.3.0
    hooks:
      - id: black-diff
      - id: black
      - id: blacken-docs
      - id: autoflake-diff
      - id: autoflake
      - id: autopep8-diff
      - id: autopep8
      - id: isort-diff
      - id: isort
      - id: flake8
      - id: bandit
      - id: mypy
      - id: shellcheck
      - id: mdformat-check
      - id: mdformat

By using pyproject-pre-commit, you can simplify your .pre-commit-config.yaml that you need only repo of https://github.com/rcmdnk/pyproject-pre-commit.

These hooks uses local installation of tools, so pre-commit will use tools installed in your working environment.

This can be made by ppc command:

$ ppc --pre-commit > .pre-commit-config.yaml

[!NOTE] If you are using poetry, run poetry run ppc ... or run after poetry shell.

If you already have it, add hooks w/o repos: by

$ ppc --pre-commit |grep -v "^repos:" >> .pre-commit-config.yaml

You may want to modify after adding these configurations.

To use ruff instead of such as black, flake8, isort, add following hooks:

repos:
  - repo: https://github.com/rcmdnk/pyproject-pre-commit
    rev: v0.3.0
    hooks:
      - id: ruff-lint-diff
      - id: ruff-lint
      - id: ruff-format-diff
      - id: ruff-format
      - id: mypy
      - id: shellcheck
      - id: mdformat-check
      - id: mdformat

This can be made by ppc command:

$ ppc --pre-commit --ruff > .pre-commit-config.yaml

Run pre-commit

pre-commit command is installed as dependencies of pyproject-pre-commit package.

After installing pyproject-pre-commit package, you can run pre-commit command.

First, install pre-commit hooks by:

$ pre-commit install

then you can run pre-commit by:

$ pre-commit run --all-files

[!NOTE] If you are using poetry, run poetry run pre-commit ... or run after poetry shell.

Available ids

You can find ids in .pre-commit-hooks.yaml.

There are ids for following tools:

All tools are installed as dependencies of pyproject-pre-commit package.

shellcheck and mdformat are given in addition to python tools as they can be managed by pip and most projects have README.md and some have shell scripts.

For tools which can format files, there are additional ids with -diff or --check which show the results before modifying files. You can see the differences after formatting if you place these ids before ids w/o --diff or --check.

Options for tools

You can set options in pyproject.toml for all tools above.

For flake8, flake8-pyproject allows to read options from pyproject.toml

About bandit, there is a plugin for the flake8, but plugin version does not read options from pyproject.toml even with pyproject.toml. Therefore, use bandit directly and give -c pyproject.toml option in the hooks.

pyproject.toml

You can set options in pyproject.toml for all tools.

Example options can be made by ppc command:

$ ppc --pyproject >> pyproject.toml

or

$ ppc --pyproject --ruff >> pyproject.toml

You may want to modify after adding these configurations.

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

pyproject_pre_commit-0.3.4.tar.gz (73.4 kB view details)

Uploaded Source

Built Distribution

pyproject_pre_commit-0.3.4-py3-none-any.whl (10.9 kB view details)

Uploaded Python 3

File details

Details for the file pyproject_pre_commit-0.3.4.tar.gz.

File metadata

File hashes

Hashes for pyproject_pre_commit-0.3.4.tar.gz
Algorithm Hash digest
SHA256 84cda772a256c8476de422aed3fe2889b2d5ff78fa0394dcb6a24679ee4b61f1
MD5 d645c3cf2372b582990cd66d8157ef84
BLAKE2b-256 6f35d02af06c16a1f2613b86706a05e74efa023f7f5eefc8c8499f377507b19a

See more details on using hashes here.

File details

Details for the file pyproject_pre_commit-0.3.4-py3-none-any.whl.

File metadata

File hashes

Hashes for pyproject_pre_commit-0.3.4-py3-none-any.whl
Algorithm Hash digest
SHA256 39cd00cc6bd84ed47443969f42f16c79fbd6b1f9ba15deb2dfca7179ce20e33e
MD5 a4f5042cdb169e7a80db3c05749577f9
BLAKE2b-256 fb1a61187be9c9e1ba5d57b5557bfc56cdad7e26ab41aa9adac896953b6f46ff

See more details on using hashes here.

Supported by

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