166 lines
8.3 KiB
Markdown
166 lines
8.3 KiB
Markdown
|
---
|
||
|
stage: Verify
|
||
|
group: Pipeline Insights
|
||
|
info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/engineering/ux/technical-writing/#assignments
|
||
|
---
|
||
|
|
||
|
# Unit test reports **(FREE)**
|
||
|
|
||
|
> - [Introduced](https://gitlab.com/gitlab-org/gitlab-foss/-/issues/45318) in GitLab 11.2. Requires GitLab Runner 11.2 and above.
|
||
|
> - [Renamed](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/39737) from JUnit test reports to Unit test reports in GitLab 13.4.
|
||
|
|
||
|
It is very common that a [CI/CD pipeline](../pipelines/index.md) contains a
|
||
|
test job that verifies your code.
|
||
|
If the tests fail, the pipeline fails and users get notified. The person that
|
||
|
works on the merge request has to check the job logs and see where the
|
||
|
tests failed so that they can fix them.
|
||
|
|
||
|
You can configure your job to use Unit test reports, and GitLab displays a
|
||
|
report on the merge request so that it's easier and faster to identify the
|
||
|
failure without having to check the entire log. Unit test reports currently
|
||
|
only support test reports in the JUnit report format.
|
||
|
|
||
|
If you don't use merge requests but still want to see the unit test report
|
||
|
output without searching through job logs, the full
|
||
|
[Unit test reports](#view-unit-test-reports-on-gitlab) are available
|
||
|
in the pipeline detail view.
|
||
|
|
||
|
Consider the following workflow:
|
||
|
|
||
|
1. Your default branch is rock solid, your project is using GitLab CI/CD and
|
||
|
your pipelines indicate that there isn't anything broken.
|
||
|
1. Someone from your team submits a merge request, a test fails and the pipeline
|
||
|
gets the known red icon. To investigate more, you have to go through the job
|
||
|
logs to figure out the cause of the failed test, which usually contain
|
||
|
thousands of lines.
|
||
|
1. You configure the Unit test reports and immediately GitLab collects and
|
||
|
exposes them in the merge request. No more searching in the job logs.
|
||
|
1. Your development and debugging workflow becomes easier, faster and efficient.
|
||
|
|
||
|
## How it works
|
||
|
|
||
|
First, GitLab Runner uploads all [JUnit report format XML files](https://www.ibm.com/docs/en/adfz/developer-for-zos/14.1.0?topic=formats-junit-xml-format)
|
||
|
as [artifacts](../yaml/artifacts_reports.md#artifactsreportsjunit) to GitLab. Then, when you visit a merge request, GitLab starts
|
||
|
comparing the head and base branch's JUnit report format XML files, where:
|
||
|
|
||
|
- The base branch is the target branch (usually the default branch).
|
||
|
- The head branch is the source branch (the latest pipeline in each merge request).
|
||
|
|
||
|
The reports panel has a summary showing how many tests failed, how many had errors
|
||
|
and how many were fixed. If no comparison can be done because data for the base branch
|
||
|
is not available, the panel just shows the list of failed tests for head.
|
||
|
|
||
|
There are four types of results:
|
||
|
|
||
|
1. **Newly failed tests:** Test cases which passed on base branch and failed on head branch
|
||
|
1. **Newly encountered errors:** Test cases which passed on base branch and failed due to a
|
||
|
test error on head branch
|
||
|
1. **Existing failures:** Test cases which failed on base branch and failed on head branch
|
||
|
1. **Resolved failures:** Test cases which failed on base branch and passed on head branch
|
||
|
|
||
|
Each entry in the panel shows the test name and its type from the list
|
||
|
above. Clicking on the test name opens a modal window with details of its
|
||
|
execution time and the error output.
|
||
|
|
||
|
![Test Reports Widget](img/junit_test_report.png)
|
||
|
|
||
|
### Number of recent failures
|
||
|
|
||
|
> - [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/241759) in merge requests in GitLab 13.7.
|
||
|
> - [Feature flag removed](https://gitlab.com/gitlab-org/gitlab/-/issues/268249) in GitLab 13.8.
|
||
|
> - [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/235525) in Test Reports in GitLab 13.9.
|
||
|
|
||
|
If a test failed in the project's default branch in the last 14 days, a message like
|
||
|
`Failed {n} time(s) in {default_branch} in the last 14 days` is displayed for that test.
|
||
|
|
||
|
## How to set it up
|
||
|
|
||
|
To enable the Unit test reports in merge requests, you must add
|
||
|
[`artifacts:reports:junit`](../yaml/artifacts_reports.md#artifactsreportsjunit)
|
||
|
in `.gitlab-ci.yml`, and specify the paths of the generated test reports.
|
||
|
The reports must be `.xml` files, otherwise [GitLab returns an Error 500](https://gitlab.com/gitlab-org/gitlab/-/issues/216575).
|
||
|
|
||
|
In the following example for Ruby, the job in the `test` stage runs and GitLab
|
||
|
collects the unit test report from the job. After the job is executed, the
|
||
|
XML report is stored in GitLab as an artifact, and the results are shown in the
|
||
|
merge request widget.
|
||
|
|
||
|
```yaml
|
||
|
## Use https://github.com/sj26/rspec_junit_formatter to generate a JUnit report format XML file with rspec
|
||
|
ruby:
|
||
|
stage: test
|
||
|
script:
|
||
|
- bundle install
|
||
|
- bundle exec rspec --format progress --format RspecJunitFormatter --out rspec.xml
|
||
|
artifacts:
|
||
|
when: always
|
||
|
paths:
|
||
|
- rspec.xml
|
||
|
reports:
|
||
|
junit: rspec.xml
|
||
|
```
|
||
|
|
||
|
To make the Unit test report output files browsable, include them with the
|
||
|
[`artifacts:paths`](../yaml/index.md#artifactspaths) keyword as well, as shown in the example.
|
||
|
To upload the report even if the job fails (for example if the tests do not pass),
|
||
|
use the [`artifacts:when:always`](../yaml/index.md#artifactswhen) keyword.
|
||
|
|
||
|
You cannot have multiple tests with the same name and class in your JUnit report format XML file.
|
||
|
|
||
|
In GitLab 15.0 and earlier, test reports from [parallel:matrix](../yaml/index.md#parallel:matrix)
|
||
|
jobs are aggregated together, which can cause some report information to not be displayed.
|
||
|
In GitLab 15.1 and later, [this bug is fixed](https://gitlab.com/gitlab-org/gitlab/-/issues/296814),
|
||
|
and all report information is displayed.
|
||
|
|
||
|
## View Unit test reports on GitLab
|
||
|
|
||
|
> - [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/24792) in GitLab 12.5 behind a feature flag (`junit_pipeline_view`), disabled by default.
|
||
|
> - [Feature flag removed](https://gitlab.com/gitlab-org/gitlab/-/issues/216478) in GitLab 13.3.
|
||
|
|
||
|
If JUnit report format XML files are generated and uploaded as part of a pipeline, these reports
|
||
|
can be viewed inside the pipelines details page. The **Tests** tab on this page
|
||
|
displays a list of test suites and cases reported from the XML file.
|
||
|
|
||
|
![Test Reports Widget](img/pipelines_junit_test_report_v13_10.png)
|
||
|
|
||
|
You can view all the known test suites and select each of these to see further
|
||
|
details, including the cases that make up the suite.
|
||
|
|
||
|
You can also retrieve the reports via the [GitLab API](../../api/pipelines.md#get-a-pipelines-test-report).
|
||
|
|
||
|
### Unit test reports parsing errors
|
||
|
|
||
|
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/263457) in GitLab 13.10.
|
||
|
|
||
|
If parsing JUnit report XML results in an error, an indicator is shown next to the job name. Hovering over the icon shows the parser error in a tooltip. If multiple parsing errors come from [grouped jobs](../jobs/index.md#group-jobs-in-a-pipeline), GitLab shows only the first error from the group.
|
||
|
|
||
|
![Test Reports With Errors](img/pipelines_junit_test_report_with_errors_v13_10.png)
|
||
|
|
||
|
For test case parsing limits, see [Max test cases per unit test report](../../user/gitlab_com/#gitlab-cicd).
|
||
|
|
||
|
GitLab does not parse very [large nodes](https://nokogiri.org/tutorials/parsing_an_html_xml_document.html#parse-options) of JUnit reports. There is [an issue](https://gitlab.com/gitlab-org/gitlab/-/issues/268035) open to make this optional.
|
||
|
|
||
|
## View JUnit screenshots on GitLab
|
||
|
|
||
|
> - [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/202114) in GitLab 13.0 behind the `:junit_pipeline_screenshots_view` feature flag, disabled by default.
|
||
|
> - [Feature flag removed](https://gitlab.com/gitlab-org/gitlab/-/issues/216979) in GitLab 13.12.
|
||
|
|
||
|
Upload your screenshots as [artifacts](../yaml/artifacts_reports.md#artifactsreportsjunit) to GitLab. If JUnit
|
||
|
report format XML files contain an `attachment` tag, GitLab parses the attachment. Note that:
|
||
|
|
||
|
- The `attachment` tag **must** contain the relative path to `$CI_PROJECT_DIR` of the screenshots you uploaded. For
|
||
|
example:
|
||
|
|
||
|
```xml
|
||
|
<testcase time="1.00" name="Test">
|
||
|
<system-out>[[ATTACHMENT|/path/to/some/file]]</system-out>
|
||
|
</testcase>
|
||
|
```
|
||
|
|
||
|
- You should set the job that uploads the screenshot to
|
||
|
[`artifacts:when: always`](../yaml/index.md#artifactswhen) so that it still uploads a screenshot
|
||
|
when a test fails.
|
||
|
|
||
|
A link to the test case attachment appears in the test case details in
|
||
|
[the pipeline test report](#view-unit-test-reports-on-gitlab).
|