2019-09-04 21:01:54 +05:30
|
|
|
---
|
|
|
|
type: reference, howto
|
|
|
|
---
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
# Code Quality **[STARTER]**
|
|
|
|
|
|
|
|
> [Introduced](https://gitlab.com/gitlab-org/gitlab-ee/merge_requests/1984)
|
|
|
|
in [GitLab Starter](https://about.gitlab.com/pricing/) 9.3.
|
|
|
|
|
2019-09-04 21:01:54 +05:30
|
|
|
With the help of [GitLab CI/CD](../../../ci/README.md), you can analyze your
|
2019-07-31 22:56:46 +05:30
|
|
|
source code quality using GitLab Code Quality.
|
|
|
|
Code Quality uses [Code Climate Engines](https://codeclimate.com), which are
|
2019-09-04 21:01:54 +05:30
|
|
|
free and open source. Code Quality doesn't require a Code Climate subscription.
|
2019-07-31 22:56:46 +05:30
|
|
|
|
|
|
|
Going a step further, GitLab can show the Code Quality report right
|
|
|
|
in the merge request widget area:
|
|
|
|
|
|
|
|
![Code Quality Widget](img/code_quality.gif)
|
|
|
|
|
|
|
|
## Use cases
|
|
|
|
|
|
|
|
For instance, consider the following workflow:
|
|
|
|
|
2019-09-04 21:01:54 +05:30
|
|
|
1. Your backend team member starts a new implementation for making a certain feature in your app faster
|
2019-07-31 22:56:46 +05:30
|
|
|
1. With Code Quality reports, they analyze how their implementation is impacting the code quality
|
|
|
|
1. The metrics show that their code degrade the quality in 10 points
|
|
|
|
1. You ask a co-worker to help them with this modification
|
|
|
|
1. They both work on the changes until Code Quality report displays no degradations, only improvements
|
|
|
|
1. You approve the merge request and authorize its deployment to staging
|
|
|
|
1. Once verified, their changes are deployed to production
|
|
|
|
|
|
|
|
## How it works
|
|
|
|
|
|
|
|
First of all, you need to define a job in your `.gitlab-ci.yml` file that generates the
|
|
|
|
[Code Quality report artifact](../../../ci/yaml/README.md#artifactsreportscodequality-starter).
|
|
|
|
|
|
|
|
The Code Quality report artifact is a subset of the
|
|
|
|
[Code Climate spec](https://github.com/codeclimate/spec/blob/master/SPEC.md#data-types).
|
|
|
|
It must be a JSON file containing an array of objects with the following properties:
|
|
|
|
|
|
|
|
| Name | Description |
|
|
|
|
| ---------------------- | -------------------------------------------------------------------------------------- |
|
|
|
|
| `description` | A description of the code quality violation. |
|
|
|
|
| `fingerprint` | A unique fingerprint to identify the code quality violation. For example, an MD5 hash. |
|
|
|
|
| `location.path` | The relative path to the file containing the code quality violation. |
|
|
|
|
| `location.lines.begin` | The line on which the code quality violation occurred. |
|
|
|
|
|
|
|
|
Example:
|
|
|
|
|
|
|
|
```json
|
|
|
|
[
|
|
|
|
{
|
|
|
|
"description": "'unused' is assigned a value but never used.",
|
|
|
|
"fingerprint": "7815696ecbf1c96e6894b779456d330e",
|
|
|
|
"location": {
|
|
|
|
"path": "lib/index.js",
|
|
|
|
"lines": {
|
|
|
|
"begin": 42
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
|
|
|
```
|
|
|
|
|
|
|
|
NOTE: **Note:**
|
|
|
|
Although the Code Climate spec supports more properties, those are ignored by GitLab.
|
|
|
|
|
2019-09-04 21:01:54 +05:30
|
|
|
For more information on what the Code Quality job should look like, check the
|
2019-07-31 22:56:46 +05:30
|
|
|
example on [analyzing a project's code quality](../../../ci/examples/code_quality.md).
|
|
|
|
|
|
|
|
GitLab then checks this report, compares the metrics between the source and target
|
|
|
|
branches, and shows the information right on the merge request.
|
|
|
|
|
|
|
|
If multiple jobs in a pipeline generate a code quality artifact, only the artifact from
|
|
|
|
the last created job (the job with the largest job ID) is used. To avoid confusion,
|
|
|
|
configure only one job to generate a code quality artifact.
|
|
|
|
|
|
|
|
If the Code Quality report doesn't have anything to compare to, no information
|
|
|
|
will be displayed in the merge request area. That is the case when you add the
|
|
|
|
Code Quality job in your `.gitlab-ci.yml` for the very first time.
|
|
|
|
Consecutive merge requests will have something to compare to and the Code Quality
|
|
|
|
report will be shown properly.
|
2019-09-04 21:01:54 +05:30
|
|
|
|
|
|
|
<!-- ## Troubleshooting
|
|
|
|
|
|
|
|
Include any troubleshooting steps that you can foresee. If you know beforehand what issues
|
|
|
|
one might have when setting this up, or when something is changed, or on upgrading, it's
|
|
|
|
important to describe those, too. Think of things that may go wrong and include them here.
|
|
|
|
This is important to minimize requests for support, and to avoid doc comments with
|
|
|
|
questions that you know someone might ask.
|
|
|
|
|
|
|
|
Each scenario can be a third-level heading, e.g. `### Getting error message X`.
|
|
|
|
If you have none to add when creating a doc, leave this section in place
|
|
|
|
but commented out to help encourage others to add to it in the future. -->
|