Skip to main content

Pytest plugin to generate json report in CTRF (Common Test Report Format)

Project description

CTRF for pytest

Pytest implementation of Common Test Report Format (CTRF) for test results.
Test report will be generated in JSON format.
Test report can be used to prettify the report in GitHub Actions with github-actions-ctrf.
Do not worry if report in GitHub does not appear immediately. It takes some time to process the report.

Features

  • Generates JSON report
  • Tested to work correctly with and without pytest-xdist
  • Tested to get browser name from pytest-playwright
  • Parametrized tests are supported and reported as 1 test with multiple retries

Installation

pip install pytest-json-ctrf

Usage

generate report.json file in the root directory of the project. File path is mandatory

pytest --ctrf report.json

Environment Variables may be used to specify the required Environment Object fields when using the CTRF slack-test-reporter.

CTRF_BUILD_NAME="Pytest JSON CTRF Report"
CTRF_BUILD_NUMBER="000"
CTRF_BUILD_URL="https://ctrf.io]"

JSON example

More info here: https://ctrf.io/docs/schema/examples

{
  "results": {
    "tool": {
      "name": "jest"
    },
    "summary": {
      "tests": 3,
      "passed": 1,
      "failed": 1,
      "pending": 0,
      "skipped": 1,
      "other": 0,
      "start": 1706644023,
      "stop": 1706644043
    },
    "environment": {
        "buildName": "Pytest JSON CTRF Report",
        "buildNumber": "000",
        "buildUrl": "https://ctrf.io"
    },
    "tests": [
      {
        "name": "User should be able to login",
        "status": "passed",
        "duration": 1200
      },
      {
        "name": "User profile information should be correct",
        "status": "failed",
        "duration": 800
      },
      {
        "name": "User should be able to logout",
        "status": "skipped",
        "duration": 0
      }
    ]
  }
}

Report Example

Example Image

Technical details

For future me and others who are interested in the technical details of the implementation.
The main idea is to handle xdist plugin because without it collecting report is quite straightforward.
By the example of putest-json-report plugin, I have learned that different plugins can be registered for the controller and workers node.
The pytest_runtest_logreport hook in the controller node is used to collect the test results from all the nodes so other nodes can just add some details to the TestReport object.

Credits

Roadmap

  • Add screenshots handling
  • Add hooks for the report extension

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_json_ctrf-0.3.7.tar.gz (8.2 kB view details)

Uploaded Source

Built Distribution

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

pytest_json_ctrf-0.3.7-py3-none-any.whl (7.2 kB view details)

Uploaded Python 3

File details

Details for the file pytest_json_ctrf-0.3.7.tar.gz.

File metadata

  • Download URL: pytest_json_ctrf-0.3.7.tar.gz
  • Upload date:
  • Size: 8.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pytest_json_ctrf-0.3.7.tar.gz
Algorithm Hash digest
SHA256 6defde973a05adc5e20371ade1b014f3a6f59596c20d93333d5a869dc7cfbd8f
MD5 c607a854301883c29b174da91164b690
BLAKE2b-256 093cdbf9d8539629bd2e1d12f3709407f0d4abd3f7e6fa1aa4f2ea61f17ec93b

See more details on using hashes here.

Provenance

The following attestation bundles were made for pytest_json_ctrf-0.3.7.tar.gz:

Publisher: deploy.yml on qamania/pytest-common-test-report-json

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

File details

Details for the file pytest_json_ctrf-0.3.7-py3-none-any.whl.

File metadata

File hashes

Hashes for pytest_json_ctrf-0.3.7-py3-none-any.whl
Algorithm Hash digest
SHA256 206412d1da8170975d4620c7211508e0926d34c2620cf3acffde18a373439ca7
MD5 b01479e79fb93f78bb0518a8bc451412
BLAKE2b-256 1d567a05ebc704e6fdd5f471633f44dd5a2dc43eec600fdba6d8b3d3ca0a6a10

See more details on using hashes here.

Provenance

The following attestation bundles were made for pytest_json_ctrf-0.3.7-py3-none-any.whl:

Publisher: deploy.yml on qamania/pytest-common-test-report-json

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