Skip to main content

A Pytest plugin for intelligent retrying of flaky tests.

Project description

pytest-smart-rerun

PyPI License

pytest-smart-rerun is a lightweight Pytest plugin that retries flaky tests with configurable attempts and delays. It integrates directly with Pytest's hook system, requires no external dependencies, and works out of the box from the command line or via per-test decorators.

Installation

pip install pytest-smart-rerun

For local development:

git clone https://github.com/Aki-07/pytest-smart-rerun.git
cd pytest-smart-rerun
pip install -e .

Quick start

Retry all failing tests up to three times with a one second delay:

pytest --smart-rerun --smart-rerun-max=3 --smart-rerun-delay=1

Use the smart_rerun marker to target specific flaky tests:

import pytest


@pytest.mark.smart_rerun(max=4, delay=0.5)
def test_eventually_consistent_service(client):
    response = client.read_state()
    assert response.status_code == 200

Combine both for a default retry policy with test-level overrides.

CLI options

  • --smart-rerun: enable smart reruns for the test session.
  • --smart-rerun-max=N: set the total number of attempts per test (default: 2).
  • --smart-rerun-delay=SECONDS: add a delay between retries (default: 0).
  • --smart-rerun-backoff=linear|exp|none: apply linear or exponential backoff to delay intervals.
  • --smart-rerun-errors=name1,name2: only retry failures whose exception names match the allow-list.
  • --smart-rerun-report=PATH: write structured JSON analytics for downstream dashboards or triage tooling.
  • --smart-rerun-ai: enable MCP-powered AI analysis to classify failures and adapt retry behaviour.
  • --smart-rerun-ai-report=PATH: append AI classifications and suggested actions to a JSON artifact.

Invalid values raise a Pytest UsageError, keeping failure feedback obvious.

Configuration via pytest.ini

All CLI options have config equivalents so you can bake defaults into your repository:

[pytest]
smart_rerun = true
smart_rerun_max = 3
smart_rerun_delay = 0.5
smart_rerun_backoff = exp
smart_rerun_errors = TimeoutError,ConnectionError
smart_rerun_report = reports/smart_rerun.json
smart_rerun_ai = true
smart_rerun_ai_endpoint = https://mcp.example.com/analyze
smart_rerun_ai_token = {{ env:SMART_RERUN_AI_TOKEN }}
smart_rerun_ai_report = reports/smart_rerun_ai.json
smart_rerun_ai_cache = .cache/smart_rerun_ai.json
smart_rerun_ai_redact = true

Features

  • Intelligent reruns driven purely by Pytest hooks—no external dependencies.
  • Automatic attempt logging with rerun-aware, colourised terminal summaries ready for CI.
  • Per-test overrides through @pytest.mark.smart_rerun(max=..., delay=..., backoff=..., errors=...).
  • Linear or exponential backoff strategies that cooperate with scripted delays.
  • Exception-aware filtering so only flaky categories (e.g. timeouts) trigger reruns.
  • Structured JSON analytics for dashboards or historical insights via --smart-rerun-report.
  • AI-assisted classification that adjusts retry strategy on the fly (delay overrides, early exits, rich reporting).
  • Works alongside existing Pytest plugins and respects fixture/state isolation.

AI-powered smart reruns

Turn on the MCP-backed engine with either --smart-rerun-ai or smart_rerun_ai = true. When a test fails, the plugin gathers the stack trace, exception metadata, and retry configuration, then:

  • Sends it to the configured MCP endpoint (or falls back to built-in heuristics when offline).
  • Classifies the failure (flaky-network, deterministic, environmental, …) with a confidence score.
  • Adapts the retry policy dynamically—e.g. retry_with_delay(2s) for network blips or stop_retry for logic bugs.
  • Writes rich analytics into the main JSON report and, if configured, an AI-specific trail (--smart-rerun-ai-report).

Caching (--smart-rerun-ai-cache) avoids duplicate calls, --smart-rerun-ai-redact trims overly verbose traces before transmission, and environment variables such as SMART_RERUN_AI_TOKEN can feed credentials securely.

Future roadmap

  1. Natural-language retry policies that the MCP agent translates into structured plugin config.
  2. Correlating repeated failures across repositories to suggest code-level fixes automatically.
  3. Optional dashboards that visualise the JSON analytics over time for QA and release teams.

Development

python -m venv .venv
source .venv/bin/activate
pip install -U pip setuptools wheel
pip install -e .[test]
pytest -v
pytest --smart-rerun --smart-rerun-max=3 --smart-rerun-delay=1 -v

Release workflow

  1. python -m build
  2. python -m twine check dist/*
  3. python -m twine upload dist/*

Refer to Publishing to PyPI for account setup and API tokens.

License

MIT © 2025 Akilesh KR. See LICENSE for full text.

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_smart_rerun-0.1.2.tar.gz (14.7 kB view details)

Uploaded Source

Built Distribution

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

pytest_smart_rerun-0.1.2-py3-none-any.whl (13.8 kB view details)

Uploaded Python 3

File details

Details for the file pytest_smart_rerun-0.1.2.tar.gz.

File metadata

  • Download URL: pytest_smart_rerun-0.1.2.tar.gz
  • Upload date:
  • Size: 14.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for pytest_smart_rerun-0.1.2.tar.gz
Algorithm Hash digest
SHA256 8b596c6f7c4b3a2c636819f1828a48eb5d843c8c7c5630abcf7aa04aa2529394
MD5 4c871fe2ec256d40f0d79a1a799781bc
BLAKE2b-256 7a2a1fc2982ee37102bae9001b5eb8d504befd951903c63007c78b49701926b0

See more details on using hashes here.

File details

Details for the file pytest_smart_rerun-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for pytest_smart_rerun-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 b4824c2b9948142f535f52f7d94e9d3451e9246bfdebe623bfaf0d4f4acf69db
MD5 1f79926a1d68f25cf8323880fdd11f43
BLAKE2b-256 610cdf0c5208620c0cd4555459b9e2ecda200f69eef41fa4f9aef07e757ae2b6

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