Skip to main content

Generic pytest reporter that uploads test results to the TestRelic AI cloud platform.

Project description

testrelic-pytest

PyPI

Generic pytest reporter that ships your test results to the TestRelic AI cloud platform. Works with any pytest project — unit tests, API tests, integration tests — and stays out of the way when no API key is configured.

Install

pip install testrelic-pytest

The plugin auto-registers via the pytest11 entry point. Nothing to import.

Configure

export TESTRELIC_API_KEY=tr_live_...
pytest

The plugin silently no-ops when TESTRELIC_API_KEY is unset, so it is safe to add to any project.

Options

All options can be set via CLI flag, environment variable, or a JSON file at .testrelic/testrelic-config.json. Precedence (highest first): CLI flag → environment → JSON file → defaults.

CLI flags use a --testrelic-pytest-* prefix so they don't collide with the testrelic-playwright plugin if both are installed.

CLI flag Env var Default Purpose
--testrelic-pytest-disable TESTRELIC_DISABLE=1 off Force-disable the plugin.
--testrelic-pytest-api-key VALUE TESTRELIC_API_KEY API key from the TestRelic dashboard.
--testrelic-pytest-endpoint URL TESTRELIC_CLOUD_ENDPOINT https://platform.testrelic.ai/api/v1 Cloud base URL.
--testrelic-pytest-upload-strategy {batch,realtime,both,none} TESTRELIC_UPLOAD_STRATEGY batch When to send results.
--testrelic-pytest-quiet TESTRELIC_QUIET=1 off Suppress banner output.
--testrelic-pytest-run-type {smoke,regression,nightly,ci} TESTRELIC_RUN_TYPE Dashboard bucket.
--testrelic-pytest-project-name NAME TESTRELIC_PROJECT_NAME git remote or pyproject name Stable project identity.
--testrelic-pytest-artifact-threshold-kb N 32 Captured output beyond N KB is truncated inline.
--testrelic-pytest-output PATH Optional JSON dump for debugging.

Config file (.testrelic/testrelic-config.json)

{
  "apiKey": "$TESTRELIC_API_KEY",
  "endpoint": "https://platform.testrelic.ai/api/v1",
  "upload": "batch",
  "projectName": "my-suite",
  "artifactThresholdKb": 32,
  "uploadArtifacts": true,
  "queueDirectory": ".testrelic/queue",
  "metadata": { "team": "platform" }
}

$ENV_VAR strings are expanded against the process environment at startup.

What gets captured

For each test the plugin captures:

  • nodeId, file, className, testName, parametrizeId
  • Outcome: passed | failed | skipped | xfailed | xpassed | error
  • Duration (ms) and per-phase breakdown (setup/call/teardown)
  • Markers (e.g. @pytest.mark.smoke), keywords, parametrize ids
  • Skip reasons and pytest warnings
  • Failure tracebacks and assertion repr
  • Captured stdout / stderr / caplog (inline with redaction; truncated above --testrelic-artifact-threshold-kb, hard cap 1 MB per stream — artifact upload for large streams is planned for v0.2)

Test runs include CI metadata auto-detected from GitHub Actions, GitLab CI, Jenkins, and CircleCI, plus git branch/commit/author from the working tree.

pytest-xdist

Parallel runs via pytest-xdist (pytest -n 4) are supported out of the box. Each worker forwards its TestReport objects through the xdist channel; only the controller node uploads. The result is exactly one cloud run with all tests aggregated.

Offline mode

Any upload that fails after retries is written to ~/.testrelic/queue/ as a JSON file. Re-run later:

testrelic-pytest drain

The drainer re-authenticates with TESTRELIC_API_KEY and replays each entry to its original endpoint.

See also

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

testrelic_pytest-0.1.1.tar.gz (31.2 kB view details)

Uploaded Source

Built Distribution

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

testrelic_pytest-0.1.1-py3-none-any.whl (39.3 kB view details)

Uploaded Python 3

File details

Details for the file testrelic_pytest-0.1.1.tar.gz.

File metadata

  • Download URL: testrelic_pytest-0.1.1.tar.gz
  • Upload date:
  • Size: 31.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for testrelic_pytest-0.1.1.tar.gz
Algorithm Hash digest
SHA256 e5e137b7c495446c7f227c8a1f930aa4be951759413cc7a5e27f580cb3b91b7c
MD5 1408200200c2330c2507cc8a4d80e88c
BLAKE2b-256 ba3b409991489b81de5aba14bf33e092d4022b7b88ac06f3869d8198ef5c51ba

See more details on using hashes here.

Provenance

The following attestation bundles were made for testrelic_pytest-0.1.1.tar.gz:

Publisher: publish-pytest-prod.yml on testrelic-ai/testrelic-python-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file testrelic_pytest-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for testrelic_pytest-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 22d38db37a498f48b71bb8a22c28b88ca95d9e9b00f7127c2fad0bf0272423d4
MD5 848c56734f1c6b168b22996869bd2628
BLAKE2b-256 d5c178d3e7590051881a76fe65a0ea630f051d57078c6b40f58ff5b5763bd52b

See more details on using hashes here.

Provenance

The following attestation bundles were made for testrelic_pytest-0.1.1-py3-none-any.whl:

Publisher: publish-pytest-prod.yml on testrelic-ai/testrelic-python-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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