Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Jérome Perrin
gitlab-ce
Commits
323bac4a
Commit
323bac4a
authored
Apr 05, 2018
by
Grzegorz Bizon
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Improve docs about pipeline variables expressions
parent
4ef3e835
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
46 additions
and
12 deletions
+46
-12
doc/ci/variables/README.md
doc/ci/variables/README.md
+44
-11
doc/ci/yaml/README.md
doc/ci/yaml/README.md
+2
-1
No files found.
doc/ci/variables/README.md
View file @
323bac4a
...
@@ -454,8 +454,8 @@ export CI_REGISTRY_PASSWORD="longalfanumstring"
...
@@ -454,8 +454,8 @@ export CI_REGISTRY_PASSWORD="longalfanumstring"
> Variables expressions were added in GitLab 10.7.
> Variables expressions were added in GitLab 10.7.
It is possible to use variables expressions with only / except policies in
It is possible to use variables expressions with only / except policies in
`.gitlab-ci.yml`
. By using this approach you can limit what
build
s are going to
`.gitlab-ci.yml`
. By using this approach you can limit what
job
s are going to
be created within a pipeline after pushing code to GitLab.
be created within a pipeline after pushing
a
code to GitLab.
This is particularly useful in combination with secret variables and triggered
This is particularly useful in combination with secret variables and triggered
pipeline variables.
pipeline variables.
...
@@ -470,22 +470,21 @@ deploy:
...
@@ -470,22 +470,21 @@ deploy:
-
$STAGING
-
$STAGING
```
```
Each provided variables expression is going to be evaluated before creating
Each expression provided is going to be evaluated before creating a pipeline.
a pipeline.
If any of the conditions in
`variables`
evaluates to truth when using
`only`
,
If any of the conditions in
`variables`
evaluates to truth when using
`only`
,
a new job is going to be created. If any of the expressions evaluates to truth
a new job is going to be created. If any of the expressions evaluates to truth
when
`except`
is being used, a job is not going to be created.
when
`except`
is being used, a job is not going to be created.
This follows usual rules for
`only`
/
`except`
policies
.
This follows usual rules for
[
`only` / `except` policies
][
builds-policies
]
.
### Supported syntax
### Supported syntax
Below you can find
currently
supported syntax reference:
Below you can find supported syntax reference:
1.
Equality matching using a string
1.
Equality matching using a string
Example: `$VARIABLE == "some value"`
>
Example: `$VARIABLE == "some value"`
You can use equality operator `==` to compare a variable content to a
You can use equality operator `==` to compare a variable content to a
string. We support both, double quotes and single quotes to define a string
string. We support both, double quotes and single quotes to define a string
...
@@ -494,26 +493,59 @@ Below you can find currently supported syntax reference:
...
@@ -494,26 +493,59 @@ Below you can find currently supported syntax reference:
1.
Checking for an undefined value
1.
Checking for an undefined value
It sometimes happens that you want to check whether variable is defined or
> Example: `$VARIABLE == null`
not. To do that, you can compare variable to `null` value, like
It sometimes happens that you want to check whether a variable is defined
or not. To do that, you can compare a variable to `null` keyword, like
`$VARIABLE == null`. This expression is going to evaluate to truth if
`$VARIABLE == null`. This expression is going to evaluate to truth if
variable is not
set
.
variable is not
defined
.
1.
Checking for an empty variable
1.
Checking for an empty variable
> Example: `$VARIABLE == ""`
If you want to check whether a variable is defined, but is empty, you can
If you want to check whether a variable is defined, but is empty, you can
simply compare it against an empty string, like `$VAR == ''`.
simply compare it against an empty string, like `$VAR == ''`.
1.
Comparing two variables
1.
Comparing two variables
It is possible to compare two variables. `$VARIABLE_1 == $VARIABLE_2`.
> Example: `$VARIABLE_1 == $VARIABLE_2`
It is possible to compare two variables. This is going to compare values
of these variables.
1.
Variable presence check
1.
Variable presence check
> Example: `$STAGING`
If you only want to create a job when there is some variable present,
If you only want to create a job when there is some variable present,
which means that it is defined and non-empty, you can simply use
which means that it is defined and non-empty, you can simply use
variable name as an expression, like `$STAGING`. If `$STAGING` variable
variable name as an expression, like `$STAGING`. If `$STAGING` variable
is defined, and is non empty, expression will evaluate to truth.
is defined, and is non empty, expression will evaluate to truth.
`$STAGING` value needs to a string, with length higher than zero.
Variable that contains only whitespace characters is not an empty variable.
### Unsupported predefined variables
Because GitLab evaluates variables before creating jobs, we do not support a
few variables that depend on persistence layer, like
`$CI_JOB_ID`
.
Environments (like
`production`
or
`staging`
) are also being created based on
what jobs pipeline consists of, thus some environment-specific variables are
not supported as well.
We do not support variables containing tokens because of security reasons.
You can find a full list of unsupported variables below:
-
`CI_JOB_ID`
-
`CI_JOB_TOKEN`
-
`CI_BUILD_ID`
-
`CI_BUILD_TOKEN`
-
`CI_REGISTRY_USER`
-
`CI_REGISTRY_PASSWORD`
-
`CI_REPOSITORY_URL`
-
`CI_ENVIRONMENT_URL`
[
ce-13784
]:
https://gitlab.com/gitlab-org/gitlab-ce/issues/13784
"Simple protection of CI secret variables"
[
ce-13784
]:
https://gitlab.com/gitlab-org/gitlab-ce/issues/13784
"Simple protection of CI secret variables"
[
eep
]:
https://about.gitlab.com/products/
"Available only in GitLab Premium"
[
eep
]:
https://about.gitlab.com/products/
"Available only in GitLab Premium"
...
@@ -525,3 +557,4 @@ Below you can find currently supported syntax reference:
...
@@ -525,3 +557,4 @@ Below you can find currently supported syntax reference:
[
triggered
]:
../triggers/README.md
[
triggered
]:
../triggers/README.md
[
triggers
]:
../triggers/README.md#pass-job-variables-to-a-trigger
[
triggers
]:
../triggers/README.md#pass-job-variables-to-a-trigger
[
subgroups
]:
../../user/group/subgroups/index.md
[
subgroups
]:
../../user/group/subgroups/index.md
[
builds-policies
]:
../yaml/README.md#only-and-except-complex
doc/ci/yaml/README.md
View file @
323bac4a
...
@@ -354,7 +354,7 @@ deploy:
...
@@ -354,7 +354,7 @@ deploy:
-
$STAGING
-
$STAGING
```
```
Learn more about variables expressions on
a separate page
.
Learn more about variables expressions on
[
a separate page
][
variables-expressions
]
.
## `tags`
## `tags`
...
@@ -1574,3 +1574,4 @@ CI with various languages.
...
@@ -1574,3 +1574,4 @@ CI with various languages.
[
ce-7447
]:
https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/7447
[
ce-7447
]:
https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/7447
[
ce-12909
]:
https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/12909
[
ce-12909
]:
https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/12909
[
schedules
]:
../../user/project/pipelines/schedules.md
[
schedules
]:
../../user/project/pipelines/schedules.md
[
variables-expressions
]:
../variables/README.md#variables-expressions
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment