Skip to main content

Validate your Python file format with yapf

Project description

pytest-yapf3

Python PyTest CII Best Practices Code style: yapf

Validate your Python file format with yapf.

This is a pytest plugin, which make sure your python file is exactly formatted by yapf, or it will crash when running pytest.

Install

Version Python Format Status Download MIT

pip install pytest-yapf3

Requires:

  • Python 3.6 or above
  • Pytest:
    • pytest>=5.4,<8 when pytest-yapf3<0.7
    • pytest>=7 when pytest-yapf3>=0.7

If someone use this with Python 3.5 or Pytest less than 5.4, set 'pytest-yapf3<0.6.0'.

Usage

Modify setup.cfg (or pytest.ini):

[tool:pytest]
addopts =
    --yapf
    --yapfdiff
yapf-ignore =
    setup.py
    src/package/auto_generated/**.py

Add --yapf to pytest configuration addopts. If run with pytest -m yapf, only yapf is checked.

By default, only line summaries is displayed. With an optional --yapfdiff, a full text of yapf -d is displayed. If not configured here, pytest --yapfdiff will also work.

An optional yapf-ignore is supported. Each line specifies a glob pattern of files which should not check yapf.

The pytest will cache success results of pytest-yapf3, and will not check again if files not changed. Sometimes you may want to disable it. There are 2 ways:

  • pytest -p no:cacheprovider This may crash if any other pytest plugin not supports.
  • rm -rf .pytest_cache/v/yapf This is ugly, but safe for any environment.

Features and Todos

  • Basic support to validate yapf.
  • Fix the diff line count error and improve the performance.
  • Display YAPF-check as the error session name.
  • Display YAPF in pytest --verbose.
  • Add yapf as a marker to enable pytest -m yapf.
  • Support yapf-ignore to ignore specified files.
  • Skip running if a file is not changed.
  • 100% test coverage.

Develop

Prepare the environment:

pipenv install --dev
pipenv shell

Run test:

pytest

Badge

Like black, if your project always pass yapf checking provided by this project, you can use an unofficial badge to show off.

Markdown (README.md)

[![Code style: yapf](https://img.shields.io/badge/code%20style-yapf-blue)](https://github.com/google/yapf)

reStructuredText (README.rst)

.. image:: https://img.shields.io/badge/code%20style-yapf-blue
    :target: https://github.com/google/yapf
    :alt: Code style: yapf

License

The MIT License (MIT)

Copyright (c) 2019~2022 Yan QiDong

This repository is forked from pytest-yapf in 2019, which is not maintained since 2017. Besides extra features, the project structure is adjusted, and the code is enhanced to pass linters like flake8, pylint and, of course, yapf.

The 3 in pytest-yapf3 means this package supports Python 3 only.

Change Log

Release 0.6.2

  • Upgrade dependencies in Pipfile and its lock.
  • Enable GitHub actions.
  • Delete .travis.yml and .appveyor.yml

Release 0.6.1

  • Fix cache missing.

Release 0.6.0

  • Upgrade pytest to 5.4+, fix a warning.
  • Support python 3.6+ only, abandon 3.5
  • Use Pipfile with pipenv

Release 0.5.1

  • Fix coverage missing lines.
  • 100% test coverage.
  • Fix a crash when yapf crash.
  • Change development status to stable.

Release 0.5.0

  • Skip running if a file is not changed.
  • Add more usage description in README.

Release 0.4.0

  • Add yapf as a pytest marker to enable pytest -m yapf
  • Support yapf-ignore to ignore specified files
  • Fix a probabilistic issue caused by \r

Release 0.3.0

  • Display YAPF-check as the error session name
  • Display ::YAPF in pytest --verbose

Release 0.2.0

Since forked from pytest-yapf 0.1.1, there are some improvements:

  • Restructure the project and rewrite documents
  • Support Python 3.4+ only
  • Add linters to pytest, and fix their errors
  • Fix the line count error
  • Change build configurations in Travis and AppVeyor
  • Support coverage and displayed in codecov

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

pytest-yapf3-0.6.2.tar.gz (24.0 kB view details)

Uploaded Source

Built Distribution

pytest_yapf3-0.6.2-py3-none-any.whl (6.3 kB view details)

Uploaded Python 3

File details

Details for the file pytest-yapf3-0.6.2.tar.gz.

File metadata

  • Download URL: pytest-yapf3-0.6.2.tar.gz
  • Upload date:
  • Size: 24.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.16

File hashes

Hashes for pytest-yapf3-0.6.2.tar.gz
Algorithm Hash digest
SHA256 8980a39e78ca1739761922f6bf1a921cbf8a7c904eb1b892525ff12bdb85dfdd
MD5 2a4c95ec31e22190a38d40f3c4ad6df7
BLAKE2b-256 7092aad0711c7b88f5107d013be2c01dea8868ba83456e72e62d61c7295da6c1

See more details on using hashes here.

File details

Details for the file pytest_yapf3-0.6.2-py3-none-any.whl.

File metadata

File hashes

Hashes for pytest_yapf3-0.6.2-py3-none-any.whl
Algorithm Hash digest
SHA256 352151a20502357a2af98dd3d2a6879d815b93de212c78cfc47a5dbf26c2be34
MD5 010c87b16c2b3fa2bc100162ee6493b1
BLAKE2b-256 062ad899308f59522193d053854adf618e2b33ce6876ab722e13e5c85ac49c96

See more details on using hashes here.

Supported by

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