Skip to main content

Reusable pytest results ingestion tooling with database export and CLI helpers.

Project description

pytest-chronicle

Searchable git-aware pytest history with a lean CLI and easy storage backends.

Pin down regressions. Squash bugs. Join the Federation today.

pytest-chronicle demo

What it does

Running pytest:

  • Emits per-test records (result/stdout/stderr/traceback)
  • Persists test result records to SQLite / Postgres (or implement your own storage backend) with:
    • git/CI metadata
    • pytest invocation parameters
    • timestamps
    • user-defined labels

With the pytest-chronicle CLI you can now query the test result history.

Install

pip install pytest-chronicle

Quickstart

pytest-chronicle init                                     # create config + local sqlite
pytest -q                                                 # auto-ingests using config/env/fallback SQLite
pytest-chronicle query last-green --format json --pretty    # ask questions
pytest-chronicle query last-red tests/test_mod.py::Test::test_case   # pytest-style selectors

Common commands

  • pytest-chronicle init – scaffold .pytest-chronicle.toml and an async SQLite DB.
  • pytest-chronicle ingest --jsonl <path> – ingest JSONL/summary artifacts.
  • pytest-chronicle query last-red|last-green|errors|flipped-green|compare – history lookups. Filters: -k/-m like pytest, --labels, --since, --until, --branch/--commit, positional pytest-style selectors, or --pytest-select "-m 'slow' -k expr path::nodeid". Outputs include per-test runtime with smart units (μs/ms/s) and git metadata; text mode shows colored tables by default (--no-color to disable). Slow tests (≥1s) are highlighted yellow, very slow (≥5s) in red. Use --show-marks to display test marks.
  • pytest-chronicle query timeline – colored TTY timeline of recent runs for matching tests (? marks not-run/filtered cases). Use -t/--show-times to display execution times.
  • pytest-chronicle query slowest – tests sorted by execution time (slowest first); use --status failed to find slowest failures.
  • pytest-chronicle query stats – per-test failure rates, pass/fail counts, and timing stats; use --min-runs N to filter low-sample tests, --sort-by failure-rate|avg-time|max-time|total-runs to rank.
  • pytest-chronicle run <project> -- <pytest args> – run pytest under uv, collect artifacts, optionally ingest.
  • pytest-chronicle backfill – ingest many summary.json files.
  • pytest-chronicle export-sqlite / import-sqlite – migrate between backends.
  • pytest-chronicle db upgrade – apply Alembic migrations.
  • pytest-chronicle config show|set – view or set repo defaults.

Configuration & defaults

  • Precedence: CLI flag --database-url > env (PYTEST_RESULTS_DB_URL, legacy TEST_RESULTS_DATABASE_URL / SCS_DATABASE_URL) > .pytest-chronicle.toml > fallback SQLite at <repo>/.pytest-chronicle/chronicle.db (async).
  • Example config:
    [chronicle]
    database_url = "postgresql+asyncpg://user:pass@host/db"
    project = "my-project"
    suite = "ci-smoke,linux"   # labels/tags (comma-separated)
    
  • Typical flow: use SQLite for local dev (via init); point env or config at Postgres for CI/prod. No other changes needed.
  • If you skip --project during init, it is auto-detected from pyproject.toml (or the current folder name); the CLI tells you how to change it later.

Pytest plugin (auto ingestion)

  • Install the package; the pytest_chronicle plugin is auto-discovered.
  • If a database is configured via env/config (or fallback SQLite), the plugin will ingest automatically at session end. You can still pass --chronicle-db <url> to override, or --chronicle-no-ingest to skip.
  • Default JSONL path: .artifacts/test-results/chronicle-results.jsonl (created automatically).

More docs

  • Detailed guide: docs/guide.md
  • Backend abstraction: docs/storage-backends.md

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_chronicle-0.4.4.tar.gz (43.5 kB view details)

Uploaded Source

Built Distribution

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

pytest_chronicle-0.4.4-py3-none-any.whl (53.1 kB view details)

Uploaded Python 3

File details

Details for the file pytest_chronicle-0.4.4.tar.gz.

File metadata

  • Download URL: pytest_chronicle-0.4.4.tar.gz
  • Upload date:
  • Size: 43.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.8

File hashes

Hashes for pytest_chronicle-0.4.4.tar.gz
Algorithm Hash digest
SHA256 063048259d87ea00a1b465a3ba137eaacd4a646a3ec549d9939d1b2146832fd5
MD5 48287dec1fd9758ff156824849709ff6
BLAKE2b-256 ecf31535094a76900f02942379d19b60245deb6af2f397876dc9dd96c5915ff1

See more details on using hashes here.

File details

Details for the file pytest_chronicle-0.4.4-py3-none-any.whl.

File metadata

File hashes

Hashes for pytest_chronicle-0.4.4-py3-none-any.whl
Algorithm Hash digest
SHA256 34f6a8ace19d2126f33bc48be0b42ecd519bd4acb6fc9a63ccb9a90a17a33fe5
MD5 e5b7565c434d2aeef149f5401ecbed1f
BLAKE2b-256 47ee1d6e0dc07a4bfc0c66f82648fa23392a462da243b2ac23695f3ad80e3e05

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