Github 代码覆盖度展示
在很多开源项目上,都有很多徽章用于展现项目的状态
在这之中,有两个是大部分项目都能用到的:测试以及测试覆盖
在更早一点的时间,测试都需要使用第三方的持续化集成工具,比如 Travis CI、以及 Azure pipeline,大概的实现原理是使用 docker 在云服务器上拉取代码并执行测试,根据测试结果返回不同的结果,并生成相应的徽章
而自从 Github Actions 发布后,已经可以直接在 Github Actions 里直接进行测试
一般而言,很多语言都有相关工具对代码覆盖率进行统计,但是要展示出来则需要一个平台来生成相应的徽章。比较常用的就是 codecov,通过测试工具生成相关的输出文件并使用对应工具发送到 codecov
下面针对不同语言,对使用 Github Actiosn 来进行测试并生成 codecov 代码覆盖率进行说明
Python
常用的 Python 测试框架是pytest
,在安装pytest-cov
后,可以使用pytest --cov-report=xml --cov=src/
来针对./src/
目录生成一个.xml
覆盖率文件
使用pip
安装codecov
工具后,即可使用codecov --token ${{ secrets.CODECOV_TOKEN }}
将覆盖率文件发送到自己 codecov.io 的对应项目中
这里用到的 token 可以登录到 codecov.io 上进入对应的项目获取,由于默认的 Github Actions 本身是公开的,因此需要在项目的 setting 内设置 secrets,这样就可以在不泄密的情况下将 token 传入 Github Actions
下面是一个参考的 Github Actions 配置文件
name: master on: push: branchs: - master jobs: build: name: Test runs-on: ubuntu-latest steps: - uses: actions/checkout@v2 - uses: actions/setup-python@v1 with: python-version: '3.8' - run: sudo python -m pip install -r requirements.txt - run: pytest --cov-report=xml --cov=src/ - run: codecov --token ${{ secrets.CODECOV_TOKEN }}
Go
Go 自带测试框架,直接使用go test ./... -race -coverprofile=coverage.txt -covermode=atomic
即可输出覆盖文件,使用bash <(curl -s https://codecov.io/bash) -t ${{ secrets.CODECOV_TOKEN }}
即可传至 codecov.io
下面是一个参考的 Github Actions 配置文件
name: master on: push: branchs: - master jobs: build: runs-on: ubuntu-latest steps: - uses: actions/checkout@master - uses: actions/setup-go@v1 with: go-version: 1.13 - run: go test ./... -race -coverprofile=coverage.txt -covermode=atomic -v - run: bash <(curl -s https://codecov.io/bash) -t ${{ secrets.CODECOV_TOKEN }}