2017-09-10 17:25:29 +05:30
|
|
|
# Pipelines settings
|
2017-08-17 22:00:37 +05:30
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
To reach the pipelines settings navigate to your project's
|
2018-03-17 18:26:18 +05:30
|
|
|
**Settings ➔ CI/CD**.
|
2017-08-17 22:00:37 +05:30
|
|
|
|
|
|
|
The following settings can be configured per project.
|
|
|
|
|
|
|
|
## Git strategy
|
|
|
|
|
|
|
|
With Git strategy, you can choose the default way your repository is fetched
|
|
|
|
from GitLab in a job.
|
|
|
|
|
|
|
|
There are two options:
|
|
|
|
|
|
|
|
- Using `git clone` which is slower since it clones the repository from scratch
|
|
|
|
for every job, ensuring that the project workspace is always pristine.
|
|
|
|
- Using `git fetch` which is faster as it re-uses the project workspace (falling
|
|
|
|
back to clone if it doesn't exist).
|
|
|
|
|
|
|
|
The default Git strategy can be overridden by the [GIT_STRATEGY variable][var]
|
|
|
|
in `.gitlab-ci.yml`.
|
|
|
|
|
|
|
|
## Timeout
|
|
|
|
|
|
|
|
Timeout defines the maximum amount of time in minutes that a job is able run.
|
|
|
|
The default value is 60 minutes. Decrease the time limit if you want to impose
|
|
|
|
a hard limit on your jobs' running time or increase it otherwise. In any case,
|
|
|
|
if the job surpasses the threshold, it is marked as failed.
|
|
|
|
|
2018-05-09 12:01:36 +05:30
|
|
|
### Timeout overriding on Runner level
|
|
|
|
|
|
|
|
> - [Introduced][ce-17221] in GitLab 10.7.
|
|
|
|
|
|
|
|
Project defined timeout (either specific timeout set by user or the default
|
|
|
|
60 minutes timeout) may be [overridden on Runner level][timeout overriding].
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
## Custom CI config path
|
|
|
|
|
|
|
|
> - [Introduced][ce-12509] in GitLab 9.4.
|
|
|
|
|
|
|
|
By default we look for the `.gitlab-ci.yml` file in the project's root
|
|
|
|
directory. If you require a different location **within** the repository,
|
|
|
|
you can set a custom filepath that will be used to lookup the config file,
|
|
|
|
this filepath should be **relative** to the root.
|
|
|
|
|
|
|
|
Here are some valid examples:
|
|
|
|
|
|
|
|
> * .gitlab-ci.yml
|
|
|
|
> * .my-custom-file.yml
|
|
|
|
> * my/path/.gitlab-ci.yml
|
|
|
|
> * my/path/.my-custom-file.yml
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
## Test coverage parsing
|
|
|
|
|
|
|
|
If you use test coverage in your code, GitLab can capture its output in the
|
|
|
|
job log using a regular expression. In the pipelines settings, search for the
|
|
|
|
"Test coverage parsing" section.
|
|
|
|
|
|
|
|
![Pipelines settings test coverage](img/pipelines_settings_test_coverage.png)
|
|
|
|
|
|
|
|
Leave blank if you want to disable it or enter a ruby regular expression. You
|
|
|
|
can use http://rubular.com to test your regex.
|
|
|
|
|
|
|
|
If the pipeline succeeds, the coverage is shown in the merge request widget and
|
|
|
|
in the jobs table.
|
|
|
|
|
|
|
|
![MR widget coverage](img/pipelines_test_coverage_mr_widget.png)
|
|
|
|
|
|
|
|
![Build status coverage](img/pipelines_test_coverage_build.png)
|
|
|
|
|
|
|
|
A few examples of known coverage tools for a variety of languages can be found
|
|
|
|
in the pipelines settings page.
|
|
|
|
|
|
|
|
## Visibility of pipelines
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
Access to pipelines and job details (including output of logs and artifacts)
|
|
|
|
is checked against your current user access level and the **Public pipelines**
|
|
|
|
project setting under your project's **Settings > CI/CD > General pipelines settings**.
|
|
|
|
|
|
|
|
If **Public pipelines** is enabled (default):
|
|
|
|
|
|
|
|
- for **public** projects, anyone can view the pipelines and access the job details
|
|
|
|
(output logs and artifacts)
|
|
|
|
- for **internal** projects, any logged in user can view the pipelines
|
|
|
|
and access the job details
|
|
|
|
(output logs and artifacts)
|
|
|
|
- for **private** projects, any member (guest or higher) can view the pipelines
|
|
|
|
and access the job details
|
|
|
|
(output logs and artifacts)
|
|
|
|
|
|
|
|
If **Public pipelines** is disabled:
|
|
|
|
|
|
|
|
- for **public** projects, anyone can view the pipelines, but only members
|
|
|
|
(reporter or higher) can access the job details (output logs and artifacts)
|
|
|
|
- for **internal** projects, any logged in user can view the pipelines,
|
|
|
|
but only members (reporter or higher) can access the job details (output logs
|
|
|
|
and artifacts)
|
|
|
|
- for **private** projects, only members (reporter or higher)
|
|
|
|
can view the pipelines and access the job details (output logs and artifacts)
|
2017-08-17 22:00:37 +05:30
|
|
|
|
|
|
|
## Auto-cancel pending pipelines
|
|
|
|
|
|
|
|
> [Introduced][ce-9362] in GitLab 9.1.
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
If you want to auto-cancel all pending non-HEAD pipelines on branch, when
|
|
|
|
new pipeline will be created (after your git push or manually from UI),
|
2017-08-17 22:00:37 +05:30
|
|
|
check **Auto-cancel pending pipelines** checkbox and save the changes.
|
|
|
|
|
2018-05-09 12:01:36 +05:30
|
|
|
## Pipeline Badges
|
2017-08-17 22:00:37 +05:30
|
|
|
|
|
|
|
In the pipelines settings page you can find pipeline status and test coverage
|
|
|
|
badges for your project. The latest successful pipeline will be used to read
|
|
|
|
the pipeline status and test coverage values.
|
|
|
|
|
|
|
|
Visit the pipelines settings page in your project to see the exact link to
|
|
|
|
your badges, as well as ways to embed the badge image in your HTML or Markdown
|
|
|
|
pages.
|
|
|
|
|
|
|
|
![Pipelines badges](img/pipelines_settings_badges.png)
|
|
|
|
|
|
|
|
### Pipeline status badge
|
|
|
|
|
|
|
|
Depending on the status of your job, a badge can have the following values:
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
- pending
|
2017-08-17 22:00:37 +05:30
|
|
|
- running
|
2018-03-17 18:26:18 +05:30
|
|
|
- passed
|
2017-08-17 22:00:37 +05:30
|
|
|
- failed
|
|
|
|
- skipped
|
2018-03-17 18:26:18 +05:30
|
|
|
- canceled
|
2017-08-17 22:00:37 +05:30
|
|
|
- unknown
|
|
|
|
|
|
|
|
You can access a pipeline status badge image using the following link:
|
|
|
|
|
|
|
|
```
|
|
|
|
https://example.gitlab.com/<namespace>/<project>/badges/<branch>/build.svg
|
|
|
|
```
|
|
|
|
|
|
|
|
### Test coverage report badge
|
|
|
|
|
|
|
|
GitLab makes it possible to define the regular expression for [coverage report],
|
|
|
|
that each job log will be matched against. This means that each job in the
|
|
|
|
pipeline can have the test coverage percentage value defined.
|
|
|
|
|
|
|
|
The test coverage badge can be accessed using following link:
|
|
|
|
|
|
|
|
```
|
|
|
|
https://example.gitlab.com/<namespace>/<project>/badges/<branch>/coverage.svg
|
|
|
|
```
|
|
|
|
|
|
|
|
If you would like to get the coverage report from a specific job, you can add
|
|
|
|
the `job=coverage_job_name` parameter to the URL. For example, the following
|
|
|
|
Markdown code will embed the test coverage report badge of the `coverage` job
|
|
|
|
into your `README.md`:
|
|
|
|
|
|
|
|
```markdown
|
|
|
|
![coverage](https://gitlab.com/gitlab-org/gitlab-ce/badges/master/coverage.svg?job=coverage)
|
|
|
|
```
|
|
|
|
|
2018-11-20 20:47:30 +05:30
|
|
|
### Environment Variables
|
|
|
|
|
|
|
|
[Environment variables](../../../ci/variables/README.html#variables) can be set in an environment to be available to a runner.
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
[var]: ../../../ci/yaml/README.md#git-strategy
|
|
|
|
[coverage report]: #test-coverage-parsing
|
2018-05-09 12:01:36 +05:30
|
|
|
[timeout overriding]: ../../../ci/runners/README.html#setting-maximum-job-timeout-for-a-runner
|
2017-08-17 22:00:37 +05:30
|
|
|
[ce-9362]: https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/9362
|
2017-09-10 17:25:29 +05:30
|
|
|
[ce-12509]: https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/12509
|
2018-05-09 12:01:36 +05:30
|
|
|
[ce-17221]: https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/17221
|