Skip to main content

An opinionated testing suite organizer for pytest

Project description

SuiteAs

License PyPI version Checked with mypy Linting: Ruff pre-commit.ci status codecov Downloads

An opinionated testing suite organizer and linter for pytest.

SuiteAs will automatically generate a skeletonized unit test suite based on the structure of your project. Then, going forward, it will enforce matching names and folder structure between your testing suite and your project using linter rules.

For now, only linting is supported; automatic test suite generation will be added later.

Sweet As

INFORMAL • NEW ZEALAND

very satisfactory; excellent.

The recommended way to use SuiteAs is using the pre-commit framework. Add the following to your .pre-commit-config.yaml file:

- repo: https://github.com/nathanjmcdougall/suiteas
    rev: v0.3.1
    hooks:
      - id: suiteas

You can also install and run SuiteAs as a standalone package:

pip install suiteas
python -m suiteas .

SuiteAs will try to automatically determine your project directory structure and configuration, but you can manually configure SuiteAs in a pyproject.toml file.

For example, if your project looks like this:

.
└── myrepo/
    ├── src/
    │   ├── mypkg/
    │   └── otherpkg/
    ├── tests/
    │   ├── unit/
    │   │   ├── mypkg/
    │   │   └── otherpkg/
    │   └── endtoend/
    └── pyproject.toml

Then you would add this section to pyproject.toml:

[tool.suiteas]
pkg_names = ["mypkg", "otherpkg"]
src_rel_path = "src"
tests_rel_path = "tests"
unittest_dir_name = "unit"
ignore = ["SUI002"]

The final line will globally disable the linting of the SUI002 rule.

Rules

SuiteAs will enforce the following rules:

Rule Description
SUI001 Function or class is missing a corresponding test function
SUI002 Pytest test class is empty
SUI003 Pytest file does not import the function being tested

Developer Information

Package Management

This project uses rye to manage dependencies, virtual environments, and the python installation. Run rye sync from the project root to install the development environment.

Hooks with pre-commit

This project uses pre-commit to manage hooks. After installing the development environment, run pre-commit install.

Signed Commits

This project requires signed commits. Please see this guide from the VS Code project for instructions on how to configure this.

Diagramming

This project uses D2Lang to develop and maintain design diagrams.

Changelog

This project uses towncrier to manage the changelog. Each PR should have at least one associated GitHub issue. Before the PR is merged, a changelog entry should be created for any issues which are resolved by the PR. The changelog entry files are created in the doc/changelog_entries directory, with the filename following the convention <github id>.<type>.rst where <github id> is the GitHub issue ID number, and <type> is one of the types documented in the pyproject.toml file in the [tool.towncrier.type] sections.

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

suiteas-0.3.3.tar.gz (33.1 kB view details)

Uploaded Source

Built Distribution

suiteas-0.3.3-py2.py3-none-any.whl (17.5 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file suiteas-0.3.3.tar.gz.

File metadata

  • Download URL: suiteas-0.3.3.tar.gz
  • Upload date:
  • Size: 33.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.12.3

File hashes

Hashes for suiteas-0.3.3.tar.gz
Algorithm Hash digest
SHA256 d132135f4ac7529f0746b60afce313fd20918f5ec7f27f6864d3d1a37174b14c
MD5 0c5e346017ccda2b1019fa61242733c6
BLAKE2b-256 8b6909b598d11ce9ffb95097a70b933ba482442deba4a68b662830955cf1a1cd

See more details on using hashes here.

File details

Details for the file suiteas-0.3.3-py2.py3-none-any.whl.

File metadata

  • Download URL: suiteas-0.3.3-py2.py3-none-any.whl
  • Upload date:
  • Size: 17.5 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.12.3

File hashes

Hashes for suiteas-0.3.3-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 e8a5ec94539418f2dec154a83d38a11d80e4c9dd1865219bd3c8cb39c3c16123
MD5 b7841502a258b59a5c809310dbe326c8
BLAKE2b-256 c676736b5a8d313ef44ed30192e7d74db615776ef0dbc7d18dc9924a8eae85c1

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