2019-09-17 10:16:34 -04:00
# Pipelines for the GitLab project
2019-11-27 01:06:40 -05:00
Pipelines for < https: / / gitlab . com / gitlab-org / gitlab > and < https: / / gitlab . com / gitlab-org / gitlab-foss > (as well as the
2019-09-17 10:16:34 -04:00
`dev` instance's mirrors) are configured in the usual
[`.gitlab-ci.yml` ](https://gitlab.com/gitlab-org/gitlab/blob/master/.gitlab-ci.yml )
which itself includes files under
[`.gitlab/ci/` ](https://gitlab.com/gitlab-org/gitlab/tree/master/.gitlab/ci )
for easier maintenance.
We're striving to [dogfood ](https://about.gitlab.com/handbook/engineering/#dogfooding )
GitLab [CI/CD features and best-practices ](../ci/yaml/README.md )
as much as possible.
## Stages
The current stages are:
2019-11-27 01:06:40 -05:00
- `sync` : This stage is used to synchronize changes from < https: // gitlab . com / gitlab-org / gitlab > to
< https: / / gitlab . com / gitlab-org / gitlab-foss > .
2019-09-17 10:16:34 -04:00
- `prepare` : This stage includes jobs that prepare artifacts that are needed by
jobs in subsequent stages.
- `quick-test` : This stage includes test jobs that should run first and fail the
pipeline early (currently used to run Geo tests when the branch name starts
with `geo-` , `geo/` , or ends with `-geo` ).
- `test` : This stage includes most of the tests, DB/migration jobs, and static analysis jobs.
2019-11-29 10:06:43 -05:00
- `post-test` : This stage includes jobs that build reports or gather data from
the `test` stage's jobs (e.g. coverage, Knapsack metadata etc.).
2019-09-17 10:16:34 -04:00
- `review-prepare` : This stage includes a job that build the CNG images that are
later used by the (Helm) Review App deployment (see
[Review Apps ](testing_guide/review_apps.md ) for details).
- `review` : This stage includes jobs that deploy the GitLab and Docs Review Apps.
- `qa` : This stage includes jobs that perform QA tasks against the Review App
that is deployed in the previous stage.
2019-11-29 10:06:43 -05:00
- `post-qa` : This stage includes jobs that build reports or gather data from
the `qa` stage's jobs (e.g. Review App performance report).
2019-11-25 10:06:45 -05:00
- `notification` : This stage includes jobs that sends notifications about pipeline status.
2019-09-17 10:16:34 -04:00
- `pages` : This stage includes a job that deploys the various reports as
2019-11-27 01:06:40 -05:00
GitLab Pages (e.g. < https: / / gitlab-org . gitlab . io / gitlab / coverage-ruby / > ,
2019-09-17 10:16:34 -04:00
< https: / / gitlab-org . gitlab . io / gitlab / coverage-javascript / > ,
< https: / / gitlab-org . gitlab . io / gitlab / webpack-report / > ).
## Default image
The default image is currently
2019-12-12 13:07:34 -05:00
`registry.gitlab.com/gitlab-org/gitlab-build-images:ruby-2.6.3-golang-1.12-git-2.24-lfs-2.9-chrome-73.0-node-12.x-yarn-1.16-postgresql-9.6-graphicsmagick-1.3.33` .
2019-10-31 02:06:31 -04:00
2019-12-12 13:07:34 -05:00
It includes Ruby 2.6.3, Go 1.12, Git 2.24, Git LFS 2.9, Chrome 73, Node 12, Yarn 1.16,
2019-09-17 10:16:34 -04:00
PostgreSQL 9.6, and Graphics Magick 1.3.33.
The images used in our pipelines are configured in the
[`gitlab-org/gitlab-build-images` ](https://gitlab.com/gitlab-org/gitlab-build-images )
project, which is push-mirrored to < https: / / dev . gitlab . org / gitlab / gitlab-build-images >
for redundancy.
The current version of the build images can be found in the
2019-10-31 02:06:31 -04:00
["Used by GitLab section" ](https://gitlab.com/gitlab-org/gitlab-build-images/blob/master/.gitlab-ci.yml ).
2019-09-17 10:16:34 -04:00
## Default variables
In addition to the [predefined variables ](../ci/variables/predefined_variables.md ),
2019-10-31 02:06:31 -04:00
each pipeline includes default variables defined in
< https: / / gitlab . com / gitlab-org / gitlab / blob / master / . gitlab-ci . yml > .
2019-09-17 10:16:34 -04:00
## Common job definitions
Most of the jobs [extend from a few CI definitions ](../ci/yaml/README.md#extends )
that are scoped to a single
[configuration parameter ](../ci/yaml/README.md#configuration-parameters ).
These common definitions are:
- `.default-tags` : Ensures a job has the `gitlab-org` tag to ensure it's using
our dedicated runners.
- `.default-retry` : Allows a job to retry upon `unknown_failure` , `api_failure` ,
`runner_system_failure` .
- `.default-before_script` : Allows a job to use a default `before_script` definition
suitable for Ruby/Rails tasks that may need a database running (e.g. tests).
- `.default-cache` : Allows a job to use a default `cache` definition suitable for
Ruby/Rails and frontend tasks.
- `.default-only` : Restricts the cases where a job is created. This currently
includes `master` , `/^[\d-]+-stable(-ee)?$/` (stable branches),
2019-10-31 02:06:31 -04:00
`/^\d+-\d+-auto-deploy-\d+$/` (auto-deploy branches), `/^security\//` (security branches), `merge_requests` , `tags` .
2019-09-17 10:16:34 -04:00
Note that jobs won't be created for branches with this default configuration.
2019-10-31 02:06:31 -04:00
- `.only:variables-canonical-dot-com` : Only creates a job if the project is
located under < https: / / gitlab . com / gitlab-org > .
- `.only:variables_refs-canonical-dot-com-schedules` : Same as
`.only:variables-canonical-dot-com` but add the condition that pipeline is scheduled.
- `.except:refs-deploy` : Don't create a job if the `ref` is an auto-deploy branch.
- `.except:refs-master-tags-stable-deploy` : Don't create a job if the `ref` is one of:
- `master`
- a tag
- a stable branch
- an auto-deploy branch
- `.only:kubernetes` : Only creates a job if a Kubernetes integration is enabled
on the project.
- `.only-review` : This extends from:
- `.only:variables-canonical-dot-com`
- `.only:kubernetes`
- `.except:refs-master-tags-stable-deploy`
- `.only-review-schedules` : This extends from:
- `.only:variables_refs-canonical-dot-com-schedules`
- `.only:kubernetes`
- `.except:refs-deploy`
2019-10-10 14:06:00 -04:00
- `.use-pg9` : Allows a job to use the `postgres:9.6` and `redis:alpine` services.
- `.use-pg10` : Allows a job to use the `postgres:10.9` and `redis:alpine` services.
- `.use-pg9-ee` : Same as `.use-pg9` but also use the
`docker.elastic.co/elasticsearch/elasticsearch:5.6.12` services.
- `.use-pg10-ee` : Same as `.use-pg10` but also use the
`docker.elastic.co/elasticsearch/elasticsearch:5.6.12` services.
2019-10-31 02:06:31 -04:00
- `.only-ee` : Only creates a job for the `gitlab` or `gitlab-ee` project.
2019-10-10 14:06:00 -04:00
- `.only-ee-as-if-foss` : Same as `.only-ee` but simulate the FOSS project by
2019-10-16 14:08:01 -04:00
setting the `FOSS_ONLY='1'` environment variable.
2019-09-17 10:16:34 -04:00
## Changes detection
If a job extends from `.default-only` (and most of the jobs should), it can restrict
the cases where it should be created
[based on the changes ](../ci/yaml/README.md#onlychangesexceptchanges )
from a commit or MR by extending from the following CI definitions:
2019-10-31 02:06:31 -04:00
- `.only:changes-code` : Allows a job to only be created upon code-related changes.
- `.only:changes-qa` : Allows a job to only be created upon QA-related changes.
- `.only:changes-docs` : Allows a job to only be created upon docs-related changes.
- `.only:changes-graphql` : Allows a job to only be created upon GraphQL-related changes.
- `.only:changes-code-backstage` : Allows a job to only be created upon code-related or backstage-related (e.g. Danger, RuboCop, specs) changes.
- `.only:changes-code-qa` : Allows a job to only be created upon code-related or QA-related changes.
- `.only:changes-code-backstage-qa` : Allows a job to only be created upon code-related, backstage-related (e.g. Danger, RuboCop, specs) or QA-related changes.
2019-09-17 10:16:34 -04:00
**See < https: / / gitlab . com / gitlab-org / gitlab / blob / master / . gitlab / ci / global . gitlab-ci . yml >
for the list of exact patterns.**
## Directed acyclic graph
We're using the [`needs:` ](../ci/yaml/README.md#needs ) keyword to
execute jobs out of order for the following jobs:
```mermaid
graph RL;
A[setup-test-env];
2019-10-16 14:08:01 -04:00
B["gitlab:assets:compile pull-push-cache< br / > (master only)"];
2019-09-17 10:16:34 -04:00
C[gitlab:assets:compile pull-cache];
D["cache gems< br / > (master and tags only)"];
E[review-build-cng];
F[build-qa-image];
G[review-deploy];
G2["schedule:review-deploy< br / > (master only)"];
H[karma];
I[jest];
2019-10-16 14:08:01 -04:00
J["compile-assets pull-push-cache< br / > (master only)"];
2019-09-17 10:16:34 -04:00
K[compile-assets pull-cache];
L[webpack-dev-server];
M[coverage];
N[pages];
O[static-analysis];
2019-09-23 11:06:32 -04:00
P["schedule:package-and-qa< br / > (master schedule only)"];
2019-09-17 10:16:34 -04:00
Q[package-and-qa];
R[package-and-qa-manual];
2019-10-16 14:08:01 -04:00
S["RSpec< br / > (e.g. rspec unit pg9)"]
T[retrieve-tests-metadata];
2019-09-17 10:16:34 -04:00
subgraph "`prepare` stage"
A
F
K
2019-10-16 14:08:01 -04:00
J
T
2019-09-17 10:16:34 -04:00
end
subgraph "`test` stage"
B --> |needs| A;
C --> |needs| A;
D --> |needs| A;
2019-10-16 14:08:01 -04:00
H -.-> |needs and depends on| A;
H -.-> |needs and depends on| K;
I -.-> |needs and depends on| A;
I -.-> |needs and depends on| K;
L -.-> |needs and depends on| A;
L -.-> |needs and depends on| K;
O -.-> |needs and depends on| A;
O -.-> |needs and depends on| K;
S -.-> |needs and depends on| A;
S -.-> |needs and depends on| K;
S -.-> |needs and depends on| T;
2019-09-17 10:16:34 -04:00
downtime_check --> |needs and depends on| A;
db:* --> |needs| A;
gitlab:setup --> |needs| A;
downtime_check --> |needs and depends on| A;
2019-10-16 14:08:01 -04:00
graphql-docs-verify --> |needs| A;
2019-09-17 10:16:34 -04:00
end
subgraph "`review-prepare` stage"
E --> |needs| C;
2019-10-16 14:08:01 -04:00
X["schedule:review-build-cng< br / > (master schedule only)"] --> |needs| C;
2019-09-17 10:16:34 -04:00
end
subgraph "`review` stage"
2019-11-25 07:06:13 -05:00
G
G2
2019-09-17 10:16:34 -04:00
end
subgraph "`qa` stage"
Q --> |needs| C;
Q --> |needs| F;
R --> |needs| C;
R --> |needs| F;
2019-10-16 14:08:01 -04:00
P --> |needs| C;
2019-09-17 10:16:34 -04:00
P --> |needs| F;
2019-10-02 08:06:04 -04:00
review-qa-smoke -.-> |needs and depends on| G;
review-qa-all -.-> |needs and depends on| G;
review-performance -.-> |needs and depends on| G;
X2["schedule:review-performance< br / > (master only)"] -.-> |needs and depends on| G2;
dast -.-> |needs and depends on| G;
2019-09-17 10:16:34 -04:00
end
2019-11-25 10:06:45 -05:00
subgraph "`notification` stage"
NOTIFICATION1["schedule:package-and-qa:notify-success< br > (on_success)"] -.-> |needs| P;
NOTIFICATION2["schedule:package-and-qa:notify-failure< br > (on_failure)"] -.-> |needs| P;
end
2019-09-17 10:16:34 -04:00
subgraph "`post-test` stage"
M
end
subgraph "`pages` stage"
2019-10-16 14:08:01 -04:00
N -.-> |depends on| C;
2019-09-17 10:16:34 -04:00
N -.-> |depends on| H;
N -.-> |depends on| M;
end
```
## Test jobs
Consult [GitLab tests in the Continuous Integration (CI) context ](testing_guide/ci.md )
for more information.
## Review app jobs
Consult the [Review Apps ](testing_guide/review_apps.md ) dedicated page for more information.
---
[Return to Development documentation ](README.md )