Commit c27023da authored by Cédric Tabin's avatar Cédric Tabin

Documentation improvement for the interruptible keyword

parent 1537c7d9
...@@ -117,7 +117,7 @@ The following table lists available parameters for jobs: ...@@ -117,7 +117,7 @@ The following table lists available parameters for jobs:
| [`extends`](#extends) | Configuration entries that this job is going to inherit from. | | [`extends`](#extends) | Configuration entries that this job is going to inherit from. |
| [`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. |
| [`variables`](#variables) | Define job variables on a job level. | | [`variables`](#variables) | Define job variables on a job level. |
| [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. |
NOTE: **Note:** NOTE: **Note:**
Parameters `types` and `type` are [deprecated](#deprecated-parameters). Parameters `types` and `type` are [deprecated](#deprecated-parameters).
...@@ -2155,19 +2155,19 @@ staging: ...@@ -2155,19 +2155,19 @@ staging:
> [Introduced](https://gitlab.com/gitlab-org/gitlab-foss/merge_requests/23464) in GitLab 12.3. > [Introduced](https://gitlab.com/gitlab-org/gitlab-foss/merge_requests/23464) in GitLab 12.3.
`interruptible` is used to indicate that a job should be canceled if made redundant by a newer run of the same job. Defaults to `false`. `interruptible` is used to indicate that a job should be canceled if made redundant by a newer pipeline run. Defaults to `false`.
This value will only be used if the [automatic cancellation of redundant pipelines feature](../../user/project/pipelines/settings.md#auto-cancel-pending-pipelines) This value will only be used if the [automatic cancellation of redundant pipelines feature](../../user/project/pipelines/settings.md#auto-cancel-pending-pipelines)
is enabled. is enabled.
When enabled, a pipeline on the same branch will be canceled when: When enabled, a pipeline on the same branch will be canceled when:
- It is made redundant by a newer pipeline run. - It is made redundant by a newer pipeline run.
- Either all jobs are set as interruptible, or any uninterruptible jobs are not yet pending. - Either all jobs are set as interruptible, or any uninterruptible jobs have not started.
Pending jobs are always considered interruptible. Pending jobs are always considered interruptible.
TIP: **Tip:** TIP: **Tip:**
Set jobs as uninterruptible that should behave atomically and should never be canceled once started. Set jobs as interruptible that can be safely canceled once started (for instance, a build job).
Here is a simple example: Here is a simple example:
...@@ -2175,23 +2175,33 @@ Here is a simple example: ...@@ -2175,23 +2175,33 @@ Here is a simple example:
stages: stages:
- stage1 - stage1
- stage2 - stage2
- stage3
step-1: step-1:
stage: stage1 stage: stage1
script: script:
- echo "Can be canceled" - echo "Can be canceled."
interruptible: true
step-2: step-2:
stage: stage2 stage: stage2
script: script:
- echo "Can not be canceled" - echo "Can not be canceled."
interruptible: false
step-3:
stage: stage3
script:
- echo "Because step-2 can not be canceled, this step will never be canceled, even though set as interruptible."
interruptible: true
``` ```
In the example above, a new pipeline run will cause an existing running pipeline to be: In the example above, a new pipeline run will cause an existing running pipeline to be:
- Canceled, if only `step-1` is running or pending. - Canceled, if only `step-1` is running or pending.
- Not canceled, once `step-2` becomes pending. - Not canceled, once `step-2` starts running.
NOTE: **Note:**
Once an uninterruptible job is running, the pipeline will never be canceled, regardless of the final job's state.
### `include` ### `include`
......
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