Skip to main content

Style checker for Launchpad doctests.

Project description

lp-lint-doctest is a style checker for Python doctests stored in text files (as opposed to doctests stored in docstrings), optimized for use in Launchpad development. It applies the following checks:

  • Comments should be in the narrative part of the doctest (i.e. in unindented text) rather than in Python examples.

  • Narrative text lines are limited to 79 characters.

  • Source lines in examples (beginning with >>> or ...) are limited to 71 characters.

  • Expected output lines in examples are limited to 75 characters.

  • Source and expected output lines should be indented by exactly four spaces.

  • There should be no trailing whitespace.

  • reStructuredText-style headings should be used, not MoinMoin-style.

A # noqa comment in any source line in an example suppresses the comment, line length, indentation, and trailing whitespace checks for all lines in that example.

In addition, lp-lint-doctest runs pyflakes on the accumulated source code of each doctest file.

This project was split out from Curtis Hovey’s pocket-lint project. Since that was written, many other excellent linters have arisen for most of the other source types supported by pocket-lint, but there seems to be no other viable replacement for its doctest checks.

lp-lint-doctest supports pre-commit. To use it, add the following to the repos section of your .pre-commit-config.yaml file:

-   repo: https://git.launchpad.net/lp-lint-doctest
    rev: ''  # pick a git tag to point to
    hooks:
    -   id: lp-lint-doctest

If you need to add a custom doctest option flag, then add args: [--allow-option-flag, MY_CUSTOM_FLAG_NAME].

NEWS for lp-lint-doctest

0.5 (2022-09-09)

  • Bump line length limit to 79 characters, which better matches Launchpad’s black configuration.

0.4 (2021-10-27)

  • Run on types: [rst] by default. This is a better default for use with repositories other than Launchpad itself (which can override this).

  • Declare support for Python 3.10.

0.3 (2021-07-27)

  • Allow # noqa comments to suppress comment checks as well.

0.2 (2021-07-25)

  • Add --allow-option-flag command-line option to register custom doctest option flags.

  • Allow comments in source lines in examples if they contain doctest directives.

  • Allow suppressing checks for an example by adding a # noqa comment to any of its source lines.

0.1 (2021-07-24)

  • Initial release, split out from pocket-lint.

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

lp-lint-doctest-0.5.tar.gz (11.2 kB view details)

Uploaded Source

Built Distribution

lp_lint_doctest-0.5-py3-none-any.whl (11.3 kB view details)

Uploaded Python 3

File details

Details for the file lp-lint-doctest-0.5.tar.gz.

File metadata

  • Download URL: lp-lint-doctest-0.5.tar.gz
  • Upload date:
  • Size: 11.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/33.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.63.0 importlib-metadata/4.11.2 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.10.4

File hashes

Hashes for lp-lint-doctest-0.5.tar.gz
Algorithm Hash digest
SHA256 98c7abddabe367093f54630f3dbaa159158e41d3d1e468aef7afb2c869b995fa
MD5 e30a7b9486c549970dc45f560740f023
BLAKE2b-256 d6e27d366a09b3577eb6e5fa5513913bf7cd29fbb8ae2ce3b20bfcd5cec9f9fc

See more details on using hashes here.

File details

Details for the file lp_lint_doctest-0.5-py3-none-any.whl.

File metadata

  • Download URL: lp_lint_doctest-0.5-py3-none-any.whl
  • Upload date:
  • Size: 11.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/33.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.63.0 importlib-metadata/4.11.2 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.10.4

File hashes

Hashes for lp_lint_doctest-0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 9552a7ee5151f1d2fe279a756f25a06018d9befc44817ae7dd7702e8149ea952
MD5 4156a515cea947752ea08848738573bd
BLAKE2b-256 54df7c1ce5c2e4f58839a5316c6b9926d08c97b9158a4b917e966680227dea5c

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