Skip to main content

Bright ideas for improving your pytest experience

Project description

pytest-brightest

What is pytest-brightest? It is a pytest plugin that uses the brightest ideas in software testing research to illuminate problems with your test suite and brighten up the execution of your tests.

Table of Contents

Perspectives

pytest-brightest is a tool that helps software engineers run their test suites more effectively. Here are three perspectives on how it can be useful:

  • The Busy Developer: "I need to get feedback from my tests as quickly as possible. By using pytest-brightest to run the fastest tests first, I can find out if I've introduced any simple bugs in seconds, rather than waiting minutes for the whole suite to run."
  • The Quality Assurance Engineer: "My team is struggling with flaky tests that pass or fail unpredictably. pytest-brightest's shuffling capabilities help us shine a light on these tests by breaking hidden dependencies, making our test suite more reliable."
  • The Open-Source Maintainer: "When a contributor submits a pull request, I want to be confident it doesn't re-introduce old bugs. Reordering tests to run previously failing ones first gives me a faster signal, streamlining my review process."

Why pytest-brightest?

In software testing, not all test executions are created equal. Some tests are long, others are short. Some are prone to failure, while others are steadfastly reliable. pytest-brightest helps you shine a light on these characteristics to run your test suite more intelligently. It's not just about leveraging the brightest ideas from software testing research; it's about making your tests brighter (yes, the pun is intended!). Whether you want to get feedback faster, find flaky tests, or simply bring more clarity to your testing chaos, pytest-brightest is here to help.

Requirements

To use pytest-brightest, you'll need:

  • pytest
  • pytest-json-report

pytest-brightest uses the data generated by pytest-json-report to work its magic. If you have pytest-json-report installed, pytest-brightest will automatically configure it for you.

Installation

Using uv

To install pytest-brightest using uv, a fast Python package installer and resolver, run the following command:

uv add pytest-brightest --group dev

Using poetry

To install pytest-brightest using poetry, a tool for dependency management and packaging in Python, run the following command:

poetry add pytest-brightest --group dev

Modes of Operation

pytest-brightest is enabled with the --brightest flag and can operate in several modes, configured through the --reorder-by-technique option.

Reordering

You can reorder your tests based on a variety of criteria:

  • cost: Reorders tests based on their execution time from the previous run. This is perfect for getting quick feedback by running faster tests first.
  • name: Reorders tests alphabetically by their name.
  • failure: Reorders tests based on their failure history, running tests that failed in the previous run first. This is a powerful technique for regression testing.

Shuffling

  • shuffle: Randomizes the order of your tests. This is an excellent way to uncover hidden dependencies between tests and identify "flaky" tests that pass or fail based on the order in which they are run.

Command-Line Arguments

Here's a breakdown of the command-line arguments you can use to control pytest-brightest:

  • --brightest
    • Description: Enable the pytest-brightest plugin.
    • Default: False
  • --reorder-by-technique
    • Description: The technique to use for reordering or shuffling tests.
    • Options: shuffle, name, cost, failure
    • Default: None
  • --reorder-by-focus
    • Description: The scope of the reordering or shuffling.
    • Options: modules-within-suite, tests-within-module, tests-across-modules
    • Default: tests-across-modules
  • --reorder-in-direction
    • Description: The direction of the reordering.
    • Options: ascending, descending
    • Default: ascending
  • --seed
    • Description: A seed for the random number generator used for shuffling, ensuring reproducible results.
    • Default: (random)

Examples

Run faster tests first

pytest --brightest --reorder-by-technique cost --reorder-in-direction ascending

Run previously failing tests first

pytest --brightest --reorder-by-technique failure --reorder-in-direction descending

Shuffle all tests with a specific seed

pytest --brightest --reorder-by-technique shuffle --seed 12345

Shuffle tests within each module, but keep the module order

pytest --brightest --reorder-by-technique shuffle --reorder-by-focus tests-within-module

Contributing and Reporting Issues

Contributions are welcome! This project is open-source and thrives on community involvement. Let's make testing brighter, together.

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_brightest-0.1.0.tar.gz (152.9 kB view details)

Uploaded Source

Built Distribution

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

pytest_brightest-0.1.0-py3-none-any.whl (15.5 kB view details)

Uploaded Python 3

File details

Details for the file pytest_brightest-0.1.0.tar.gz.

File metadata

  • Download URL: pytest_brightest-0.1.0.tar.gz
  • Upload date:
  • Size: 152.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.6

File hashes

Hashes for pytest_brightest-0.1.0.tar.gz
Algorithm Hash digest
SHA256 3c916b4dbcb70c9c1cd918bb84d53a6057ac8dab800cb660066be446db2740fc
MD5 d8e97d1188ee988eb86d8ac1b724f86d
BLAKE2b-256 4cbebfbe4f1dac2c2b263af2bbc630da56e7f8da213232510cfc74699839b8fa

See more details on using hashes here.

File details

Details for the file pytest_brightest-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for pytest_brightest-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 769216675a4d3e98da888a6670dcd50c583e571297fc601a0d148cd95214ac39
MD5 08484cad8ca42f84dcb7689831714197
BLAKE2b-256 ab03087e759fe096d84f21f7948429f54b166e5cbbe649fb3be55c6eccb8ee87

See more details on using hashes here.

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