如何使用GitHub动作来获得总的综合覆盖率

106 阅读2分钟

这是一个关于如何使用GitHub动作来获得总的综合覆盖率,并为你的README创建一个徽章的草图。也有其他方法,但这是用一些常用的工具来完成工作。

我们将使用 tox 来运行测试,并使用 GitHub 动作来运行 tox。 一个GitHub gist将被用作scratch文件来存储徽章的参数,徽章将由shields.io呈现。

从 tox.ini 开始,它运行你的测试套件,还包括一个 "覆盖率 "环境,它结合、报告并产生一个 JSON 数据文件。

tox.ini

[tox]
envlist = py37,py38,py39,py310,coverage

[testenv]
commands =
    python -m coverage run -p -m pytest

[testenv:coverage]
basepython = python3.10
commands =
    python -m coverage combine
    python -m coverage report -m --skip-covered
    python -m coverage json

[gh-actions]
python =
    3.7: py37
    3.8: py38
    3.9: py39
    3.10: py310

我们将使用GitHub动作来运行tox,但在这之前,我们需要两个比特的基础设施。 去gist.github.com,做一个空的秘密gist。 复制该gist的id。 这里我们称之为123abc456def789。

接下来,我们将创建一个个人访问令牌,用于更新该gist。 去你的GitHub个人访问令牌页面,点击 "生成新令牌"。 选择 "gist "范围,点击 "生成令牌"。 复制显示的值,它看起来像 "ghp_FSfkCeFblahblah"。你不能再得到这个值了,所以要小心对待它。

在 GitHub 上的 repo 中,进入设置 - 秘密 - 操作,点击 "新建仓库秘密"。 使用 "GIST_TOKEN "作为名称,并粘贴 ghp_etc 标记作为秘密,然后 "添加秘密"。

现在我们准备创建GitHub动作。 它将在许多版本的Python上运行测试套件,然后运行覆盖步骤来合并所有的数据文件。 它使用JSON报告来提取可显示的百分比,然后使用第三方GitHub动作在Gist中创建JSON数据,以便shields.io可以显示徽章。

徽章是自动着色的。50%或更低是红色,90%或更高是绿色,两者之间有一个梯度,像这样:

The spectrum of badge colors.

作为奖励,还有一个带有覆盖率的行动工作总结。这里是工作流程文件。

.github/workflows/tests.yaml

# Run tests

name: "Test Suite"

on:
  push:
  pull_request:

defaults:
  run:
    shell: bash

jobs:
  tests:
    name: "Python ${{ matrix.python-version }} on ${{ matrix.os }}"
    runs-on: "${{ matrix.os }}"

    strategy:
      fail-fast: false
      matrix:
        os:
          - ubuntu-latest
          - macos-latest
          - windows-latest
        python-version:
          - "3.7"
          - "3.8"
          - "3.9"
          - "3.10"

    steps:
      - name: "Check out the repo"
        uses: "actions/checkout@v2"

      - name: "Set up Python"
        uses: "actions/setup-python@v2"
        with:
          python-version: "${{ matrix.python-version }}"

      - name: "Install dependencies"
        run: |
          python -m pip install tox tox-gh-actions

      - name: "Run tox for ${{ matrix.python-version }}"
        run: |
          python -m tox

      - name: "Upload coverage data"
        uses: actions/upload-artifact@v3
        with:
          name: covdata
          path: .coverage.*

  coverage:
    name: Coverage
    needs: tests
    runs-on: ubuntu-latest
    steps:
      - name: "Check out the repo"
        uses: "actions/checkout@v2"

      - name: "Set up Python"
        uses: "actions/setup-python@v2"
        with:
          python-version: "3.10"

      - name: "Install dependencies"
        run: |
          python -m pip install tox tox-gh-actions

      - name: "Download coverage data"
        uses: actions/download-artifact@v3
        with:
          name: covdata

      - name: "Combine"
        run: |
          python -m tox -e coverage
          export TOTAL=$(python -c "import json;print(json.load(open('coverage.json'))['totals']['percent_covered_display'])")
          echo "total=$TOTAL" >> $GITHUB_ENV
          echo "### Total coverage: ${TOTAL}%" >> $GITHUB_STEP_SUMMARY

      - name: "Make badge"
        uses: schneegans/dynamic-badges-action@v1.4.0
        with:
          # GIST_TOKEN is a GitHub personal access token with scope "gist".
          auth: ${{ secrets.GIST_TOKEN }}
          gistID: 123abc456def789   # replace with your real Gist id.
          filename: covbadge.json
          label: Coverage
          message: ${{ env.total }}%
          minColorRange: 50
          maxColorRange: 90
          valColorRange: ${{ env.total }}

现在,徽章可以用这样的URL显示,但要用你的GitHub名称替换YOUR_GITHUB_NAME,用你真正的Gist ID替换123abc456def789。

https://img.shields.io/endpoint?url=https://gist.githubusercontent.com/YOUR_GITHUB_NAME/123abc456def789/raw/covbadge.json

关于如何使用图片URL来显示徽章,请参考你选择的标记语言的文档。