Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

pytest-github-report

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

pytest-github-report

Generate a GitHub report using pytest in GitHub Workflows

  • 0.0.1
  • PyPI
  • Socket score

Maintainers
1

Pytest GitHub Report

This is an example of how we can use GitHub reports with pytest to generate a nice markdown matrix of results. The tests here are from the pytest-md-report repository.

Usage

Local

First, install dependencies:

$ pip install -r requirements.txt

And then run tests to see the markdown output (that will get piped into GitHub):

$ pytest --github-report tests/

This markdown output is provided via pytest-md-report and you can see other ways to customize it there!

GitHub Actions

To make this work in GitHub actions, it's actually very simple! You can either run the same command:

  - name: Report via Command Line
    run: pytest --github-report tests

Or export via the environment (e.g., good if you don't want to change your default testing command but want it to work during GitHub actions).

  - name: Report via Environment
    env:
      pytest_github_report: true
    run: pytest tests

Configuration

Advanced configuration can be done via the environment since we are scoping to GitHub actions.

Enable

If you want to have the report work from the environment (ideal if you don't want to change the command to run your tests) you can do:

export pytest_github_report=true

If that value is found with any none Null value (e.g., True or yes) a report will be generated given this module is installed.

Title

To set a particular title for your report:

  - name: Report via Environment
    env:
      pytest_github_report: true
      pytest_report_title: "Formatting"
    run: pytest tests
Zeros

By default, we only show colored emojis to indicate a success or failure. To use a count (value) instead:

  - name: Report via Environment
    env:
      pytest_github_report: true
      pytest_use_zeros: true
    run: pytest tests
Blanks

Or a blank value:

  - name: Report via Environment
    env:
      pytest_github_report: true
      pytest_use_blanks: true
    run: pytest tests
Detail

By default, we output a simplified view, which is pytest_verbosity: 0. You actually have two options for verbosity: This first is the default (0), which shows a summary by file:

  - name: Report via Environment
    env:
      pytest_verbosity: 0
    run: pytest --github-report tests

Notice below that although the table shows summary by file, the output section shows both failures within the file:

img/report-simple.png

The second shows per test results (adding the function name) and adds more detail to the matrix:

  - name: Report via Environment
    env:
      pytest_verbosity: 2
    run: pytest --github-report tests

img/report-verbosity.png

In this case, the detail is on the level of the function. But either way, detail is printed below the matrix, as you can see above!

Emojis

Choose the emijos (or characters) you want for your tests! A helpful emoji guide is here.

  - name: Report via Environment
    env:
      pytest_github_report: true
      pytest_report_title: ":unicorn: Report With Custom Emojis :unicorn:"
      pytest_passed_emoji: ":green_heart:"
      pytest_failed_emoji: ":heart:"
      pytest_xpassed_emoji: ":bangbang:"
      pytest_xfailed_emoji: ":bangbang:"
      pytest_skipped_emoji: ":shipit:"
    run: pytest tests

Here is an example with the custom emojis above!

img/report-custom-emojis.png

You can see the GitHub workflow for these examples.

Thanks!

The markdown functionality here is based off of thombashi/pytest-md-report which is released under an MIT license that we credit in .github/LICENSE.

Keywords

FAQs


Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc