Skip to main content

Review repos for compliance to the Scientific-Python development guidelines

Project description

sp-repo-review provides checks based on the Scientific-Python Development Guide at scientific-python/cookie for repo-review.

This tool can check the style of a repository. Use like this:

uvx sp-repo-review[cli] <path to repository>

This will produce a list of results - green checkmarks mean this rule is followed, red x’s mean the rule is not. A yellow warning sign means that the check was skipped because a previous required check failed. Some checks will fail, that’s okay - the goal is bring all possible issues to your attention, not to force compliance with arbitrary checks. Eventually there might be a way to mark checks as ignored.

For example, GH101 expects all your action files to have a nice name: field. If you are happy with the file-based names you see in CI, you should feel free to simply ignore this check (you can specify ignored checks in pyproject.toml or by passing args to repo-review, see the repo-review docs).

All checks are mentioned at least in some way in the Scientific-Python Development Guide. You should read that first - if you are not attempting to follow them, some of the checks might not work. For example, the guidelines specify pytest configuration be placed in pyproject.toml. If you place it somewhere else, then all the pytest checks will be skipped.

This was originally developed for Scikit-HEP before moving to Scientific Python.

Extras

  • cli: Dependencies to run the CLI (not needed for programmatic access, like on Web Assembly)
  • pyproject: Include validate pyproject with schema store.
  • all: All extras

Helper utility

There's also a script, accessible as sp-ruff-checks, that will compare your ruff checks to the known values. It's a little more elegant on the command line than the Ruff family description, which will only print out a basic list.

Other ways to use

You can also use GitHub Actions:

- uses: scientific-python/cookie@<version>

Or pre-commit:

- repo: https://github.com/scientific-python/cookie
  rev: <version>
  hooks:
    - id: sp-repo-review

If you use additional_dependencies to add more plugins, like validate-pyproject, you should also include "repo-review[cli]" to ensure the CLI requirements are included.

List of checks

General

  • PY001: Has a pyproject.toml
  • PY002: Has a README.(md|rst) file
  • PY003: Has a LICENSE* file
  • PY004: Has docs folder
  • PY005: Has tests folder
  • PY006: Has pre-commit config
  • PY007: Supports an easy task runner (nox, tox, pixi, etc.)

PyProject

  • PP002: Has a proper build-system table
  • PP003: Does not list wheel as a build-dep
  • PP004: Does not upper cap Python requires
  • PP005: Using SPDX project.license should not use deprecated trove classifiers
  • PP006: The dev dependency group should be defined
  • PP301: Has pytest in pyproject
  • PP302: Sets a minimum pytest to at least 6 or 9
  • PP303: Sets the test paths
  • PP304: Sets the log level in pytest
  • PP305: Specifies strict xfail
  • PP306: Specifies strict config
  • PP307: Specifies strict markers
  • PP308: Specifies useful pytest summary
  • PP309: Filter warnings specified

GitHub Actions

  • GH100: Has GitHub Actions config
  • GH101: Has nice names
  • GH102: Auto-cancel on repeated PRs
  • GH103: At least one workflow with manual dispatch trigger
  • GH104: Use unique names for upload-artifact
  • GH200: Maintained by Dependabot
  • GH210: Maintains the GitHub action versions with Dependabot
  • GH211: Do not pin core actions as major versions
  • GH212: Require GHA update grouping

MyPy

  • MY100: Uses MyPy (pyproject config)
  • MY101: MyPy strict mode
  • MY102: MyPy show_error_codes deprecated
  • MY103: MyPy warn unreachable
  • MY104: MyPy enables ignore-without-code
  • MY105: MyPy enables redundant-expr
  • MY106: MyPy enables truthy-bool

Nox

Will not show up if no noxfile.py file is present.

  • NOX101: Sets minimum nox version
  • NOX102: Sets venv backend
  • NOX103: Set default per session instead of session list
  • NOX201: Set a script block with dependencies in your noxfile
  • NOX202: Has a shebang line
  • NOX203: Provide a main block to run nox

Pre-commit

Will not show up if using lefthook instead of pre-commit/prek.

  • PC100: Has pre-commit-hooks
  • PC110: Uses black or ruff-format
  • PC111: Uses blacken-docs
  • PC140: Uses a type checker
  • PC160: Uses a spell checker
  • PC170: Uses PyGrep hooks (only needed if rST present)
  • PC180: Uses a markdown formatter
  • PC190: Uses Ruff
  • PC191: Ruff show fixes if fixes enabled
  • PC192: Ruff uses ruff-check instead of ruff (legacy)
  • PC901: Custom pre-commit CI update message
  • PC902: Custom pre-commit CI autofix message
  • PC903: Specified pre-commit CI schedule

ReadTheDocs

Will not show up if no .readthedocs.yml/.readthedocs.yaml file is present.

  • RTD100: Uses ReadTheDocs (pyproject config)
  • RTD101: You have to set the RTD version number to 2
  • RTD102: You have to set the RTD build image
  • RTD103: You have to set the RTD python version
  • RTD104: You have to specify a build configuration now for readthedocs.

Ruff

  • RF001: Has Ruff config
  • RF002: Target version must be set
  • RF003: src directory doesn't need to be specified anymore (0.6+)
  • RF101: Bugbear must be selected
  • RF102: isort must be selected
  • RF103: pyupgrade must be selected
  • RF201: Avoid using deprecated config settings
  • RF202: Use (new) lint config section

Setuptools Config

Will not show up if no setup.cfg file is present.

  • SCFG001: Avoid deprecated setup.cfg names

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

sp_repo_review-2025.11.21.tar.gz (186.3 kB view details)

Uploaded Source

Built Distribution

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

sp_repo_review-2025.11.21-py3-none-any.whl (31.1 kB view details)

Uploaded Python 3

File details

Details for the file sp_repo_review-2025.11.21.tar.gz.

File metadata

  • Download URL: sp_repo_review-2025.11.21.tar.gz
  • Upload date:
  • Size: 186.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for sp_repo_review-2025.11.21.tar.gz
Algorithm Hash digest
SHA256 1198e7fd55bb4ecfbc05db6fa5e28d0a2b4707da32a97c07d8ecc114892c8c1b
MD5 e73a6cee4859a8160a71f33784c7f630
BLAKE2b-256 836d49fa92bc996068cba549eb9ab32934bff5ff7ac3f955efc2fd131489c248

See more details on using hashes here.

Provenance

The following attestation bundles were made for sp_repo_review-2025.11.21.tar.gz:

Publisher: cd.yml on scientific-python/cookie

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file sp_repo_review-2025.11.21-py3-none-any.whl.

File metadata

File hashes

Hashes for sp_repo_review-2025.11.21-py3-none-any.whl
Algorithm Hash digest
SHA256 e19b1dcca1d0967bdc97544f15d2a6b44cde3df432aa39d0a36751c734f37539
MD5 3fff469695891c8f396218b4ec52c776
BLAKE2b-256 254d2bedfc7fb6689b92412b58fdb84ec3920d0fccc52cfd8cb25dab40f9a1f0

See more details on using hashes here.

Provenance

The following attestation bundles were made for sp_repo_review-2025.11.21-py3-none-any.whl:

Publisher: cd.yml on scientific-python/cookie

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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