Commit 3929020e authored by Suzanne Selhorn's avatar Suzanne Selhorn

Docs: Fix Vale issues

Related to: https://gitlab.com/gitlab-org/gitlab/-/issues/234029
parent 254c59ad
...@@ -34,8 +34,8 @@ We have complete examples of configuring pipelines: ...@@ -34,8 +34,8 @@ We have complete examples of configuring pipelines:
> from 30 days to under 8 hours with GitLab. > from 30 days to under 8 hours with GitLab.
NOTE: **Note:** NOTE: **Note:**
If you have a [mirrored repository where GitLab pulls from](../../user/project/repository/repository_mirroring.md#pulling-from-a-remote-repository-starter), If you have a [mirrored repository that GitLab pulls from](../../user/project/repository/repository_mirroring.md#pulling-from-a-remote-repository-starter),
you may need to enable pipeline triggering in your project's you may need to enable pipeline triggering. Go to your project's
**Settings > Repository > Pull from a remote repository > Trigger pipelines for mirror updates**. **Settings > Repository > Pull from a remote repository > Trigger pipelines for mirror updates**.
## Introduction ## Introduction
...@@ -63,8 +63,8 @@ jobs, where each of the jobs executes a different command. ...@@ -63,8 +63,8 @@ jobs, where each of the jobs executes a different command.
Of course a command can execute code directly (`./configure;make;make install`) Of course a command can execute code directly (`./configure;make;make install`)
or run a script (`test.sh`) in the repository. or run a script (`test.sh`) in the repository.
Jobs are picked up by [Runners](../runners/README.md) and executed within the Jobs are picked up by [runners](../runners/README.md) and executed within the
environment of the Runner. What is important, is that each job is run environment of the runner. What is important is that each job is run
independently from each other. independently from each other.
### Validate the `.gitlab-ci.yml` ### Validate the `.gitlab-ci.yml`
...@@ -103,7 +103,7 @@ The following table lists available parameters for jobs: ...@@ -103,7 +103,7 @@ The following table lists available parameters for jobs:
| Keyword | Description | | Keyword | Description |
|:---------------------------------------------------|:------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| |:---------------------------------------------------|:------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [`script`](#script) | Shell script which is executed by Runner. | | [`script`](#script) | Shell script that is executed by a runner. |
| [`after_script`](#before_script-and-after_script) | Override a set of commands that are executed after job. | | [`after_script`](#before_script-and-after_script) | Override a set of commands that are executed after job. |
| [`allow_failure`](#allow_failure) | Allow job to fail. Failed job does not contribute to commit status. | | [`allow_failure`](#allow_failure) | Allow job to fail. Failed job does not contribute to commit status. |
| [`artifacts`](#artifacts) | List of files and directories to attach to a job on success. Also available: `artifacts:paths`, `artifacts:exclude`, `artifacts:expose_as`, `artifacts:name`, `artifacts:untracked`, `artifacts:when`, `artifacts:expire_in`, `artifacts:reports`. | | [`artifacts`](#artifacts) | List of files and directories to attach to a job on success. Also available: `artifacts:paths`, `artifacts:exclude`, `artifacts:expose_as`, `artifacts:name`, `artifacts:untracked`, `artifacts:when`, `artifacts:expire_in`, `artifacts:reports`. |
...@@ -113,20 +113,20 @@ The following table lists available parameters for jobs: ...@@ -113,20 +113,20 @@ The following table lists available parameters for jobs:
| [`dependencies`](#dependencies) | Restrict which artifacts are passed to a specific job by providing a list of jobs to fetch artifacts from. | | [`dependencies`](#dependencies) | Restrict which artifacts are passed to a specific job by providing a list of jobs to fetch artifacts from. |
| [`environment`](#environment) | Name of an environment to which the job deploys. Also available: `environment:name`, `environment:url`, `environment:on_stop`, `environment:auto_stop_in` and `environment:action`. | | [`environment`](#environment) | Name of an environment to which the job deploys. Also available: `environment:name`, `environment:url`, `environment:on_stop`, `environment:auto_stop_in` and `environment:action`. |
| [`except`](#onlyexcept-basic) | Limit when jobs are not created. Also available: [`except:refs`, `except:kubernetes`, `except:variables`, and `except:changes`](#onlyexcept-advanced). | | [`except`](#onlyexcept-basic) | Limit when jobs are not created. Also available: [`except:refs`, `except:kubernetes`, `except:variables`, and `except:changes`](#onlyexcept-advanced). |
| [`extends`](#extends) | Configuration entries that this job is going to inherit from. | | [`extends`](#extends) | Configuration entries that this job inherits from. |
| [`image`](#image) | Use Docker images. Also available: `image:name` and `image:entrypoint`. | | [`image`](#image) | Use Docker images. Also available: `image:name` and `image:entrypoint`. |
| [`include`](#include) | Allows this job to include external YAML files. Also available: `include:local`, `include:file`, `include:template`, and `include:remote`. | | [`include`](#include) | Allows this job to include external YAML files. Also available: `include:local`, `include:file`, `include:template`, and `include:remote`. |
| [`interruptible`](#interruptible) | Defines if a job can be canceled when made redundant by a newer run. | | [`interruptible`](#interruptible) | Defines if a job can be canceled when made redundant by a newer run. |
| [`only`](#onlyexcept-basic) | Limit when jobs are created. Also available: [`only:refs`, `only:kubernetes`, `only:variables`, and `only:changes`](#onlyexcept-advanced). | | [`only`](#onlyexcept-basic) | Limit when jobs are created. Also available: [`only:refs`, `only:kubernetes`, `only:variables`, and `only:changes`](#onlyexcept-advanced). |
| [`pages`](#pages) | Upload the result of a job to use with GitLab Pages. | | [`pages`](#pages) | Upload the result of a job to use with GitLab Pages. |
| [`parallel`](#parallel) | How many instances of a job should be run in parallel. | | [`parallel`](#parallel) | How many instances of a job should be run in parallel. |
| [`release`](#release) | Instructs the Runner to generate a [Release](../../user/project/releases/index.md) object. | | [`release`](#release) | Instructs the runner to generate a [Release](../../user/project/releases/index.md) object. |
| [`resource_group`](#resource_group) | Limit job concurrency. | | [`resource_group`](#resource_group) | Limit job concurrency. |
| [`retry`](#retry) | When and how many times a job can be auto-retried in case of a failure. | | [`retry`](#retry) | When and how many times a job can be auto-retried in case of a failure. |
| [`rules`](#rules) | List of conditions to evaluate and determine selected attributes of a job, and whether or not it's created. May not be used alongside `only`/`except`. | | [`rules`](#rules) | List of conditions to evaluate and determine selected attributes of a job, and whether or not it's created. May not be used alongside `only`/`except`. |
| [`services`](#services) | Use Docker services images. Also available: `services:name`, `services:alias`, `services:entrypoint`, and `services:command`. | | [`services`](#services) | Use Docker services images. Also available: `services:name`, `services:alias`, `services:entrypoint`, and `services:command`. |
| [`stage`](#stage) | Defines a job stage (default: `test`). | | [`stage`](#stage) | Defines a job stage (default: `test`). |
| [`tags`](#tags) | List of tags which are used to select Runner. | | [`tags`](#tags) | List of tags which are used to select a runner. |
| [`timeout`](#timeout) | Define a custom job-level timeout that takes precedence over the project-wide setting. | | [`timeout`](#timeout) | Define a custom job-level timeout that takes precedence over the project-wide setting. |
| [`trigger`](#trigger) | Defines a downstream pipeline trigger. | | [`trigger`](#trigger) | Defines a downstream pipeline trigger. |
| [`variables`](#variables) | Define job variables on a job level. | | [`variables`](#variables) | Define job variables on a job level. |
...@@ -290,14 +290,14 @@ There are also two edge cases worth mentioning: ...@@ -290,14 +290,14 @@ There are also two edge cases worth mentioning:
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/29654) in GitLab 12.5 > [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/29654) in GitLab 12.5
The top-level `workflow:` key applies to the entirety of a pipeline, and will The top-level `workflow:` key applies to the entirety of a pipeline, and
determine whether or not a pipeline is created. It currently accepts a single determines whether or not a pipeline is created. It accepts a single
`rules:` key that operates similarly to [`rules:` defined within jobs](#rules), `rules:` key that operates similarly to [`rules:` defined within jobs](#rules),
enabling dynamic configuration of the pipeline. enabling dynamic configuration of the pipeline.
If you are new to GitLab CI/CD and `workflow: rules`, you may find the [`workflow:rules` templates](#workflowrules-templates) useful. If you are new to GitLab CI/CD and `workflow: rules`, you may find the [`workflow:rules` templates](#workflowrules-templates) useful.
To define your own `workflow: rules`, the configuration options currently available are: To define your own `workflow: rules`, the available configuration options are:
- [`if`](#rulesif): Define a rule. - [`if`](#rulesif): Define a rule.
- [`when`](#when): May be set to `always` or `never` only. If not provided, the default value is `always`​. - [`when`](#when): May be set to `always` or `never` only. If not provided, the default value is `always`​.
...@@ -315,8 +315,8 @@ the [common `if` clauses for `rules`](#common-if-clauses-for-rules) for more exa ...@@ -315,8 +315,8 @@ the [common `if` clauses for `rules`](#common-if-clauses-for-rules) for more exa
| `if: $CI_COMMIT_TAG` | Control when tag pipelines run. | | `if: $CI_COMMIT_TAG` | Control when tag pipelines run. |
| `if: $CI_COMMIT_BRANCH` | Control when branch pipelines run. | | `if: $CI_COMMIT_BRANCH` | Control when branch pipelines run. |
For example, with the following configuration, pipelines run for all `push` events (changes to For example, in the following configuration, pipelines run for all `push` events (changes to
branches and new tags) as long as they *don't* have `-wip` in the commit message. Scheduled branches and new tags). Only push events with `-wip` in the commit message are excluded. Scheduled
pipelines and merge request pipelines don't run, as there's no rule allowing them. pipelines and merge request pipelines don't run, as there's no rule allowing them.
```yaml ```yaml
...@@ -399,7 +399,7 @@ It's also possible to have template files stored in a central repository and pro ...@@ -399,7 +399,7 @@ It's also possible to have template files stored in a central repository and pro
configuration files. This helps avoid duplicated configuration, for example, global default variables for all projects. configuration files. This helps avoid duplicated configuration, for example, global default variables for all projects.
`include` requires the external YAML file to have the extensions `.yml` or `.yaml`, `include` requires the external YAML file to have the extensions `.yml` or `.yaml`,
otherwise the external file won't be included. otherwise the external file is not included.
`include` supports the following inclusion methods: `include` supports the following inclusion methods:
...@@ -415,7 +415,7 @@ The `include` methods do not support [variable expansion](../variables/where_var ...@@ -415,7 +415,7 @@ The `include` methods do not support [variable expansion](../variables/where_var
NOTE: **Note:** NOTE: **Note:**
`.gitlab-ci.yml` configuration included by all methods is evaluated at pipeline creation. `.gitlab-ci.yml` configuration included by all methods is evaluated at pipeline creation.
The configuration is a snapshot in time and persisted in the database. Any changes to The configuration is a snapshot in time and persisted in the database. Any changes to
referenced `.gitlab-ci.yml` configuration won't be reflected in GitLab until the next pipeline is created. referenced `.gitlab-ci.yml` configuration is not reflected in GitLab until the next pipeline is created.
The files defined by `include` are: The files defined by `include` are:
...@@ -425,7 +425,7 @@ The files defined by `include` are: ...@@ -425,7 +425,7 @@ The files defined by `include` are:
TIP: **Tip:** TIP: **Tip:**
Use merging to customize and override included CI/CD configurations with local Use merging to customize and override included CI/CD configurations with local
definitions. Local definitions in `.gitlab-ci.yml` will override included definitions. definitions. Local definitions in `.gitlab-ci.yml` override included definitions.
NOTE: **Note:** NOTE: **Note:**
Using [YAML anchors](#anchors) across different YAML files sourced by `include` is not Using [YAML anchors](#anchors) across different YAML files sourced by `include` is not
...@@ -437,11 +437,11 @@ of using YAML anchors, you can use the [`extends` keyword](#extends). ...@@ -437,11 +437,11 @@ of using YAML anchors, you can use the [`extends` keyword](#extends).
`include:local` includes a file from the same repository as `.gitlab-ci.yml`. `include:local` includes a file from the same repository as `.gitlab-ci.yml`.
It's referenced using full paths relative to the root directory (`/`). It's referenced using full paths relative to the root directory (`/`).
You can only use files that are currently tracked by Git on the same branch You can only use files that are tracked by Git on the same branch
your configuration file is on. In other words, when using a `include:local`, make your configuration file is on. In other words, when using a `include:local`, make
sure that both `.gitlab-ci.yml` and the local file are on the same branch. sure that both `.gitlab-ci.yml` and the local file are on the same branch.
All [nested includes](#nested-includes) will be executed in the scope of the same project, All [nested includes](#nested-includes) are executed in the scope of the same project,
so it's possible to use local, project, remote, or template includes. so it's possible to use local, project, remote, or template includes.
NOTE: **Note:** NOTE: **Note:**
...@@ -494,7 +494,7 @@ include: ...@@ -494,7 +494,7 @@ include:
file: '/templates/.gitlab-ci-template.yml' file: '/templates/.gitlab-ci-template.yml'
``` ```
All [nested includes](#nested-includes) will be executed in the scope of the target project, All [nested includes](#nested-includes) are executed in the scope of the target project,
so it's possible to use local (relative to target project), project, remote so it's possible to use local (relative to target project), project, remote
or template includes. or template includes.
...@@ -510,7 +510,7 @@ include: ...@@ -510,7 +510,7 @@ include:
- remote: 'https://gitlab.com/awesome-project/raw/master/.gitlab-ci-template.yml' - remote: 'https://gitlab.com/awesome-project/raw/master/.gitlab-ci-template.yml'
``` ```
All [nested includes](#nested-includes) will be executed without context as public user, so only another remote All [nested includes](#nested-includes) are executed without context as public user, so only another remote
or public project, or template, is allowed. or public project, or template, is allowed.
#### `include:template` #### `include:template`
...@@ -536,7 +536,7 @@ include: ...@@ -536,7 +536,7 @@ include:
- template: Auto-DevOps.gitlab-ci.yml - template: Auto-DevOps.gitlab-ci.yml
``` ```
All [nested includes](#nested-includes) will be executed only with the permission of the user, All [nested includes](#nested-includes) are executed only with the permission of the user,
so it's possible to use project, remote or template includes. so it's possible to use project, remote or template includes.
#### Nested includes #### Nested includes
...@@ -616,7 +616,7 @@ For more information, see [Available settings for `services`](../docker/using_do ...@@ -616,7 +616,7 @@ For more information, see [Available settings for `services`](../docker/using_do
### `script` ### `script`
`script` is the only required keyword that a job needs. It's a shell script `script` is the only required keyword that a job needs. It's a shell script
which is executed by the Runner. For example: which is executed by the runner. For example:
```yaml ```yaml
job: job:
...@@ -635,14 +635,14 @@ job: ...@@ -635,14 +635,14 @@ job:
``` ```
NOTE: **Note:** NOTE: **Note:**
Sometimes, `script` commands will need to be wrapped in single or double quotes. Sometimes, `script` commands must be wrapped in single or double quotes.
For example, commands that contain a colon (`:`) need to be wrapped in quotes so For example, commands that contain a colon (`:`) must be wrapped in quotes so
that the YAML parser knows to interpret the whole thing as a string rather than that the YAML parser knows to interpret the whole thing as a string rather than
a "key: value" pair. Be careful when using special characters: a "key: value" pair. Be careful when using special characters:
`:`, `{`, `}`, `[`, `]`, `,`, `&`, `*`, `#`, `?`, `|`, `-`, `<`, `>`, `=`, `!`, `%`, `@`, `` ` ``. `:`, `{`, `}`, `[`, `]`, `,`, `&`, `*`, `#`, `?`, `|`, `-`, `<`, `>`, `=`, `!`, `%`, `@`, `` ` ``.
If any of the script commands return an exit code different from zero, the job If any of the script commands return an exit code other than zero, the job
will fail and further commands won't be executed. This behavior can be avoided by fails and further commands are not executed. You can avoid this behavior by
storing the exit code in a variable: storing the exit code in a variable:
```yaml ```yaml
...@@ -663,7 +663,7 @@ This must be an array. ...@@ -663,7 +663,7 @@ This must be an array.
Scripts specified in `before_script` are concatenated with any scripts specified Scripts specified in `before_script` are concatenated with any scripts specified
in the main [`script`](#script), and executed together in a single shell. in the main [`script`](#script), and executed together in a single shell.
`after_script` is used to define the command that will be run after each `after_script` is used to define the command that runs after each
job, including failed ones. This must be an array. job, including failed ones. This must be an array.
Scripts specified in `after_script` are executed in a new shell, separate from any Scripts specified in `after_script` are executed in a new shell, separate from any
...@@ -672,12 +672,12 @@ Scripts specified in `after_script` are executed in a new shell, separate from a ...@@ -672,12 +672,12 @@ Scripts specified in `after_script` are executed in a new shell, separate from a
- Have a current working directory set back to the default. - Have a current working directory set back to the default.
- Have no access to changes done by scripts defined in `before_script` or `script`, including: - Have no access to changes done by scripts defined in `before_script` or `script`, including:
- Command aliases and variables exported in `script` scripts. - Command aliases and variables exported in `script` scripts.
- Changes outside of the working tree (depending on the Runner executor), like - Changes outside of the working tree (depending on the runner executor), like
software installed by a `before_script` or `script` script. software installed by a `before_script` or `script` script.
- Have a separate timeout, which is hard coded to 5 minutes. See - Have a separate timeout, which is hard coded to 5 minutes. See
[related issue](https://gitlab.com/gitlab-org/gitlab-runner/-/issues/2716) for details. [related issue](https://gitlab.com/gitlab-org/gitlab-runner/-/issues/2716) for details.
- Don't affect the job's exit code. If the `script` section succeeds and the - Don't affect the job's exit code. If the `script` section succeeds and the
`after_script` times out or fails, the job will exit with code `0` (`Job Succeeded`). `after_script` times out or fails, the job exits with code `0` (`Job Succeeded`).
It's possible to overwrite a globally defined `before_script` or `after_script` It's possible to overwrite a globally defined `before_script` or `after_script`
if you set it per-job: if you set it per-job:
...@@ -736,14 +736,14 @@ job: ...@@ -736,14 +736,14 @@ job:
- Write-Host "This text is not colored" - Write-Host "This text is not colored"
``` ```
#### Multiline commands #### Multi-line commands
You can split long commands into multi-line commands to improve readability You can split long commands into multi-line commands to improve readability
using [`|` (literal) and `>` (folded) YAML multiline block scalar indicators](https://yaml-multiline.info/). using [`|` (literal) and `>` (folded) YAML multi-line block scalar indicators](https://yaml-multiline.info/).
CAUTION: **Warning:** CAUTION: **Warning:**
If multiple commands are combined into one command string, only the last command's If multiple commands are combined into one command string, only the last command's
failure or success will be reported, failure or success is reported,
[incorrectly ignoring failures from earlier commands due to a bug](https://gitlab.com/gitlab-org/gitlab-runner/-/issues/25394). [incorrectly ignoring failures from earlier commands due to a bug](https://gitlab.com/gitlab-org/gitlab-runner/-/issues/25394).
If the success of the job depends on the success or failure of these commands, If the success of the job depends on the success or failure of these commands,
you can run the commands as separate `script:` items, or add `exit 1` commands you can run the commands as separate `script:` items, or add `exit 1` commands
...@@ -806,7 +806,7 @@ First command line is split over two lines. ...@@ -806,7 +806,7 @@ First command line is split over two lines.
Second command line. Second command line.
``` ```
When the `>` or `|` block scalar indicators are omitted, GitLab will form the command When you omit the `>` or `|` block scalar indicators, GitLab forms the command
by concatenating non-empty lines, so make sure the lines can run when concatenated. by concatenating non-empty lines, so make sure the lines can run when concatenated.
Shell [here documents](https://en.wikipedia.org/wiki/Here_document) work with the Shell [here documents](https://en.wikipedia.org/wiki/Here_document) work with the
...@@ -872,16 +872,16 @@ job 5: ...@@ -872,16 +872,16 @@ job 5:
script: make something useful at the end of pipeline script: make something useful at the end of pipeline
``` ```
#### Using your own Runners #### Using your own runners
When using your own Runners, GitLab Runner runs only one job at a time by default (see the When you use your own runners, GitLab Runner runs only one job at a time by default. See the
`concurrent` flag in [Runner global settings](https://docs.gitlab.com/runner/configuration/advanced-configuration.html#the-global-section) `concurrent` flag in [runner global settings](https://docs.gitlab.com/runner/configuration/advanced-configuration.html#the-global-section)
for more information). for more information.
Jobs will run on your own Runners in parallel only if: Jobs run on your own runners in parallel only if:
- Run on different Runners. - Run on different runners.
- The Runner's `concurrent` setting has been changed. - The runner's `concurrent` setting has been changed.
#### `.pre` and `.post` #### `.pre` and `.post`
...@@ -2188,13 +2188,13 @@ Downloading artifacts from jobs that are run in [`parallel:`](#parallel) is not ...@@ -2188,13 +2188,13 @@ Downloading artifacts from jobs that are run in [`parallel:`](#parallel) is not
### `tags` ### `tags`
`tags` is used to select specific Runners from the list of all Runners that are `tags` is used to select specific runners from the list of all runners that are
allowed to run this project. allowed to run this project.
During the registration of a Runner, you can specify the Runner's tags, for During the registration of a runner, you can specify the runner's tags, for
example `ruby`, `postgres`, `development`. example `ruby`, `postgres`, `development`.
`tags` allow you to run jobs with Runners that have the specified tags `tags` allow you to run jobs with runners that have the specified tags
assigned to them: assigned to them:
```yaml ```yaml
...@@ -2204,11 +2204,11 @@ job: ...@@ -2204,11 +2204,11 @@ job:
- postgres - postgres
``` ```
The specification above, will make sure that `job` is built by a Runner that The specification above, will make sure that `job` is built by a runner that
has both `ruby` AND `postgres` tags defined. has both `ruby` AND `postgres` tags defined.
Tags are also a great way to run different jobs on different platforms, for Tags are also a great way to run different jobs on different platforms, for
example, given an OS X Runner with tag `osx` and Windows Runner with tag example, given an OS X runner with tag `osx` and Windows runner with tag
`windows`, the following jobs run on respective platforms: `windows`, the following jobs run on respective platforms:
```yaml ```yaml
...@@ -2450,8 +2450,8 @@ timed rollout 10%: ...@@ -2450,8 +2450,8 @@ timed rollout 10%:
You can stop the active timer of a delayed job by clicking the **{time-out}** (**Unschedule**) button. You can stop the active timer of a delayed job by clicking the **{time-out}** (**Unschedule**) button.
This job will never be executed in the future unless you execute the job manually. This job will never be executed in the future unless you execute the job manually.
You can start a delayed job immediately by clicking the **Play** button. To start a delayed job immediately, click the **Play** button.
GitLab Runner will pick your job soon and start the job. Soon GitLab Runner picks up and starts the job.
### `environment` ### `environment`
...@@ -2688,7 +2688,7 @@ deploy as review app: ...@@ -2688,7 +2688,7 @@ deploy as review app:
The `deploy as review app` job will be marked as deployment to dynamically The `deploy as review app` job will be marked as deployment to dynamically
create the `review/$CI_COMMIT_REF_NAME` environment, where `$CI_COMMIT_REF_NAME` create the `review/$CI_COMMIT_REF_NAME` environment, where `$CI_COMMIT_REF_NAME`
is an [environment variable](../variables/README.md) set by the Runner. The is an [environment variable](../variables/README.md) set by the runner. The
`$CI_ENVIRONMENT_SLUG` variable is based on the environment name, but suitable `$CI_ENVIRONMENT_SLUG` variable is based on the environment name, but suitable
for inclusion in URLs. In this case, if the `deploy as review app` job was run for inclusion in URLs. In this case, if the `deploy as review app` job was run
in a branch named `pow`, this environment would be accessible with an URL like in a branch named `pow`, this environment would be accessible with an URL like
...@@ -3483,7 +3483,7 @@ test: ...@@ -3483,7 +3483,7 @@ test:
The job-level timeout can exceed the The job-level timeout can exceed the
[project-level timeout](../pipelines/settings.md#timeout) but can't [project-level timeout](../pipelines/settings.md#timeout) but can't
exceed the Runner-specific timeout. exceed the runner-specific timeout.
### `parallel` ### `parallel`
...@@ -3788,12 +3788,12 @@ Sometimes running multiple jobs or pipelines at the same time in an environment ...@@ -3788,12 +3788,12 @@ Sometimes running multiple jobs or pipelines at the same time in an environment
can lead to errors during the deployment. can lead to errors during the deployment.
To avoid these errors, the `resource_group` attribute can be used to ensure that To avoid these errors, the `resource_group` attribute can be used to ensure that
the Runner won't run certain jobs simultaneously. the runner doesn't run certain jobs simultaneously.
When the `resource_group` key is defined for a job in `.gitlab-ci.yml`, When the `resource_group` key is defined for a job in `.gitlab-ci.yml`,
job executions are mutually exclusive across different pipelines for the same project. job executions are mutually exclusive across different pipelines for the same project.
If multiple jobs belonging to the same resource group are enqueued simultaneously, If multiple jobs belonging to the same resource group are enqueued simultaneously,
only one of the jobs will be picked by the Runner, and the other jobs will wait until the only one of the jobs is picked by the runner, and the other jobs wait until the
`resource_group` is free. `resource_group` is free.
Here is a simple example: Here is a simple example:
...@@ -4070,7 +4070,7 @@ The YAML-defined variables are also set to all created service containers, ...@@ -4070,7 +4070,7 @@ The YAML-defined variables are also set to all created service containers,
thus allowing to fine tune them. thus allowing to fine tune them.
Except for the user defined variables, there are also the ones [set up by the Except for the user defined variables, there are also the ones [set up by the
Runner itself](../variables/README.md#predefined-environment-variables). runner itself](../variables/README.md#predefined-environment-variables).
One example would be `CI_COMMIT_REF_NAME` which has the value of One example would be `CI_COMMIT_REF_NAME` which has the value of
the branch or tag name for which project is built. Apart from the variables the branch or tag name for which project is built. Apart from the variables
you can set in `.gitlab-ci.yml`, there are also the so called you can set in `.gitlab-ci.yml`, there are also the so called
...@@ -4176,7 +4176,7 @@ The `GIT_CHECKOUT` variable can be used when the `GIT_STRATEGY` is set to either ...@@ -4176,7 +4176,7 @@ The `GIT_CHECKOUT` variable can be used when the `GIT_STRATEGY` is set to either
specified, it defaults to true. You can set them globally or per-job in the specified, it defaults to true. You can set them globally or per-job in the
[`variables`](#variables) section. [`variables`](#variables) section.
If set to `false`, the Runner will: If set to `false`, the runner will:
- when doing `fetch` - update the repository and leave working copy on - when doing `fetch` - update the repository and leave working copy on
the current revision, the current revision,
...@@ -4184,7 +4184,7 @@ If set to `false`, the Runner will: ...@@ -4184,7 +4184,7 @@ If set to `false`, the Runner will:
default branch. default branch.
Having this setting set to `true` will mean that for both `clone` and `fetch` Having this setting set to `true` will mean that for both `clone` and `fetch`
strategies the Runner will checkout the working copy to a revision related strategies the runner will checkout the working copy to a revision related
to the CI pipeline: to the CI pipeline:
```yaml ```yaml
...@@ -4258,7 +4258,7 @@ The configurtion above will result in `git fetch` being called this way: ...@@ -4258,7 +4258,7 @@ The configurtion above will result in `git fetch` being called this way:
git fetch origin $REFSPECS --depth 50 --prune git fetch origin $REFSPECS --depth 50 --prune
``` ```
Where `$REFSPECS` is a value provided to the Runner internally by GitLab. Where `$REFSPECS` is a value provided to the runner internally by GitLab.
### Job stages attempts ### Job stages attempts
...@@ -4301,7 +4301,7 @@ NOTE: **Note:** ...@@ -4301,7 +4301,7 @@ NOTE: **Note:**
If you use a depth of 1 and have a queue of jobs or retry If you use a depth of 1 and have a queue of jobs or retry
jobs, jobs may fail. jobs, jobs may fail.
Since Git fetching and cloning is based on a ref, such as a branch name, Runners Since Git fetching and cloning is based on a ref, such as a branch name, runners
can't clone a specific commit SHA. If there are multiple jobs in the queue, or can't clone a specific commit SHA. If there are multiple jobs in the queue, or
you're retrying an old job, the commit to be tested needs to be within the you're retrying an old job, the commit to be tested needs to be within the
Git history that is cloned. Setting too small a value for `GIT_DEPTH` can make Git history that is cloned. Setting too small a value for `GIT_DEPTH` can make
...@@ -4322,17 +4322,17 @@ You can set it globally or per-job in the [`variables`](#variables) section. ...@@ -4322,17 +4322,17 @@ You can set it globally or per-job in the [`variables`](#variables) section.
### Custom build directories ### Custom build directories
> [Introduced](https://gitlab.com/gitlab-org/gitlab-runner/-/issues/2211) in GitLab Runner 11.10 > [Introduced](https://gitlab.com/gitlab-org/gitlab-runner/-/issues/2211) in GitLab Runner 11.10.
NOTE: **Note:** NOTE: **Note:**
This can only be used when `custom_build_dir` is enabled in the [Runner's This can only be used when `custom_build_dir` is enabled in the [runner's
configuration](https://docs.gitlab.com/runner/configuration/advanced-configuration.html#the-runnerscustom_build_dir-section). configuration](https://docs.gitlab.com/runner/configuration/advanced-configuration.html#the-runnerscustom_build_dir-section).
This is the default configuration for `docker` and `kubernetes` executor. This is the default configuration for `docker` and `kubernetes` executor.
By default, GitLab Runner clones the repository in a unique subpath of the By default, GitLab Runner clones the repository in a unique subpath of the
`$CI_BUILDS_DIR` directory. However, your project might require the code in a `$CI_BUILDS_DIR` directory. However, your project might require the code in a
specific directory (Go projects, for example). In that case, you can specify specific directory (Go projects, for example). In that case, you can specify
the `GIT_CLONE_PATH` variable to tell the Runner in which directory to clone the the `GIT_CLONE_PATH` variable to tell the runner in which directory to clone the
repository: repository:
```yaml ```yaml
...@@ -4354,9 +4354,9 @@ An executor using a concurrency greater than `1` might lead ...@@ -4354,9 +4354,9 @@ An executor using a concurrency greater than `1` might lead
to failures because multiple jobs might be working on the same directory if the `builds_dir` to failures because multiple jobs might be working on the same directory if the `builds_dir`
is shared between jobs. is shared between jobs.
GitLab Runner does not try to prevent this situation. It's up to the administrator GitLab Runner does not try to prevent this situation. It's up to the administrator
and developers to comply with the requirements of Runner configuration. and developers to comply with the requirements of runner configuration.
To avoid this scenario, you can use a unique path within `$CI_BUILDS_DIR`, because Runner To avoid this scenario, you can use a unique path within `$CI_BUILDS_DIR`, because runner
exposes two additional variables that provide a unique `ID` of concurrency: exposes two additional variables that provide a unique `ID` of concurrency:
- `$CI_CONCURRENT_ID`: Unique ID for all jobs running within the given executor. - `$CI_CONCURRENT_ID`: Unique ID for all jobs running within the given executor.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment