Update release.md #686
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Run code coverage | |
on: | |
push: | |
branches: | |
- dev | |
tags-ignore: # exclude tags created by "ci_addons publish_github_release" | |
- 'latest' | |
- 'latest-tmp' | |
pull_request: | |
workflow_dispatch: | |
jobs: | |
run-coverage: | |
name: ${{ matrix.os }}, opt reqs ${{ matrix.opt_req }} | |
runs-on: ${{ matrix.os }} | |
# TODO | |
# run pipeline on either a push event or a PR event on a fork | |
# if: github.event_name != 'pull_request' || github.event.pull_request.head.repo.full_name != github.event.pull_request.base.repo.full_name | |
defaults: | |
run: | |
shell: bash | |
strategy: | |
matrix: | |
include: | |
- { os: ubuntu-latest , opt_req: true } | |
- { os: ubuntu-latest , opt_req: false } | |
- { os: windows-latest, opt_req: false } | |
- { os: macos-latest , opt_req: false } | |
env: | |
OS: ${{ matrix.os }} | |
PYTHON: '3.11' | |
steps: | |
- name: Cancel non-latest runs | |
uses: styfle/[email protected] | |
with: | |
all_but_latest: true | |
access_token: ${{ github.token }} | |
- uses: actions/checkout@v3 | |
with: | |
submodules: 'recursive' | |
- name: Set up Python | |
uses: actions/setup-python@v4 | |
with: | |
python-version: ${{ env.PYTHON }} | |
- name: Install dependencies | |
run: | | |
python -m pip install --upgrade pip | |
python -m pip install -r requirements-dev.txt -r requirements.txt -r requirements-opt.txt | |
- name: Install package | |
run: | | |
python -m pip install -e . # must install in editable mode for coverage to find sources | |
python -m pip list | |
- name: Run tests and generate coverage report | |
run: | | |
pytest --cov | |
python -m coverage xml # codecov uploader requires xml format | |
python -m coverage report -m | |
- name: Upload coverage to Codecov | |
uses: codecov/codecov-action@v4 | |
with: | |
fail_ci_if_error: true | |
env: | |
CODECOV_TOKEN: ${{ secrets.CODECOV_TOKEN }} |