Files
codecov-action/README.md
T

130 lines
7.1 KiB
Markdown
Raw Normal View History

2020-04-04 14:00:57 +01:00
# Codecov GitHub Action
2019-08-08 14:59:24 -07:00
2022-05-09 14:53:21 -04:00
[![GitHub Marketplace](https://img.shields.io/badge/Marketplace-v3-undefined.svg?logo=github&logoColor=white&style=flat)](https://github.com/marketplace/actions/codecov)
2020-08-25 13:19:19 -05:00
[![FOSSA Status](https://app.fossa.com/api/projects/git%2Bgithub.com%2Fcodecov%2Fcodecov-action.svg?type=shield)](https://app.fossa.com/projects/git%2Bgithub.com%2Fcodecov%2Fcodecov-action?ref=badge_shield)
2021-03-15 01:20:30 +03:00
[![Workflow for Codecov Action](https://github.com/codecov/codecov-action/actions/workflows/main.yml/badge.svg)](https://github.com/codecov/codecov-action/actions/workflows/main.yml)
2020-04-04 14:00:57 +01:00
### Easily upload coverage reports to Codecov from GitHub Actions
2019-11-20 13:00:29 -08:00
2020-03-07 00:00:34 -08:00
>The latest release of this Action adds support for tokenless uploads from GitHub Actions!
2019-07-30 18:21:05 -07:00
2022-04-28 17:06:34 -04:00
## ⚠️ Deprecation of v1
2022-02-25 14:50:25 -05:00
**As of February 1, 2022, v1 has been fully sunset and no longer functions**
2021-06-24 10:50:37 -04:00
2021-08-09 08:58:02 +02:00
Due to the [deprecation](https://about.codecov.io/blog/introducing-codecovs-new-uploader/) of the underlying bash uploader,
2022-06-29 14:51:51 -04:00
the Codecov GitHub Action has released `v2`/`v3` which will use the new [uploader](https://github.com/codecov/uploader). You can learn
2021-06-24 10:50:37 -04:00
more about our deprecation plan and the new uploader on our [blog](https://about.codecov.io/blog/introducing-codecovs-new-uploader/).
We will be restricting any updates to the `v1` Action to security updates and hotfixes.
2022-06-29 14:51:51 -04:00
### Migration from `v1` to `v3`
The `v3` uploader has a few breaking changes for users
2021-06-24 10:50:37 -04:00
- Multiple fields have not been transferred from the bash uploader or have been deprecated. Notably
many of the `functionalities` and `gcov_` arguments have been removed. Please check the documentation
below for the full list.
2019-08-06 19:29:18 -07:00
## Usage
2022-06-29 14:51:51 -04:00
To integrate Codecov with your Actions pipeline, specify the name of this repository with a tag number (`@v3` is recommended) as a `step` within your `workflow.yml` file.
2020-03-04 22:22:38 -08:00
If you have a *private repository*, this Action also requires you to [provide an upload token](https://docs.codecov.io/docs/frequently-asked-questions#section-where-is-the-repository-upload-token-found-) from [codecov.io](https://www.codecov.io) (tip: in order to avoid exposing your token, store it as a `secret`). Optionally, you can choose to include up to four additional inputs to customize the upload context. **For public repositories, no token is needed**
2019-08-07 19:17:51 -07:00
2019-08-06 19:29:18 -07:00
Inside your `.github/workflows/workflow.yml` file:
```yaml
steps:
- uses: actions/checkout@master
2022-06-29 14:51:51 -04:00
- uses: codecov/codecov-action@v3
2019-08-06 19:29:18 -07:00
with:
2020-03-04 22:22:38 -08:00
token: ${{ secrets.CODECOV_TOKEN }} # not required for public repos
2020-07-10 15:32:51 -04:00
files: ./coverage1.xml,./coverage2.xml # optional
2020-03-04 22:22:38 -08:00
flags: unittests # optional
name: codecov-umbrella # optional
fail_ci_if_error: true # optional (default = false)
2020-10-16 18:27:17 -04:00
verbose: true # optional (default = false)
2019-08-06 19:29:18 -07:00
```
2020-04-04 14:00:57 +01:00
>**Note**: This assumes that you've set your Codecov token inside *Settings > Secrets* as `CODECOV_TOKEN`. If not, you can [get an upload token](https://docs.codecov.io/docs/frequently-asked-questions#section-where-is-the-repository-upload-token-found-) for your specific repo on [codecov.io](https://www.codecov.io). Keep in mind that secrets are *not* available to forks of repositories.
2019-08-06 19:29:18 -07:00
2019-08-07 18:44:06 -07:00
## Arguments
Codecov's Action supports inputs from the user. These inputs, along with their descriptions and usage contexts, are listed in the table below:
2019-08-07 19:17:51 -07:00
2019-08-07 18:44:06 -07:00
| Input | Description | Usage |
| :---: | :---: | :---: |
2020-03-04 18:30:14 -08:00
| `token` | Used to authorize coverage report uploads | *Required for private repos* |
| `files` | Comma-separated paths to the coverage report(s). Negated paths are supported by starting with `!` | Optional
2020-07-07 22:29:12 -04:00
| `directory` | Directory to search for coverage reports. | Optional
2021-06-24 10:50:37 -04:00
| `dry_run` | Don't upload files to Codecov | Optional
| `flags` | Flag the upload to group coverage metrics (unittests, uitests, etc.). Multiple flags are separated by a comma (ui,chrome) | Optional
2021-01-02 14:03:30 -05:00
| `commit_parent` | The commit SHA of the parent for which you are uploading coverage. If not present, the parent will be determined using the API of your repository provider. When using the repository provider's API, the parent is determined via finding the closest ancestor to the commit. | Optional
2020-04-04 14:00:57 +01:00
| `env_vars` | Environment variables to tag the upload with. Multiple env variables can be separated with commas (e.g. `OS,PYTHON`) | Optional
| `fail_ci_if_error` | Specify if CI pipeline should fail when Codecov runs into errors during upload. *Defaults to **false*** | Optional
| `functionalities` | Toggle functionalities | Optional
2022-07-25 12:45:07 -07:00
| `network` | Disable uploading the file network | Optional
2022-04-21 10:12:03 -04:00
| `gcov` | Run with gcov support | Optional
| `gcov_args` | Extra arguments to pass to gcov | Optional
| `gcov_ignore` | Paths to ignore during gcov gathering | Optional
| `gcov_include` | Paths to include during gcov gathering | Optional
2021-01-02 14:03:30 -05:00
| `move_coverage_to_trash` | Move discovered coverage reports to the trash | Optional
| `name` | Custom defined name for the upload | Optional
| `override_branch` | Specify the branch name | Optional
| `override_build` | Specify the build number | Optional
| `override_commit` | Specify the commit SHA | Optional
| `override_pr` | Specify the pull request number | Optional
| `override_tag` | Specify the git tag | Optional
| `root_dir` | Used when not in git/hg project to identify project root directory | Optional
2021-06-24 10:50:37 -04:00
| `slug` | Specify the slug manually (Enterprise use) | Optional
| `url` | Change the upload host (Enterprise use) | Optional
2020-10-16 18:27:17 -04:00
| `verbose` | Specify whether the Codecov output should be verbose | Optional
| `version` | Specify which version of the Codecov Uploader should be used. Defaults to `latest` | Optional
2021-01-02 18:53:08 -05:00
| `working-directory` | Directory in which to execute `codecov.sh` | Optional
2022-04-21 10:12:03 -04:00
| `xcode` | Run with xcode support | Optional
| `xcode_archive_path` | Specify the xcode archive path. Likely specified as the -resultBundlePath and should end in .xcresult | Optional
2019-08-07 18:44:06 -07:00
2019-08-07 07:59:10 -07:00
### Example `workflow.yml` with Codecov Action
```yaml
name: Example workflow for Codecov
on: [push]
jobs:
run:
runs-on: ${{ matrix.os }}
strategy:
2020-04-04 14:00:57 +01:00
matrix:
os: [ubuntu-latest, macos-latest, windows-latest]
2020-03-20 16:05:53 +00:00
env:
OS: ${{ matrix.os }}
PYTHON: '3.7'
2019-08-07 07:59:10 -07:00
steps:
- uses: actions/checkout@master
2020-04-04 14:00:57 +01:00
- name: Setup Python
2019-08-07 07:59:10 -07:00
uses: actions/setup-python@master
with:
2019-12-01 13:41:06 -05:00
python-version: 3.7
2019-08-07 07:59:10 -07:00
- name: Generate coverage report
run: |
pip install pytest
pip install pytest-cov
pytest --cov=./ --cov-report=xml
2020-04-04 14:00:57 +01:00
- name: Upload coverage to Codecov
2022-06-29 14:51:51 -04:00
uses: codecov/codecov-action@v3
2019-08-07 07:59:10 -07:00
with:
token: ${{ secrets.CODECOV_TOKEN }}
2020-07-07 22:29:12 -04:00
directory: ./coverage/reports/
2020-03-20 16:05:53 +00:00
env_vars: OS,PYTHON
2019-12-05 18:25:24 -08:00
fail_ci_if_error: true
files: ./coverage1.xml,./coverage2.xml,!./cache
2021-06-24 10:50:37 -04:00
flags: unittests
name: codecov-umbrella
2020-10-16 18:27:17 -04:00
verbose: true
2019-08-07 07:59:10 -07:00
```
2019-08-07 21:38:13 -07:00
## Contributing
2019-08-07 21:40:59 -07:00
Contributions are welcome! Check out the [Contribution Guide](CONTRIBUTING.md).
2019-08-07 07:59:10 -07:00
2020-04-04 14:00:57 +01:00
## License
2019-08-06 19:29:18 -07:00
2019-08-07 20:10:44 -07:00
The code in this project is released under the [MIT License](LICENSE).
2020-08-25 13:19:19 -05:00
2020-10-16 18:27:17 -04:00
[![FOSSA Status](https://app.fossa.com/api/projects/git%2Bgithub.com%2Fcodecov%2Fcodecov-action.svg?type=large)](https://app.fossa.com/projects/git%2Bgithub.com%2Fcodecov%2Fcodecov-action?ref=badge_large)