Unit Test Coverage.
testing:coverage
Calculate test coverage based on test results and report the coverage badge.
# Applicable Events
# Overall Coverage
The coverage is parsed from the local coverage report file. The following report formats are currently supported:
json
(recommended)json-summary
lcov
(recommended)jacoco
golang
# Incremental Coverage
The test coverage for changed lines is only supported for
pull_request
, pull_request.update
and pull_request.target
events.
# Parameters
# pattern
- type:
String
- required:
false
Specify the location of the coverage report file using the glob format, relative to the current working directory. When not specified, it will attempt to find the following files in the current directory (including subdirectories): coverage.json, jacoco*.xml, lcov.info, *.lcov.
# lines
- type:
Number
- required:
false
Specify the threshold for full coverage and check if the overall coverage percentage is below that value to block the workflow and exit the pipeline.
# diffLines
- type:
Number
- required:
false
Specify the threshold for incremental coverage, check if the overall coverage percentage is below that value, and halt the workflow to exit the pipeline.
The pull_request
, pull_request.update
and pull_request.target
events support calculating incremental coverage results, while other events only calculate overall coverage.
# allowExts
- type:
String
- required:
false
The whitelist of code file types involved in coverage calculation should be comma-separated, for example: .json,.ts,.js
.
By default, all files included in the report will be considered for coverage calculation if no whitelist of code file types is specified.
# lang
- type:
String
- required:
false
When the coverage result report target format is set to golang
, please specify the parameter as go
to avoid calculation errors. For other cases, you can ignore this parameter.
# breakIfNoCoverage
- type:
Boolean
- required:
false
Should an error be thrown and the process terminated when the coverage report file is not found?
# Output Results
{
// Code line coverage, e.g., 100. If calculation fails, the value is NA.
lines,
// Incremental code line coverage, e.g., 100. If calculation fails, the value is NA.
diff_pct,
}
# Configuration Example
#.cnb.yml
main:
push:
- stages:
- name: Coverage
type: testing:coverage
options:
breakIfNoCoverage: false
exports:
lines: LINES
- name: Result
script: echo $LINES
← release remove-tag →