Commit ba2b0a5a authored by Suzanne Selhorn's avatar Suzanne Selhorn

Merge branch 'docs-yaml-config-file-naming' into 'master'

Ensure config file mentions are consistent

See merge request gitlab-org/gitlab!52553
parents 3150d9c3 aa3211db
...@@ -5,7 +5,9 @@ info: To determine the technical writer assigned to the Stage/Group associated w ...@@ -5,7 +5,9 @@ info: To determine the technical writer assigned to the Stage/Group associated w
type: reference type: reference
--- ---
# GitLab CI/CD pipeline configuration reference <!-- markdownlint-disable MD044 -->
# Keyword reference for the .gitlab-ci.yml file
<!-- markdownlint-enable MD044 -->
This document lists the configuration options for your GitLab `.gitlab-ci.yml` file. This document lists the configuration options for your GitLab `.gitlab-ci.yml` file.
...@@ -223,7 +225,7 @@ stages: ...@@ -223,7 +225,7 @@ stages:
If any job fails, the pipeline is marked as `failed` and jobs in later stages do not If any job fails, the pipeline is marked as `failed` and jobs in later stages do not
start. Jobs in the current stage are not stopped and continue to run. start. Jobs in the current stage are not stopped and continue to run.
If no `stages` are defined in `.gitlab-ci.yml`, then `build`, `test` and `deploy` If no `stages` are defined in the `.gitlab-ci.yml` file, then `build`, `test` and `deploy`
are the default pipeline stages. are the default pipeline stages.
If a job does not specify a [`stage`](#stage), the job is assigned the `test` stage. If a job does not specify a [`stage`](#stage), the job is assigned the `test` stage.
...@@ -342,7 +344,7 @@ include: ...@@ -342,7 +344,7 @@ include:
> - [Moved](https://gitlab.com/gitlab-org/gitlab-foss/-/issues/42861) to GitLab Core in 11.4. > - [Moved](https://gitlab.com/gitlab-org/gitlab-foss/-/issues/42861) to GitLab Core in 11.4.
Use the `include` keyword to include external YAML files in your CI/CD configuration. Use the `include` keyword to include external YAML files in your CI/CD configuration.
You can break down one long `gitlab-ci.yml` into multiple files to increase readability, You can break down one long `gitlab-ci.yml` file into multiple files to increase readability,
or reduce duplication of the same configuration in multiple places. or reduce duplication of the same configuration in multiple places.
You can also store template files in a central repository and `include` them in projects. You can also store template files in a central repository and `include` them in projects.
...@@ -363,19 +365,19 @@ use the [`extends` keyword](#extends). ...@@ -363,19 +365,19 @@ use the [`extends` keyword](#extends).
| [`remote`](#includeremote) | Include a file from a remote URL. Must be publicly accessible. | | [`remote`](#includeremote) | Include a file from a remote URL. Must be publicly accessible. |
| [`template`](#includetemplate) | Include templates that are provided by GitLab. | | [`template`](#includetemplate) | Include templates that are provided by GitLab. |
`.gitlab-ci.yml` configuration included by all methods is evaluated at pipeline creation. The `.gitlab-ci.yml` file configuration included by all methods is evaluated when the pipeline is created.
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 is not reflected in GitLab until the next pipeline is created. the referenced `.gitlab-ci.yml` file configuration is not reflected in GitLab until the next pipeline is created.
The files defined by `include` are: The files defined by `include` are:
- Deep merged with those in `.gitlab-ci.yml`. - Deep merged with those in the `.gitlab-ci.yml` file.
- Always evaluated first and merged with the content of `.gitlab-ci.yml`, - Always evaluated first and merged with the content of the `.gitlab-ci.yml` file,
regardless of the position of the `include` keyword. regardless of the position of the `include` keyword.
NOTE: NOTE:
Use merging to customize and override included CI/CD configurations with local Use merging to customize and override included CI/CD configurations with local
configurations. Local configurations in `.gitlab-ci.yml` override included configurations. configurations. Local configurations in the `.gitlab-ci.yml` file override included configurations.
#### Variables with `include` **(CORE ONLY)** #### Variables with `include` **(CORE ONLY)**
...@@ -383,7 +385,7 @@ configurations. Local configurations in `.gitlab-ci.yml` override included confi ...@@ -383,7 +385,7 @@ configurations. Local configurations in `.gitlab-ci.yml` override included confi
> - [Feature flag removed](https://gitlab.com/gitlab-org/gitlab/-/issues/294294) in GitLab 13.9. > - [Feature flag removed](https://gitlab.com/gitlab-org/gitlab/-/issues/294294) in GitLab 13.9.
You can [use some predefined variables in `include` sections](../variables/where_variables_can_be_used.md#gitlab-ciyml-file) You can [use some predefined variables in `include` sections](../variables/where_variables_can_be_used.md#gitlab-ciyml-file)
in your `.gitlab-ci.yml`: in your `.gitlab-ci.yml` file:
```yaml ```yaml
include: include:
...@@ -396,12 +398,11 @@ see the following [CI variable demo](https://youtu.be/4XR8gw3Pkos). ...@@ -396,12 +398,11 @@ see the following [CI variable demo](https://youtu.be/4XR8gw3Pkos).
#### `include:local` #### `include:local`
`include:local` includes a file from the same repository as `.gitlab-ci.yml`. `include:local` includes a file that is in the same repository as the `.gitlab-ci.yml` file.
It's referenced with full paths relative to the root directory (`/`). It's referenced with full paths relative to the root directory (`/`).
You can only use files that are tracked by Git on the same branch If you use `include:local`, make sure that both the `.gitlab-ci.yml` file and the local file
your configuration file is on. If you `include:local`, make are on the same branch.
sure that both `.gitlab-ci.yml` and the local file are on the same branch.
You can't include local files through Git submodules paths. You can't include local files through Git submodules paths.
...@@ -786,7 +787,7 @@ User-defined stages are executed after `.pre` and before `.post`. ...@@ -786,7 +787,7 @@ User-defined stages are executed after `.pre` and before `.post`.
A pipeline is not created if all jobs are in `.pre` or `.post` stages. A pipeline is not created if all jobs are in `.pre` or `.post` stages.
The order of `.pre` and `.post` can't be changed, even if defined out of order in `.gitlab-ci.yml`. The order of `.pre` and `.post` can't be changed, even if defined out of order in the `.gitlab-ci.yml` file.
For example, the following are equivalent configuration: For example, the following are equivalent configuration:
- Configured in order: - Configured in order:
...@@ -973,7 +974,7 @@ For example, if you have a local `included.yml` file: ...@@ -973,7 +974,7 @@ For example, if you have a local `included.yml` file:
- echo Hello! - echo Hello!
``` ```
Then, in `.gitlab-ci.yml`: Then, in the `.gitlab-ci.yml` file:
```yaml ```yaml
include: included.yml include: included.yml
...@@ -2511,8 +2512,8 @@ deployment to the `production` environment. ...@@ -2511,8 +2512,8 @@ deployment to the `production` environment.
#### `environment:name` #### `environment:name`
The `environment: name` keyword can use any of the defined CI variables, The `environment: name` keyword can use any of the defined CI/CD [variables](#variables),
including predefined, secure, or `.gitlab-ci.yml` [`variables`](#variables). including predefined, secure, or variables defined in the `.gitlab-ci.yml` file.
You can't use variables defined in a `script` section. You can't use variables defined in a `script` section.
...@@ -2545,8 +2546,8 @@ deploy to production: ...@@ -2545,8 +2546,8 @@ deploy to production:
#### `environment:url` #### `environment:url`
The `url` keyword can use any of the defined CI variables, The `environment:url` keyword can use any of the defined CI/CD [variables](#variables),
including predefined, secure, or `.gitlab-ci.yml` [`variables`](#variables). including predefined, secure, or variables defined in the `.gitlab-ci.yml` file.
You can't use variables defined in a `script` section. You can't use variables defined in a `script` section.
...@@ -3753,7 +3754,7 @@ upstream_bridge: ...@@ -3753,7 +3754,7 @@ upstream_bridge:
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/16094) in GitLab 12.7. > [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/16094) in GitLab 12.7.
To create a [child pipeline](../parent_child_pipelines.md), specify the path to the To create a [child pipeline](../parent_child_pipelines.md), specify the path to the
YAML file containing the CI config of the child pipeline: YAML file that contains the configuration of the child pipeline:
```yaml ```yaml
trigger_job: trigger_job:
...@@ -3904,7 +3905,7 @@ To avoid these errors, the `resource_group` attribute can be used to ensure that ...@@ -3904,7 +3905,7 @@ To avoid these errors, the `resource_group` attribute can be used to ensure that
the runner doesn't run certain jobs simultaneously. Resource groups behave similar the runner doesn't run certain jobs simultaneously. Resource groups behave similar
to semaphores in other programming languages. to semaphores in other programming languages.
When the `resource_group` keyword is defined for a job in `.gitlab-ci.yml`, When the `resource_group` keyword is defined for a job in the `.gitlab-ci.yml` file,
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 is picked by the runner. The other jobs wait until the only one of the jobs is picked by the runner. The other jobs wait until the
...@@ -4031,7 +4032,7 @@ description. ...@@ -4031,7 +4032,7 @@ description.
You can specify a file in `$CI_PROJECT_DIR` that contains the description. The file must be relative You can specify a file in `$CI_PROJECT_DIR` that contains the description. The file must be relative
to the project directory (`$CI_PROJECT_DIR`), and if the file is a symbolic link it can't reside to the project directory (`$CI_PROJECT_DIR`), and if the file is a symbolic link it can't reside
outside of `$CI_PROJECT_DIR`. The `./path/to/file` and file name can't contain spaces. outside of `$CI_PROJECT_DIR`. The `./path/to/file` and filename can't contain spaces.
```yaml ```yaml
job: job:
...@@ -4299,7 +4300,7 @@ You can also use variables to configure how many times a runner ...@@ -4299,7 +4300,7 @@ You can also use variables to configure how many times a runner
It's possible to use special YAML features like anchors (`&`), aliases (`*`) It's possible to use special YAML features like anchors (`&`), aliases (`*`)
and map merging (`<<`). Use these features to reduce the complexity and map merging (`<<`). Use these features to reduce the complexity
of `.gitlab-ci.yml`. of the code in the `.gitlab-ci.yml` file.
Read more about the various [YAML features](https://learnxinyminutes.com/docs/yaml/). Read more about the various [YAML features](https://learnxinyminutes.com/docs/yaml/).
......
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