Files
codecov-action/README.md
T

96 lines
4.7 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
2020-03-04 22:22:38 -08:00
[![GitHub Marketplace](https://img.shields.io/badge/Marketplace-v1-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)
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
2019-08-06 19:29:18 -07:00
## Usage
2020-04-04 14:00:57 +01:00
To integrate Codecov with your Actions pipeline, specify the name of this repository with a tag number (`@v1` 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
- uses: codecov/codecov-action@v1
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
file: ./coverage.xml # optional
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)
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
2020-04-04 14:00:57 +01:00
Codecov's Action currently supports five inputs from the user: `token`, `file`, `flags`,`name`, and `fail_ci_if_error`. These inputs, along with their descriptions and usage contexts, are listed in the table below:
2019-08-07 19:17:51 -07:00
2020-05-03 10:22:07 -04:00
>**Update**: We've removed the `yml` parameter with the latest release of this action. Please put your custom codecov yaml file at the root of the repo because other locations will no longer be supported in the future.
2020-03-04 19:59:17 -08: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* |
| `file` | Path to the coverage report(s) | Optional
2020-07-10 15:32:51 -04:00
| `files` | Comma-separated paths to the coverage report(s) | Optional
2020-07-07 22:29:12 -04:00
| `directory` | Directory to search for coverage reports. | Optional
| `flags` | Flag the upload to group coverage metrics (unittests, uitests, etc.). Multiple flags are separated by a comma (ui,chrome) | 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
2019-11-19 11:26:54 -08:00
| `name` | Custom defined name for the upload | Optional
| `fail_ci_if_error` | Specify if CI pipeline should fail when Codecov runs into errors during upload. *Defaults to **false*** | Optional
2020-07-07 22:29:12 -04:00
| `path_to_write_report` | Write upload file to path before uploading | 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
uses: codecov/codecov-action@v1
2019-08-07 07:59:10 -07:00
with:
token: ${{ secrets.CODECOV_TOKEN }}
2019-08-07 12:01:44 -07:00
file: ./coverage.xml
2020-07-09 23:05:11 -04:00
files: ./coverage1.xml,./coverage2.xml
2020-07-07 22:29:12 -04:00
directory: ./coverage/reports/
2019-08-07 13:08:23 -07:00
flags: unittests
2020-03-20 16:05:53 +00:00
env_vars: OS,PYTHON
name: codecov-umbrella
2019-12-05 18:25:24 -08:00
fail_ci_if_error: true
2020-07-07 22:29:12 -04:00
path_to_write_report: ./coverage/codecov_report.gz
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
[![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)