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
Boxiang Sun
gitlab-ce
Commits
b881c772
Commit
b881c772
authored
Aug 26, 2019
by
Stan Hu
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Reduce complexity of CI files
Signed-off-by:
Rémy Coutable
<
remy@rymai.me
>
parent
f6873023
Changes
14
Show whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
474 additions
and
451 deletions
+474
-451
.gitlab-ci.yml
.gitlab-ci.yml
+10
-16
.gitlab/ci/cng.gitlab-ci.yml
.gitlab/ci/cng.gitlab-ci.yml
+3
-4
.gitlab/ci/docs.gitlab-ci.yml
.gitlab/ci/docs.gitlab-ci.yml
+28
-19
.gitlab/ci/frontend.gitlab-ci.yml
.gitlab/ci/frontend.gitlab-ci.yml
+95
-72
.gitlab/ci/global.gitlab-ci.yml
.gitlab/ci/global.gitlab-ci.yml
+44
-58
.gitlab/ci/memory.gitlab-ci.yml
.gitlab/ci/memory.gitlab-ci.yml
+15
-2
.gitlab/ci/pages.gitlab-ci.yml
.gitlab/ci/pages.gitlab-ci.yml
+10
-11
.gitlab/ci/qa.gitlab-ci.yml
.gitlab/ci/qa.gitlab-ci.yml
+3
-3
.gitlab/ci/rails.gitlab-ci.yml
.gitlab/ci/rails.gitlab-ci.yml
+152
-136
.gitlab/ci/reports.gitlab-ci.yml
.gitlab/ci/reports.gitlab-ci.yml
+13
-20
.gitlab/ci/review.gitlab-ci.yml
.gitlab/ci/review.gitlab-ci.yml
+60
-69
.gitlab/ci/setup.gitlab-ci.yml
.gitlab/ci/setup.gitlab-ci.yml
+23
-22
.gitlab/ci/test-metadata.gitlab-ci.yml
.gitlab/ci/test-metadata.gitlab-ci.yml
+14
-16
.gitlab/ci/yaml.gitlab-ci.yml
.gitlab/ci/yaml.gitlab-ci.yml
+4
-3
No files found.
.gitlab-ci.yml
View file @
b881c772
image
:
"
dev.gitlab.org:5005/gitlab/gitlab-build-images:ruby-2.6.3-golang-1.11-git-2.22-chrome-73.0-node-12.x-yarn-1.16-postgresql-9.6-graphicsmagick-1.3.33"
image
:
"
dev.gitlab.org:5005/gitlab/gitlab-build-images:ruby-2.6.3-golang-1.11-git-2.22-chrome-73.0-node-12.x-yarn-1.16-postgresql-9.6-graphicsmagick-1.3.33"
stages
:
-
build
-
prepare
-
quick-test
-
test
-
review
-
qa
-
post-test
-
pages
variables
:
variables
:
RAILS_ENV
:
"
test"
RAILS_ENV
:
"
test"
NODE_ENV
:
"
test"
NODE_ENV
:
"
test"
...
@@ -11,25 +21,9 @@ variables:
...
@@ -11,25 +21,9 @@ variables:
FLAKY_RSPEC_SUITE_REPORT_PATH
:
rspec_flaky/report-suite.json
FLAKY_RSPEC_SUITE_REPORT_PATH
:
rspec_flaky/report-suite.json
BUILD_ASSETS_IMAGE
:
"
false"
BUILD_ASSETS_IMAGE
:
"
false"
before_script
:
-
date
-
source scripts/utils.sh
-
source scripts/prepare_build.sh
-
date
after_script
:
after_script
:
-
date
-
date
stages
:
-
build
-
prepare
-
merge
-
test
-
review
-
qa
-
post-test
-
pages
include
:
include
:
-
local
:
.gitlab/ci/global.gitlab-ci.yml
-
local
:
.gitlab/ci/global.gitlab-ci.yml
-
local
:
.gitlab/ci/cng.gitlab-ci.yml
-
local
:
.gitlab/ci/cng.gitlab-ci.yml
...
...
.gitlab/ci/cng.gitlab-ci.yml
View file @
b881c772
cloud-native-image
:
cloud-native-image
:
image
:
ruby:2.6-alpine
image
:
ruby:2.6-alpine
before_script
:
[]
dependencies
:
[]
dependencies
:
[]
stage
:
post-test
stage
:
post-test
allow_failure
:
true
allow_failure
:
true
variables
:
variables
:
GIT_DEPTH
:
"
1"
GIT_DEPTH
:
"
1"
cache
:
{}
when
:
manual
when
:
manual
script
:
script
:
-
install_gitlab_gem
-
install_gitlab_gem
-
CNG_PROJECT_PATH="gitlab-org/build/CNG" BUILD_TRIGGER_TOKEN=$CI_JOB_TOKEN ./scripts/trigger-build cng
-
CNG_PROJECT_PATH="gitlab-org/build/CNG" BUILD_TRIGGER_TOKEN=$CI_JOB_TOKEN ./scripts/trigger-build cng
only
:
only
:
refs
:
-
tags@gitlab-org/gitlab-ce
-
tags@gitlab-org/gitlab-ce
-
tags@gitlab-org/gitlab-ee
-
tags@gitlab-org/gitlab-ee
.gitlab/ci/docs.gitlab-ci.yml
View file @
b881c772
.review-docs
:
&review-docs
.review-docs
:
extends
:
.single-script-job-dedicated-runner
extends
:
-
.default-tags
-
.default-retry
image
:
ruby:2.6-alpine
stage
:
review
dependencies
:
[]
variables
:
variables
:
SCRIPT_NAME
:
trigger-build-docs
GIT_STRATEGY
:
none
environment
:
environment
:
name
:
review-docs/$CI_COMMIT_REF_SLUG
name
:
review-docs/$CI_COMMIT_REF_SLUG
# DOCS_REVIEW_APPS_DOMAIN and DOCS_GITLAB_REPO_SUFFIX are CI variables
# DOCS_REVIEW_APPS_DOMAIN and DOCS_GITLAB_REPO_SUFFIX are CI variables
# Discussion: https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/14236/diffs#note_40140693
# Discussion: https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/14236/diffs#note_40140693
url
:
http://$CI_ENVIRONMENT_SLUG.$DOCS_REVIEW_APPS_DOMAIN/$DOCS_GITLAB_REPO_SUFFIX
url
:
http://$CI_ENVIRONMENT_SLUG.$DOCS_REVIEW_APPS_DOMAIN/$DOCS_GITLAB_REPO_SUFFIX
on_stop
:
review-docs-cleanup
on_stop
:
review-docs-cleanup
before_script
:
# We don't clone the repo by using GIT_STRATEGY: none and only download the
# single script we need here so it's much faster than cloning.
-
apk add --update openssl
-
wget $CI_PROJECT_URL/raw/$CI_COMMIT_SHA/scripts/trigger-build-docs
-
chmod 755 trigger-build-docs
# Trigger a manual docs build in gitlab-docs only on non docs-only branches.
# Trigger a manual docs build in gitlab-docs only on non docs-only branches.
# Useful to preview the docs changes live.
# Useful to preview the docs changes live.
review-docs-deploy-manual
:
review-docs-deploy-manual
:
extends
:
extends
:
-
.review-docs
-
.review-docs
-
.no-docs-and-no-qa
-
.except-docs-qa
stage
:
review
script
:
script
:
-
gem install gitlab --no-document
-
gem install gitlab --no-document
-
./
$SCRIPT_NAME
deploy
-
./
trigger-build-docs
deploy
when
:
manual
when
:
manual
only
:
only
:
-
branches@gitlab-org/gitlab-ce
-
branches@gitlab-org/gitlab-ce
...
@@ -27,39 +37,40 @@ review-docs-deploy-manual:
...
@@ -27,39 +37,40 @@ review-docs-deploy-manual:
# Always trigger a docs build in gitlab-docs only on docs-only branches.
# Always trigger a docs build in gitlab-docs only on docs-only branches.
# Useful to preview the docs changes live.
# Useful to preview the docs changes live.
review-docs-deploy
:
review-docs-deploy
:
<<
:
*review-docs
extends
:
stage
:
review
-
.review-docs
-
.except-qa
script
:
script
:
-
gem install gitlab --no-document
-
gem install gitlab --no-document
-
./
$SCRIPT_NAME
deploy
-
./
trigger-build-docs
deploy
only
:
only
:
-
/(^docs[\/-].+|.+-docs$)/@gitlab-org/gitlab-ce
-
/(^docs[\/-].+|.+-docs$)/@gitlab-org/gitlab-ce
-
/(^docs[\/-].+|.+-docs$)/@gitlab-org/gitlab-ee
-
/(^docs[\/-].+|.+-docs$)/@gitlab-org/gitlab-ee
except
:
-
/(^qa[\/-].*|.*-qa$)/
# Cleanup remote environment of gitlab-docs
# Cleanup remote environment of gitlab-docs
review-docs-cleanup
:
review-docs-cleanup
:
<<
:
*review-docs
extends
:
stage
:
review
-
.review-docs
-
.except-qa
environment
:
environment
:
name
:
review-docs/$CI_COMMIT_REF_SLUG
name
:
review-docs/$CI_COMMIT_REF_SLUG
action
:
stop
action
:
stop
script
:
script
:
-
gem install gitlab --no-document
-
gem install gitlab --no-document
-
./
$SCRIPT_NAME
cleanup
-
./
trigger-build-docs
cleanup
when
:
manual
when
:
manual
only
:
only
:
-
branches@gitlab-org/gitlab-ce
-
branches@gitlab-org/gitlab-ce
-
branches@gitlab-org/gitlab-ee
-
branches@gitlab-org/gitlab-ee
docs lint
:
docs lint
:
extends
:
.dedicated-runner
extends
:
-
.default-tags
-
.default-retry
-
.except-qa
image
:
"
registry.gitlab.com/gitlab-org/gitlab-build-images:gitlab-docs-lint"
image
:
"
registry.gitlab.com/gitlab-org/gitlab-build-images:gitlab-docs-lint"
stage
:
test
stage
:
test
cache
:
{}
dependencies
:
[]
dependencies
:
[]
before_script
:
[]
script
:
script
:
-
scripts/lint-doc.sh
-
scripts/lint-doc.sh
-
mv doc/ /tmp/gitlab-docs/content/$DOCS_GITLAB_REPO_SUFFIX
-
mv doc/ /tmp/gitlab-docs/content/$DOCS_GITLAB_REPO_SUFFIX
...
@@ -72,5 +83,3 @@ docs lint:
...
@@ -72,5 +83,3 @@ docs lint:
-
bundle exec nanoc check internal_links
-
bundle exec nanoc check internal_links
# Check the internal anchor links
# Check the internal anchor links
-
bundle exec nanoc check internal_anchors
-
bundle exec nanoc check internal_anchors
except
:
-
/(^qa[\/-].*|.*-qa$)/
.gitlab/ci/frontend.gitlab-ci.yml
View file @
b881c772
.assets-compile-cache
:
&assets-compile-cache
.assets-compile-cache
:
cache
:
cache
:
key
:
"
assets-compile:vendor_ruby:.yarn-cache:tmp_cache_assets_sprockets:v6"
paths
:
paths
:
-
vendor/ruby/
-
vendor/ruby/
-
.yarn-cache/
-
.yarn-cache/
-
tmp/cache/assets/sprockets
-
tmp/cache/assets/sprockets
.use-pg
:
&use-pg
services
:
-
name
:
postgres:9.6.14
command
:
[
"
postgres"
,
"
-c"
,
"
fsync=off"
,
"
-c"
,
"
synchronous_commit=off"
,
"
-c"
,
"
full_page_writes=off"
]
-
name
:
redis:alpine
.gitlab:assets:compile-metadata:
.gitlab:assets:compile-metadata:
<<
:
*assets-compile-cache
extends
:
extends
:
.dedicated-no-docs-pull-cache-job
-
.default-tags
-
.default-retry
-
.assets-compile-cache
-
.default-before_script
-
.except-docs
image
:
dev.gitlab.org:5005/gitlab/gitlab-build-images:ruby-2.6.3-git-2.22-chrome-73.0-node-12.x-yarn-1.16-graphicsmagick-1.3.33-docker-18.06.1
image
:
dev.gitlab.org:5005/gitlab/gitlab-build-images:ruby-2.6.3-git-2.22-chrome-73.0-node-12.x-yarn-1.16-graphicsmagick-1.3.33-docker-18.06.1
dependencies
:
dependencies
:
[
"
setup-test-env"
]
-
setup-test-env
services
:
services
:
-
docker:19.03.0-dind
-
docker:19.03.0-dind
variables
:
variables
:
...
@@ -30,6 +26,14 @@
...
@@ -30,6 +26,14 @@
NODE_OPTIONS
:
--max_old_space_size=3584
NODE_OPTIONS
:
--max_old_space_size=3584
DOCKER_DRIVER
:
overlay2
DOCKER_DRIVER
:
overlay2
DOCKER_HOST
:
tcp://docker:2375
DOCKER_HOST
:
tcp://docker:2375
cache
:
key
:
"
assets-compile:production:vendor_ruby:.yarn-cache:tmp_cache_assets_sprockets:v6"
artifacts
:
name
:
webpack-report
expire_in
:
31d
paths
:
-
webpack-report/
-
public/assets/
script
:
script
:
-
node --version
-
node --version
-
retry yarn install --frozen-lockfile --production --cache-folder .yarn-cache --prefer-offline
-
retry yarn install --frozen-lockfile --production --cache-folder .yarn-cache --prefer-offline
...
@@ -42,43 +46,41 @@
...
@@ -42,43 +46,41 @@
-
install_api_client_dependencies_with_apt
-
install_api_client_dependencies_with_apt
-
play_job "review-build-cng" ||
true
# this job might not exist so ignore the failure if it cannot be played
-
play_job "review-build-cng" ||
true
# this job might not exist so ignore the failure if it cannot be played
-
play_job "schedule:review-build-cng" ||
true
# this job might not exist so ignore the failure if it cannot be played
-
play_job "schedule:review-build-cng" ||
true
# this job might not exist so ignore the failure if it cannot be played
artifacts
:
name
:
webpack-report
expire_in
:
31d
paths
:
-
webpack-report/
-
public/assets/
only
:
only
:
-
/.+/@gitlab-org/gitlab-ce
-
/.+/@gitlab-org/gitlab-ce
-
/.+/@gitlab-org/gitlab-ee
-
/.+/@gitlab-org/gitlab-ee
-
/.+/@gitlab/gitlabhq
-
/.+/@gitlab/gitlabhq
-
/.+/@gitlab/gitlab-ee
-
/.+/@gitlab/gitlab-ee
tags
:
tags
:
-
docker
-
gitlab-org
-
gitlab-org
-
docker
gitlab:assets:compile:
gitlab:assets:compile:
extends
:
.gitlab:assets:compile-metadata
extends
:
.gitlab:assets:compile-metadata
cache
:
policy
:
pull-push
only
:
only
:
refs
:
-
master@gitlab-org/gitlab-ce
-
master@gitlab-org/gitlab-ce
-
master@gitlab-org/gitlab-ee
-
master@gitlab-org/gitlab-ee
cache
:
policy
:
pull-push
gitlab:assets:compile pull-cache
:
gitlab:assets:compile pull-cache
:
extends
:
.gitlab:assets:compile-metadata
extends
:
.gitlab:assets:compile-metadata
cache
:
policy
:
pull
except
:
except
:
refs
:
refs
:
-
master@gitlab-org/gitlab-ce
-
master@gitlab-org/gitlab-ce
-
master@gitlab-org/gitlab-ee
-
master@gitlab-org/gitlab-ee
-
/(^docs[\/-].+|.+-docs$)/
-
/(^docs[\/-].+|.+-docs$)/
cache
:
policy
:
pull
.compile-assets-metadata
:
.compile-assets-metadata
:
extends
:
.dedicated-runner
extends
:
<<
:
*use-pg
-
.default-tags
<<
:
*assets-compile-cache
-
.default-retry
-
.assets-compile-cache
-
.default-before_script
-
.use-pg
stage
:
prepare
stage
:
prepare
script
:
script
:
-
node --version
-
node --version
...
@@ -89,6 +91,8 @@ gitlab:assets:compile pull-cache:
...
@@ -89,6 +91,8 @@ gitlab:assets:compile pull-cache:
variables
:
variables
:
# we override the max_old_space_size to prevent OOM errors
# we override the max_old_space_size to prevent OOM errors
NODE_OPTIONS
:
--max_old_space_size=3584
NODE_OPTIONS
:
--max_old_space_size=3584
cache
:
key
:
"
assets-compile:test:vendor_ruby:.yarn-cache:tmp_cache_assets_sprockets:v6"
artifacts
:
artifacts
:
expire_in
:
7d
expire_in
:
7d
paths
:
paths
:
...
@@ -96,30 +100,34 @@ gitlab:assets:compile pull-cache:
...
@@ -96,30 +100,34 @@ gitlab:assets:compile pull-cache:
-
public/assets
-
public/assets
compile-assets
:
compile-assets
:
extends
:
.compile-assets-metadata
extends
:
cache
:
-
.compile-assets-metadata
policy
:
pull-push
only
:
only
:
refs
:
-
master@gitlab-org/gitlab-ce
-
master@gitlab-org/gitlab-ce
-
master@gitlab-org/gitlab-ee
-
master@gitlab-org/gitlab-ee
cache
:
policy
:
pull-push
compile-assets pull-cache
:
compile-assets pull-cache
:
extends
:
.compile-assets-metadata
extends
:
.compile-assets-metadata
cache
:
policy
:
pull
except
:
except
:
refs
:
refs
:
-
master@gitlab-org/gitlab-ce
-
master@gitlab-org/gitlab-ce
-
master@gitlab-org/gitlab-ee
-
master@gitlab-org/gitlab-ee
-
/(^docs[\/-].+|.+-docs$)/
-
/(^docs[\/-].+|.+-docs$)/
cache
:
policy
:
pull
karma
:
karma
:
extends
:
.dedicated-no-docs-pull-cache-job
extends
:
<<
:
*use-pg
-
.default-tags
dependencies
:
-
.default-retry
-
compile-assets
-
.default-cache
-
compile-assets pull-cache
-
.default-before_script
-
setup-test-env
-
.use-pg
-
.except-docs
dependencies
:
[
"
compile-assets"
,
"
compile-assets
pull-cache"
,
"
setup-test-env"
]
variables
:
variables
:
# we override the max_old_space_size to prevent OOM errors
# we override the max_old_space_size to prevent OOM errors
NODE_OPTIONS
:
--max_old_space_size=3584
NODE_OPTIONS
:
--max_old_space_size=3584
...
@@ -142,12 +150,14 @@ karma:
...
@@ -142,12 +150,14 @@ karma:
junit
:
junit_karma.xml
junit
:
junit_karma.xml
jest
:
jest
:
extends
:
.dedicated-no-docs-and-no-qa-pull-cache-job
extends
:
<<
:
*use-pg
-
.default-tags
dependencies
:
-
.default-retry
-
compile-assets
-
.default-cache
-
compile-assets pull-cache
-
.default-before_script
-
setup-test-env
-
.use-pg
-
.except-docs-qa
dependencies
:
[
"
compile-assets"
,
"
compile-assets
pull-cache"
,
"
setup-test-env"
]
script
:
script
:
-
scripts/gitaly-test-spawn
-
scripts/gitaly-test-spawn
-
date
-
date
...
@@ -170,36 +180,41 @@ jest:
...
@@ -170,36 +180,41 @@ jest:
-
tmp/jest/jest/
-
tmp/jest/jest/
policy
:
pull-push
policy
:
pull-push
qa:internal:
.qa
:
extends
:
.dedicated-no-docs-no-db-pull-cache-job
extends
:
services
:
[]
-
.default-tags
script
:
-
.default-retry
-
.default-cache
-
.except-docs
dependencies
:
[
"
setup-test-env"
]
variables
:
SETUP_DB
:
"
false"
before_script
:
-
cd qa/
-
cd qa/
-
bundle install
-
bundle install
qa:internal:
extends
:
.qa
script
:
-
bundle exec rspec
-
bundle exec rspec
dependencies
:
-
setup-test-env
qa:selectors:
qa:selectors:
extends
:
.dedicated-no-docs-no-db-pull-cache-job
extends
:
.qa
services
:
[]
script
:
script
:
-
cd qa/
-
bundle install
-
bundle exec bin/qa Test::Sanity::Selectors
-
bundle exec bin/qa Test::Sanity::Selectors
dependencies
:
-
setup-test-env
.qa-frontend-node
:
&qa-frontend-node
.qa-frontend-node
:
extends
:
.dedicated-no-docs-no-db-pull-cache-job
extends
:
stage
:
test
-
.default-tags
-
.default-retry
-
.default-cache
-
.except-docs
dependencies
:
[]
cache
:
cache
:
key
:
"
$CI_JOB_NAME"
key
:
"
$CI_JOB_NAME"
paths
:
paths
:
-
.yarn-cache/
-
.yarn-cache/
policy
:
pull-push
policy
:
pull-push
dependencies
:
[]
before_script
:
[]
script
:
script
:
-
date
-
date
-
yarn install --frozen-lockfile --cache-folder .yarn-cache --prefer-offline
-
yarn install --frozen-lockfile --cache-folder .yarn-cache --prefer-offline
...
@@ -207,23 +222,28 @@ qa:selectors:
...
@@ -207,23 +222,28 @@ qa:selectors:
-
yarn run webpack-prod
-
yarn run webpack-prod
qa-frontend-node:8:
qa-frontend-node:8:
<<
:
*
qa-frontend-node
extends
:
.
qa-frontend-node
image
:
node:carbon
image
:
node:carbon
qa-frontend-node:10:
qa-frontend-node:10:
<<
:
*
qa-frontend-node
extends
:
.
qa-frontend-node
image
:
node:dubnium
image
:
node:dubnium
qa-frontend-node:latest:
qa-frontend-node:latest:
<<
:
*
qa-frontend-node
extends
:
.
qa-frontend-node
image
:
node:latest
image
:
node:latest
allow_failure
:
true
allow_failure
:
true
lint:javascript:report:
lint:javascript:report:
extends
:
.dedicated-no-docs-no-db-pull-cache-job
extends
:
-
.default-tags
-
.default-retry
-
.default-cache
-
.except-docs
variables
:
SETUP_DB
:
"
false"
stage
:
post-test
stage
:
post-test
dependencies
:
[]
dependencies
:
[]
before_script
:
[]
script
:
script
:
-
date
-
date
-
yarn run eslint-report ||
true
# ignore exit code
-
yarn run eslint-report ||
true
# ignore exit code
...
@@ -234,12 +254,15 @@ lint:javascript:report:
...
@@ -234,12 +254,15 @@ lint:javascript:report:
-
eslint-report.html
-
eslint-report.html
jsdoc
:
jsdoc
:
extends
:
.dedicated-no-docs-no-db-pull-cache-job
extends
:
-
.default-tags
-
.default-retry
-
.default-cache
-
.except-docs
variables
:
SETUP_DB
:
"
false"
stage
:
post-test
stage
:
post-test
dependencies
:
dependencies
:
[
"
compile-assets"
,
"
compile-assets
pull-cache"
]
-
compile-assets
-
compile-assets pull-cache
before_script
:
[]
script
:
script
:
-
date
-
date
-
yarn run jsdoc ||
true
# ignore exit code
-
yarn run jsdoc ||
true
# ignore exit code
...
...
.gitlab/ci/global.gitlab-ci.yml
View file @
b881c772
.dedicated-runner
:
.default-tags
:
tags
:
-
gitlab-org
.default-retry
:
retry
:
retry
:
max
:
2
# This is confusing but this means "3 runs at max".
max
:
2
# This is confusing but this means "3 runs at max".
when
:
when
:
-
unknown_failure
-
unknown_failure
-
api_failure
-
api_failure
-
runner_system_failure
-
runner_system_failure
tags
:
-
gitlab-org
.default-cache
:
&default-cache
.default-before_script
:
before_script
:
-
date
-
source scripts/utils.sh
-
source scripts/prepare_build.sh
-
date
# Jobs that only need to pull cache
.default-cache
:
cache
:
key
:
"
debian-stretch-ruby-2.6.3-node-12.x"
key
:
"
debian-stretch-ruby-2.6.3-node-12.x"
paths
:
paths
:
-
vendor/ruby
-
vendor/ruby
-
.yarn-cache/
-
.yarn-cache/
-
vendor/gitaly-ruby
-
vendor/gitaly-ruby
.dedicated-runner-default-cache
:
extends
:
.dedicated-runner
cache
:
<<
:
*default-cache
# Jobs that only need to pull cache
.dedicated-pull-cache-job
:
extends
:
.dedicated-runner
cache
:
<<
:
*default-cache
policy
:
pull
policy
:
pull
stage
:
test
.
no
-docs
:
.
except
-docs
:
except
:
except
:
refs
:
refs
:
-
/(^docs[\/-].+|.+-docs$)/
-
/(^docs[\/-].+|.+-docs$)/
.
no-docs-and-no
-qa
:
.
except
-qa
:
except
:
except
:
refs
:
refs
:
-
/(^docs[\/-].+|.+-docs$)/
-
/(^qa[\/-].*|.*-qa$)/
-
/(^qa[\/-].*|.*-qa$)/
.dedicated-no-docs-pull-cache-job
:
.except-docs-qa
:
extends
:
except
:
-
.dedicated-pull-cache-job
refs
:
-
.no-docs
-
/(^docs[\/-].+|.+-docs$)/
-
/(^qa[\/-].*|.*-qa$)/
.dedicated-no-docs-and-no-qa-pull-cache-job
:
extends
:
-
.dedicated-pull-cache-job
-
.no-docs-and-no-qa
# Jobs that do not need a DB
.dedicated-no-docs-no-db-pull-cache-job
:
extends
:
.dedicated-no-docs-pull-cache-job
variables
:
SETUP_DB
:
"
false"
# Jobs that need a dedicated runner, with no cache
.dedicated-no-docs
:
extends
:
-
.dedicated-runner
-
.no-docs
.single-script-job-dedicated-runner
:
.except-docs-qa-geo
:
extends
:
.dedicated-runner
except
:
image
:
ruby:2.6-alpine
refs
:
stage
:
test
-
/(^docs[\/-].+|.+-docs$)/
cache
:
{}
-
/(^qa[\/-].*|.*-qa$)/
dependencies
:
[]
-
/(^geo[\/-].*|.*-geo$)/
variables
:
GIT_STRATEGY
:
none
before_script
:
# We don't clone the repo by using GIT_STRATEGY: none and only download the
# single script we need here so it's much faster than cloning.
-
export SCRIPT_NAME="${SCRIPT_NAME:-$CI_JOB_NAME}"
-
apk add --update openssl
-
wget $CI_PROJECT_URL/raw/$CI_COMMIT_SHA/scripts/$SCRIPT_NAME
-
chmod 755 $(basename $SCRIPT_NAME)
.review-only
:
&review-only
.review-only
:
only
:
only
:
refs
:
refs
:
-
branches@gitlab-org/gitlab-ce
-
branches@gitlab-org/gitlab-ce
...
@@ -88,3 +61,16 @@
...
@@ -88,3 +61,16 @@
-
master
-
master
-
/^\d+-\d+-auto-deploy-\d+$/
-
/^\d+-\d+-auto-deploy-\d+$/
-
/(^docs[\/-].+|.+-docs$)/
-
/(^docs[\/-].+|.+-docs$)/
.use-pg
:
services
:
-
name
:
postgres:9.6.14
command
:
[
"
postgres"
,
"
-c"
,
"
fsync=off"
,
"
-c"
,
"
synchronous_commit=off"
,
"
-c"
,
"
full_page_writes=off"
]
-
name
:
redis:alpine
.use-pg-10
:
image
:
"
dev.gitlab.org:5005/gitlab/gitlab-build-images:ruby-2.6.3-golang-1.11-git-2.22-chrome-73.0-node-12.x-yarn-1.16-postgresql-10-graphicsmagick-1.3.33"
services
:
-
name
:
postgres:10.9
command
:
[
"
postgres"
,
"
-c"
,
"
fsync=off"
,
"
-c"
,
"
synchronous_commit=off"
,
"
-c"
,
"
full_page_writes=off"
]
-
name
:
redis:alpine
.gitlab/ci/memory.gitlab-ci.yml
View file @
b881c772
memory-static
:
memory-static
:
extends
:
.dedicated-no-docs-no-db-pull-cache-job
extends
:
-
.default-tags
-
.default-retry
-
.default-cache
-
.default-before_script
-
.except-docs
variables
:
SETUP_DB
:
"
false"
script
:
script
:
# Uses two different reports from the 'derailed_benchmars' gem.
# Uses two different reports from the 'derailed_benchmars' gem.
...
@@ -23,7 +30,13 @@ memory-static:
...
@@ -23,7 +30,13 @@ memory-static:
# The application is booted in `production` environment.
# The application is booted in `production` environment.
# All tests are run without a webserver (directly using Rack::Mock by default).
# All tests are run without a webserver (directly using Rack::Mock by default).
memory-on-boot
:
memory-on-boot
:
extends
:
.rspec-metadata-pg-10
extends
:
-
.default-tags
-
.default-retry
-
.default-cache
-
.default-before_script
-
.use-pg-10
-
.except-docs-qa
variables
:
variables
:
NODE_ENV
:
"
production"
NODE_ENV
:
"
production"
RAILS_ENV
:
"
production"
RAILS_ENV
:
"
production"
...
...
.gitlab/ci/pages.gitlab-ci.yml
View file @
b881c772
pages
:
pages
:
extends
:
.dedicated-no-docs-no-db-pull-cache-job
extends
:
before_script
:
[]
-
.default-tags
-
.default-retry
-
.default-cache
-
.except-docs
only
:
refs
:
-
master@gitlab-org/gitlab-ce
-
master@gitlab-org/gitlab-ee
stage
:
pages
stage
:
pages
dependencies
:
dependencies
:
[
"
coverage"
,
"
karma"
,
"
gitlab:assets:compile"
,
"
lint:javascript:report"
,
"
jsdoc"
]
-
coverage
-
karma
-
gitlab:assets:compile
-
lint:javascript:report
-
jsdoc
script
:
script
:
-
mv public/ .public/
-
mv public/ .public/
-
mkdir public/
-
mkdir public/
...
@@ -21,6 +23,3 @@ pages:
...
@@ -21,6 +23,3 @@ pages:
artifacts
:
artifacts
:
paths
:
paths
:
-
public
-
public
only
:
-
master@gitlab-org/gitlab-ce
-
master@gitlab-org/gitlab-ee
.gitlab/ci/qa.gitlab-ci.yml
View file @
b881c772
.package-and-qa-base
:
.package-and-qa-base
:
image
:
ruby:2.6-alpine
image
:
ruby:2.6-alpine
stage
:
qa
stage
:
qa
before_script
:
[]
needs
:
[
"
build-qa-image"
,
"
gitlab:assets:compile
pull-cache"
]
needs
:
[
"
build-qa-image"
,
"
gitlab:assets:compile
pull-cache"
]
dependencies
:
[]
dependencies
:
[]
cache
:
{}
variables
:
variables
:
GIT_DEPTH
:
"
1"
GIT_DEPTH
:
"
1"
retry
:
0
retry
:
0
...
@@ -19,7 +17,9 @@
...
@@ -19,7 +17,9 @@
-
master
-
master
package-and-qa-manual
:
package-and-qa-manual
:
extends
:
.package-and-qa-base
extends
:
-
.package-and-qa-base
-
.except-docs-qa
when
:
manual
when
:
manual
except
:
except
:
-
master
-
master
...
...
.gitlab/ci/rails.gitlab-ci.yml
View file @
b881c772
.use-pg
:
&use-pg
.only-schedules-master
:
services
:
-
name
:
postgres:9.6.14
command
:
[
"
postgres"
,
"
-c"
,
"
fsync=off"
,
"
-c"
,
"
synchronous_commit=off"
,
"
-c"
,
"
full_page_writes=off"
]
-
name
:
redis:alpine
.use-pg-10
:
&use-pg-10
services
:
-
name
:
postgres:10.9
command
:
[
"
postgres"
,
"
-c"
,
"
fsync=off"
,
"
-c"
,
"
synchronous_commit=off"
,
"
-c"
,
"
full_page_writes=off"
]
-
name
:
redis:alpine
.only-schedules-master
:
&only-schedules-master
only
:
only
:
refs
:
-
schedules@gitlab-org/gitlab-ce
-
schedules@gitlab-org/gitlab-ce
-
schedules@gitlab-org/gitlab-ee
-
schedules@gitlab-org/gitlab-ee
-
master@gitlab-org/gitlab-ce
-
master@gitlab-org/gitlab-ce
...
@@ -19,34 +8,24 @@
...
@@ -19,34 +8,24 @@
-
master@gitlab/gitlabhq
-
master@gitlab/gitlabhq
-
master@gitlab/gitlab-ee
-
master@gitlab/gitlab-ee
.
gitlab-setup
:
&gitlab-setup
.
rake-exec
:
extends
:
extends
:
-
.dedicated-no-docs-and-no-qa-pull-cache-job
-
.default-tags
-
.use-pg
-
.default-retry
-
.default-cache
-
.default-before_script
variables
:
variables
:
SETUP_DB
:
"
false"
SETUP_DB
:
"
false"
script
:
# Manually clone gitlab-test and only seed this project in
# db/fixtures/development/04_project.rb thanks to SIZE=1 below
-
git clone https://gitlab.com/gitlab-org/gitlab-test.git
/home/git/repositories/gitlab-org/gitlab-test.git
-
scripts/gitaly-test-spawn
-
force=yes SIZE=1 FIXTURE_PATH="db/fixtures/development" bundle exec rake gitlab:setup
artifacts
:
when
:
on_failure
expire_in
:
1d
paths
:
-
log/development.log
.rake-exec
:
&rake-exec
extends
:
.dedicated-no-docs-no-db-pull-cache-job
script
:
script
:
-
bundle exec rake $CI_JOB_NAME
-
bundle exec rake $CI_JOB_NAME
.rspec-
metadata
:
&rspec-metadata
.rspec-
base
:
extends
:
extends
:
-
.dedicated-pull-cache-job
-
.default-tags
-
.no-docs-and-no-qa
-
.default-retry
-
.default-cache
-
.default-before_script
-
.except-docs-qa
stage
:
test
stage
:
test
script
:
script
:
-
JOB_NAME=( $CI_JOB_NAME )
-
JOB_NAME=( $CI_JOB_NAME )
...
@@ -83,52 +62,24 @@
...
@@ -83,52 +62,24 @@
reports
:
reports
:
junit
:
junit_rspec.xml
junit
:
junit_rspec.xml
.rspec-metadata-pg
:
&rspec-metadata-pg
.rspec-base-pg
:
<<
:
*rspec-metadata
extends
:
<<
:
*use-pg
-
.rspec-base
-
.use-pg
.rspec-metadata-pg-10
:
&rspec-metadata-pg-10
<<
:
*rspec-metadata
<<
:
*use-pg-10
image
:
"
dev.gitlab.org:5005/gitlab/gitlab-build-images:ruby-2.6.3-golang-1.11-git-2.22-chrome-73.0-node-12.x-yarn-1.16-postgresql-10-graphicsmagick-1.3.33"
# DB migration, rollback, and seed jobs
.db-migrate-reset
:
&db-migrate-reset
extends
:
.dedicated-no-docs-and-no-qa-pull-cache-job
script
:
-
bundle exec rake db:migrate:reset
dependencies
:
-
setup-test-env
.migration-paths
:
&migration-paths
.rspec-base-pg-10
:
extends
:
.dedicated-no-docs-and-no-qa-pull-cache-job
extends
:
variables
:
-
.rspec-base
SETUP_DB
:
"
false"
-
.use-pg-10
script
:
-
git fetch https://gitlab.com/gitlab-org/gitlab-ce.git v11.11.0
-
git checkout -f FETCH_HEAD
-
sed -i "s/gem 'oj', '~> 2.17.4'//" Gemfile
-
sed -i "s/gem 'bootsnap', '~> 1.0.0'/gem 'bootsnap'/" Gemfile
-
bundle update google-protobuf grpc bootsnap
-
bundle install $BUNDLE_INSTALL_FLAGS
-
date
-
cp config/gitlab.yml.example config/gitlab.yml
-
bundle exec rake db:drop db:create db:schema:load db:seed_fu
-
date
-
git checkout -f $CI_COMMIT_SHA
-
bundle install $BUNDLE_INSTALL_FLAGS
-
date
-
. scripts/prepare_build.sh
-
date
-
bundle exec rake db:migrate
dependencies
:
-
setup-test-env
setup-test-env
:
setup-test-env
:
extends
:
extends
:
-
.dedicated-runner-default-cache
-
.default-tags
-
.no-docs
-
.default-retry
-
.default-cache
-
.default-before_script
-
.use-pg
-
.use-pg
-
.except-docs
stage
:
prepare
stage
:
prepare
script
:
script
:
-
bundle exec ruby -Ispec -e 'require "spec_helper" ; TestEnv.init'
-
bundle exec ruby -Ispec -e 'require "spec_helper" ; TestEnv.init'
...
@@ -141,67 +92,72 @@ setup-test-env:
...
@@ -141,67 +92,72 @@ setup-test-env:
-
vendor/gitaly-ruby
-
vendor/gitaly-ruby
rspec unit pg
:
rspec unit pg
:
<<
:
*rspec-metadata
-pg
extends
:
.rspec-base
-pg
parallel
:
20
parallel
:
20
rspec integration pg
:
rspec integration pg
:
<<
:
*rspec-metadata
-pg
extends
:
.rspec-base
-pg
parallel
:
6
parallel
:
6
rspec system pg
:
rspec system pg
:
<<
:
*rspec-metadata
-pg
extends
:
.rspec-base
-pg
parallel
:
24
parallel
:
24
rspec unit pg-10
:
rspec unit pg-10
:
<<
:
*rspec-metadata-pg-10
extends
:
<<
:
*only-schedules-master
-
.rspec-base-pg-10
-
.only-schedules-master
parallel
:
20
parallel
:
20
rspec integration pg-10
:
rspec integration pg-10
:
<<
:
*rspec-metadata-pg-10
extends
:
<<
:
*only-schedules-master
-
.rspec-base-pg-10
-
.only-schedules-master
parallel
:
6
parallel
:
6
rspec system pg-10
:
rspec system pg-10
:
<<
:
*rspec-metadata-pg-10
extends
:
<<
:
*only-schedules-master
-
.rspec-base-pg-10
-
.only-schedules-master
parallel
:
24
parallel
:
24
rspec-fast-spec-helper
:
rspec-fast-spec-helper
:
<<
:
*rspec-metadata
-pg
extends
:
.rspec-base
-pg
script
:
script
:
-
bundle exec rspec spec/fast_spec_helper.rb
-
bundle exec rspec spec/fast_spec_helper.rb
.rspec-quarantine
:
&rspec-quarantine
rspec quarantine pg
:
<<
:
*only-schedules-master
extends
:
-
.default-before_script
-
.rspec-base-pg
-
.only-schedules-master
script
:
script
:
-
export CACHE_CLASSES=true
-
export
NO_KNAPSACK=1
CACHE_CLASSES=true
-
scripts/gitaly-test-spawn
-
scripts/gitaly-test-spawn
-
bin/rspec --color --format documentation --tag quarantine -- spec/
-
bin/rspec --color --format documentation --tag quarantine -- spec/
rspec quarantine pg
:
<<
:
*rspec-metadata-pg
<<
:
*rspec-quarantine
allow_failure
:
true
allow_failure
:
true
static-analysis
:
static-analysis
:
extends
:
.dedicated-no-docs-no-db-pull-cache-job
extends
:
dependencies
:
-
.default-tags
-
compile-assets
-
.default-retry
-
compile-assets pull-cache
-
.default-cache
-
setup-test-env
-
.default-before_script
-
.except-docs
dependencies
:
[
"
setup-test-env"
,
"
compile-assets"
,
"
compile-assets
pull-cache"
]
variables
:
SETUP_DB
:
"
false"
script
:
script
:
-
scripts/static-analysis
-
scripts/static-analysis
cache
:
cache
:
key
:
"
debian-stretch-ruby-2.6.3-
node-12.x-
and-rubocop"
key
:
"
debian-stretch-ruby-2.6.3-and-rubocop"
paths
:
paths
:
-
vendor/ruby
-
vendor/ruby
-
.yarn-cache/
-
tmp/rubocop_cache
-
tmp/rubocop_cache
policy
:
pull-push
policy
:
pull-push
downtime_check
:
downtime_check
:
<<
:
*
rake-exec
extends
:
.
rake-exec
except
:
except
:
refs
:
refs
:
-
master
-
master
...
@@ -209,22 +165,20 @@ downtime_check:
...
@@ -209,22 +165,20 @@ downtime_check:
-
/^[\d-]+-stable(-ee)?$/
-
/^[\d-]+-stable(-ee)?$/
-
/(^docs[\/-].+|.+-docs$)/
-
/(^docs[\/-].+|.+-docs$)/
-
/(^qa[\/-].*|.*-qa$)/
-
/(^qa[\/-].*|.*-qa$)/
dependencies
:
dependencies
:
[
"
setup-test-env"
]
-
setup-test-env
ee_compat_check
:
ee_compat_check
:
<<
:
*
rake-exec
extends
:
.
rake-exec
dependencies
:
[]
dependencies
:
[]
except
:
except
:
refs
:
refs
:
-
master
-
master
-
tags
-
tags
-
/[\d-]+-stable(-ee)?/
-
/^security-/
-
branches@gitlab-org/gitlab-ee
-
branches@gitlab-org/gitlab-ee
-
branches@gitlab/gitlab-ee
-
branches@gitlab/gitlab-ee
-
/^[\d-]+-stable(-ee)?$/
-
/(^docs[\/-].+|.+-docs$)/
-
/(^docs[\/-].+|.+-docs$)/
retry
:
0
-
/^security-/
artifacts
:
artifacts
:
name
:
"
${CI_JOB_NAME}_${CI_COMIT_REF_NAME}_${CI_COMMIT_SHA}"
name
:
"
${CI_JOB_NAME}_${CI_COMIT_REF_NAME}_${CI_COMMIT_SHA}"
when
:
always
when
:
always
...
@@ -232,44 +186,106 @@ ee_compat_check:
...
@@ -232,44 +186,106 @@ ee_compat_check:
paths
:
paths
:
-
ee_compat_check/patches/*.patch
-
ee_compat_check/patches/*.patch
db:migrate:reset-pg:
# DB migration, rollback, and seed jobs
<<
:
*db-migrate-reset
db:migrate:reset:
<<
:
*use-pg
extends
:
-
.default-tags
-
.default-retry
-
.default-cache
-
.default-before_script
-
.use-pg
-
.except-docs-qa
dependencies
:
[
"
setup-test-env"
]
script
:
-
bundle exec rake db:migrate:reset
db:check-schema-pg:
db:check-schema:
<<
:
*db-migrate-reset
extends
:
<<
:
*use-pg
-
.default-tags
-
.default-retry
-
.default-cache
-
.default-before_script
-
.use-pg
-
.except-docs-qa
dependencies
:
[
"
setup-test-env"
]
script
:
script
:
-
source scripts/schema_changed.sh
-
source scripts/schema_changed.sh
migration:path-pg:
db:migrate-from-v11.11.0:
<<
:
*migration-paths
extends
:
<<
:
*use-pg
-
.default-tags
-
.default-retry
-
.default-cache
-
.default-before_script
-
.use-pg
-
.except-docs-qa
dependencies
:
[
"
setup-test-env"
]
variables
:
SETUP_DB
:
"
false"
script
:
-
git fetch https://gitlab.com/gitlab-org/gitlab-ce.git v11.11.0
-
git checkout -f FETCH_HEAD
-
sed -i "s/gem 'oj', '~> 2.17.4'//" Gemfile
-
sed -i "s/gem 'bootsnap', '~> 1.0.0'/gem 'bootsnap'/" Gemfile
-
bundle update google-protobuf grpc bootsnap
-
bundle install $BUNDLE_INSTALL_FLAGS
-
date
-
cp config/gitlab.yml.example config/gitlab.yml
-
bundle exec rake db:drop db:create db:schema:load db:seed_fu
-
date
-
git checkout -f $CI_COMMIT_SHA
-
bundle install $BUNDLE_INSTALL_FLAGS
-
date
-
. scripts/prepare_build.sh
-
date
-
bundle exec rake db:migrate
.db-rollback
:
&db-rollback
db:rollback:
extends
:
.dedicated-no-docs-and-no-qa-pull-cache-job
extends
:
-
.default-tags
-
.default-retry
-
.default-cache
-
.default-before_script
-
.use-pg
-
.except-docs-qa
dependencies
:
[
"
setup-test-env"
]
script
:
script
:
-
bundle exec rake db:migrate VERSION=20180101160629
-
bundle exec rake db:migrate VERSION=20180101160629
-
bundle exec rake db:migrate SKIP_SCHEMA_VERSION_CHECK=true
-
bundle exec rake db:migrate SKIP_SCHEMA_VERSION_CHECK=true
dependencies
:
-
setup-test-env
db:rollback-pg:
<<
:
*db-rollback
<<
:
*use-pg
gitlab:setup-pg:
gitlab:setup:
<<
:
*gitlab-setup
extends
:
<<
:
*use-pg
-
.default-tags
dependencies
:
-
.default-retry
-
setup-test-env
-
.default-cache
-
.default-before_script
-
.use-pg
-
.except-docs-qa
dependencies
:
[
"
setup-test-env"
]
variables
:
SETUP_DB
:
"
false"
script
:
# Manually clone gitlab-test and only seed this project in
# db/fixtures/development/04_project.rb thanks to SIZE=1 below
-
git clone https://gitlab.com/gitlab-org/gitlab-test.git
/home/git/repositories/gitlab-org/gitlab-test.git
-
scripts/gitaly-test-spawn
-
force=yes SIZE=1 FIXTURE_PATH="db/fixtures/development" bundle exec rake gitlab:setup
artifacts
:
when
:
on_failure
expire_in
:
1d
paths
:
-
log/development.log
coverage
:
coverage
:
# Don't include dedicated-no-docs-no-db-pull-cache-job here since we need to
# Don't include dedicated-no-docs-no-db-pull-cache-job here since we need to
# download artifacts from all the rspec jobs instead of from setup-test-env only
# download artifacts from all the rspec jobs instead of from setup-test-env only
extends
:
extends
:
-
.dedicated-runner-default-cache
-
.default-tags
-
.no-docs-and-no-qa
-
.default-retry
-
.default-cache
-
.default-before_script
-
.except-docs-qa
cache
:
cache
:
policy
:
pull
policy
:
pull
variables
:
variables
:
...
...
.gitlab/ci/reports.gitlab-ci.yml
View file @
b881c772
...
@@ -4,36 +4,29 @@ include:
...
@@ -4,36 +4,29 @@ include:
-
template
:
Security/Dependency-Scanning.gitlab-ci.yml
-
template
:
Security/Dependency-Scanning.gitlab-ci.yml
-
template
:
Security/DAST.gitlab-ci.yml
-
template
:
Security/DAST.gitlab-ci.yml
.reports
:
extends
:
-
.default-retry
-
.except-docs
tags
:
-
gitlab-org
-
docker
code_quality
:
code_quality
:
extends
:
.dedicated-no-docs
extends
:
.reports
# gitlab-org runners set `privileged: false` but we need to have it set to true
# since we're using Docker in Docker
tags
:
[]
before_script
:
[]
cache
:
{}
sast
:
sast
:
extends
:
.dedicated-no-docs
extends
:
.reports
tags
:
[]
before_script
:
[]
cache
:
{}
variables
:
variables
:
SAST_BRAKEMAN_LEVEL
:
2
SAST_BRAKEMAN_LEVEL
:
2
SAST_EXCLUDED_PATHS
:
qa,spec,doc
SAST_EXCLUDED_PATHS
:
qa,spec,doc
dependency_scanning
:
dependency_scanning
:
extends
:
.dedicated-no-docs
extends
:
.reports
tags
:
[]
before_script
:
[]
cache
:
{}
dast
:
dast
:
extends
:
extends
:
.reports
-
.dedicated-runner
-
.review-only
stage
:
qa
stage
:
qa
dependencies
:
dependencies
:
[
"
review-deploy"
]
-
review-deploy
before_script
:
before_script
:
-
export DAST_WEBSITE="$(cat review_app_url.txt)"
-
export DAST_WEBSITE="$(cat review_app_url.txt)"
cache
:
{}
.gitlab/ci/review.gitlab-ci.yml
View file @
b881c772
.review-schedules-only
:
&review-schedules-only
.review-schedules-only
:
only
:
only
:
refs
:
refs
:
-
schedules@gitlab-org/gitlab-ce
-
schedules@gitlab-org/gitlab-ce
...
@@ -11,39 +11,39 @@
...
@@ -11,39 +11,39 @@
-
tags
-
tags
-
/(^docs[\/-].+|.+-docs$)/
-
/(^docs[\/-].+|.+-docs$)/
.review-base
:
&review-base
.review-base
:
extends
:
extends
:
-
.dedicated-runner
-
.default-tags
-
.default-retry
-
.review-only
-
.review-only
image
:
registry.gitlab.com/gitlab-org/gitlab-build-images:gitlab-charts-build-base
image
:
registry.gitlab.com/gitlab-org/gitlab-build-images:gitlab-charts-build-base
cache
:
{}
dependencies
:
[]
dependencies
:
[]
before_script
:
before_script
:
-
source scripts/utils.sh
-
source scripts/utils.sh
.review-docker
:
&review-docker
.review-docker
:
<<
:
*
review-base
extends
:
.
review-base
image
:
registry.gitlab.com/gitlab-org/gitlab-build-images:gitlab-qa-alpine
image
:
registry.gitlab.com/gitlab-org/gitlab-build-images:gitlab-qa-alpine
services
:
services
:
-
docker:19.03.0-dind
-
docker:19.03.0-dind
tags
:
tags
:
-
gitlab-org
-
gitlab-org
-
docker
-
docker
variables
:
&review-docker-variables
variables
:
DOCKER_DRIVER
:
overlay2
DOCKER_DRIVER
:
overlay2
DOCKER_HOST
:
tcp://docker:2375
DOCKER_HOST
:
tcp://docker:2375
LATEST_QA_IMAGE
:
"
gitlab/${CI_PROJECT_NAME}-qa:nightly"
LATEST_QA_IMAGE
:
"
gitlab/${CI_PROJECT_NAME}-qa:nightly"
QA_IMAGE
:
"
${CI_REGISTRY}/${CI_PROJECT_PATH}/gitlab/${CI_PROJECT_NAME}-qa:${CI_COMMIT_REF_SLUG}"
QA_IMAGE
:
"
${CI_REGISTRY}/${CI_PROJECT_PATH}/gitlab/${CI_PROJECT_NAME}-qa:${CI_COMMIT_REF_SLUG}"
build-qa-image
:
build-qa-image
:
<<
:
*
review-docker
extends
:
.
review-docker
stage
:
test
stage
:
test
script
:
script
:
-
time docker build --cache-from ${LATEST_QA_IMAGE} --tag ${QA_IMAGE} --file ./qa/Dockerfile ./
-
time docker build --cache-from ${LATEST_QA_IMAGE} --tag ${QA_IMAGE} --file ./qa/Dockerfile ./
-
echo "${CI_JOB_TOKEN}" | docker login --username gitlab-ci-token --password-stdin ${CI_REGISTRY}
-
echo "${CI_JOB_TOKEN}" | docker login --username gitlab-ci-token --password-stdin ${CI_REGISTRY}
-
time docker push ${QA_IMAGE}
-
time docker push ${QA_IMAGE}
.review-build-cng-base
:
&review-build-cng-base
.review-build-cng-base
:
image
:
ruby:2.6-alpine
image
:
ruby:2.6-alpine
stage
:
test
stage
:
test
when
:
manual
when
:
manual
...
@@ -52,20 +52,21 @@ build-qa-image:
...
@@ -52,20 +52,21 @@ build-qa-image:
-
install_api_client_dependencies_with_apk
-
install_api_client_dependencies_with_apk
-
install_gitlab_gem
-
install_gitlab_gem
dependencies
:
[]
dependencies
:
[]
cache
:
{}
script
:
script
:
-
BUILD_TRIGGER_TOKEN=$REVIEW_APPS_BUILD_TRIGGER_TOKEN ./scripts/trigger-build cng
-
BUILD_TRIGGER_TOKEN=$REVIEW_APPS_BUILD_TRIGGER_TOKEN ./scripts/trigger-build cng
review-build-cng
:
review-build-cng
:
extends
:
.review-only
extends
:
<<
:
*review-build-cng-base
-
.review-build-cng-base
-
.review-only
schedule:review-build-cng:
schedule:review-build-cng:
<<
:
*review-schedules-only
extends
:
<<
:
*review-build-cng-base
-
.review-build-cng-base
-
.review-schedules-only
.review-deploy-base
:
&review-deploy-base
review-deploy
:
<<
:
*
review-base
extends
:
.
review-base
allow_failure
:
true
allow_failure
:
true
retry
:
1
retry
:
1
stage
:
review
stage
:
review
...
@@ -73,7 +74,7 @@ schedule:review-build-cng:
...
@@ -73,7 +74,7 @@ schedule:review-build-cng:
HOST_SUFFIX
:
"
${CI_ENVIRONMENT_SLUG}"
HOST_SUFFIX
:
"
${CI_ENVIRONMENT_SLUG}"
DOMAIN
:
"
-${CI_ENVIRONMENT_SLUG}.${REVIEW_APPS_DOMAIN}"
DOMAIN
:
"
-${CI_ENVIRONMENT_SLUG}.${REVIEW_APPS_DOMAIN}"
GITLAB_HELM_CHART_REF
:
"
master"
GITLAB_HELM_CHART_REF
:
"
master"
environment
:
&review-environment
environment
:
name
:
review/${CI_COMMIT_REF_NAME}
name
:
review/${CI_COMMIT_REF_NAME}
url
:
https://gitlab-${CI_ENVIRONMENT_SLUG}.${REVIEW_APPS_DOMAIN}
url
:
https://gitlab-${CI_ENVIRONMENT_SLUG}.${REVIEW_APPS_DOMAIN}
on_stop
:
review-stop
on_stop
:
review-stop
...
@@ -98,50 +99,45 @@ schedule:review-build-cng:
...
@@ -98,50 +99,45 @@ schedule:review-build-cng:
expire_in
:
2 days
expire_in
:
2 days
when
:
always
when
:
always
review-deploy
:
<<
:
*review-deploy-base
schedule:review-deploy:
schedule:review-deploy:
<<
:
*review-deploy-base
extends
:
<<
:
*review-schedules-only
-
review-deploy
-
.review-schedules-only
review-stop
:
review-stop
:
extends
:
extends
:
review-deploy
-
.single-script-job-dedicated-runner
-
.review-only
image
:
registry.gitlab.com/gitlab-org/gitlab-build-images:gitlab-charts-build-base
stage
:
review
when
:
manual
when
:
manual
allow_failure
:
true
variables
:
SCRIPT_NAME
:
review_apps/review-apps.sh
environment
:
environment
:
<<
:
*review-environment
action
:
stop
action
:
stop
script
:
variables
:
GIT_STRATEGY
:
none
before_script
:
# We don't clone the repo by using GIT_STRATEGY: none and only download the
# single script we need here so it's much faster than cloning.
-
apk add --update openssl
-
wget $CI_PROJECT_URL/raw/$CI_COMMIT_SHA/scripts/review_apps/review-apps.sh
-
wget $CI_PROJECT_URL/raw/$CI_COMMIT_SHA/scripts/utils.sh
-
wget $CI_PROJECT_URL/raw/$CI_COMMIT_SHA/scripts/utils.sh
-
source utils.sh
-
source utils.sh
-
source $(basename $SCRIPT_NAME)
-
source review-apps.sh
script
:
-
delete
-
delete
artifacts
:
{}
.review-qa-base
:
&review-qa-base
.review-qa-base
:
<<
:
*review-docker
extends
:
.review-docker
allow_failure
:
true
retry
:
2
retry
:
2
stage
:
qa
stage
:
qa
variables
:
variables
:
<<
:
*review-docker-variables
QA_ARTIFACTS_DIR
:
"
${CI_PROJECT_DIR}/qa"
QA_ARTIFACTS_DIR
:
"
${CI_PROJECT_DIR}/qa"
QA_CAN_TEST_GIT_PROTOCOL_V2
:
"
false"
QA_CAN_TEST_GIT_PROTOCOL_V2
:
"
false"
QA_DEBUG
:
"
true"
GITLAB_USERNAME
:
"
root"
GITLAB_USERNAME
:
"
root"
GITLAB_PASSWORD
:
"
${REVIEW_APPS_ROOT_PASSWORD}"
GITLAB_PASSWORD
:
"
${REVIEW_APPS_ROOT_PASSWORD}"
GITLAB_ADMIN_USERNAME
:
"
root"
GITLAB_ADMIN_USERNAME
:
"
root"
GITLAB_ADMIN_PASSWORD
:
"
${REVIEW_APPS_ROOT_PASSWORD}"
GITLAB_ADMIN_PASSWORD
:
"
${REVIEW_APPS_ROOT_PASSWORD}"
GITHUB_ACCESS_TOKEN
:
"
${REVIEW_APPS_QA_GITHUB_ACCESS_TOKEN}"
GITHUB_ACCESS_TOKEN
:
"
${REVIEW_APPS_QA_GITHUB_ACCESS_TOKEN}"
EE_LICENSE
:
"
${REVIEW_APPS_EE_LICENSE}"
EE_LICENSE
:
"
${REVIEW_APPS_EE_LICENSE}"
QA_DEBUG
:
"
true"
dependencies
:
[
"
review-deploy"
]
dependencies
:
-
review-deploy
artifacts
:
artifacts
:
paths
:
paths
:
-
./qa/gitlab-qa-run-*
-
./qa/gitlab-qa-run-*
...
@@ -156,12 +152,13 @@ review-stop:
...
@@ -156,12 +152,13 @@ review-stop:
-
gem install gitlab-qa --no-document ${GITLAB_QA_VERSION:+ --version ${GITLAB_QA_VERSION}}
-
gem install gitlab-qa --no-document ${GITLAB_QA_VERSION:+ --version ${GITLAB_QA_VERSION}}
review-qa-smoke
:
review-qa-smoke
:
<<
:
*review-qa-base
extends
:
.review-qa-base
allow_failure
:
true
script
:
script
:
-
gitlab-qa Test::Instance::Smoke "${QA_IMAGE}" "${CI_ENVIRONMENT_URL}"
-
gitlab-qa Test::Instance::Smoke "${QA_IMAGE}" "${CI_ENVIRONMENT_URL}"
review-qa-all
:
review-qa-all
:
<<
:
*
review-qa-base
extends
:
.
review-qa-base
allow_failure
:
true
allow_failure
:
true
when
:
manual
when
:
manual
parallel
:
5
parallel
:
5
...
@@ -172,21 +169,16 @@ review-qa-all:
...
@@ -172,21 +169,16 @@ review-qa-all:
parallel-spec-reports
:
parallel-spec-reports
:
extends
:
extends
:
-
.dedicated-runner
-
.default-tags
-
.no-docs
-
.except-docs
dependencies
:
-
review-qa-all
image
:
ruby:2.6-alpine
image
:
ruby:2.6-alpine
s
ervices
:
[]
s
tage
:
post-test
before_script
:
[
]
dependencies
:
[
"
review-qa-all"
]
variables
:
variables
:
SETUP_DB
:
"
false"
NEW_PARALLEL_SPECS_REPORT
:
qa/report-new.html
NEW_PARALLEL_SPECS_REPORT
:
qa/report-new.html
BASE_ARTIFACT_URL
:
"
${CI_PROJECT_URL}/-/jobs/${CI_JOB_ID}/artifacts/file/qa/"
BASE_ARTIFACT_URL
:
"
${CI_PROJECT_URL}/-/jobs/${CI_JOB_ID}/artifacts/file/qa/"
stage
:
post-test
allow_failure
:
true
allow_failure
:
true
when
:
manual
when
:
manual
retry
:
0
artifacts
:
artifacts
:
when
:
always
when
:
always
paths
:
paths
:
...
@@ -196,15 +188,15 @@ parallel-spec-reports:
...
@@ -196,15 +188,15 @@ parallel-spec-reports:
junit
:
qa/gitlab-qa-run-*/**/rspec-*.xml
junit
:
qa/gitlab-qa-run-*/**/rspec-*.xml
script
:
script
:
-
apk add --update build-base libxml2-dev libxslt-dev && rm -rf /var/cache/apk/*
-
apk add --update build-base libxml2-dev libxslt-dev && rm -rf /var/cache/apk/*
-
gem install nokogiri
-
gem install nokogiri
--no-document
-
cd qa/gitlab-qa-run-*/gitlab-*
-
cd qa/gitlab-qa-run-*/gitlab-*
-
ARTIFACT_DIRS=$(pwd |rev| awk -F / '{print $1,$2}' | rev | sed s_\ _/_)
-
ARTIFACT_DIRS=$(pwd |rev| awk -F / '{print $1,$2}' | rev | sed s_\ _/_)
-
cd
../../..
-
cd
-
-
'
[[
-f
$NEW_PARALLEL_SPECS_REPORT
]]
||
echo
"{}"
>
${NEW_PARALLEL_SPECS_REPORT}'
-
'
[[
-f
$NEW_PARALLEL_SPECS_REPORT
]]
||
echo
"{}"
>
${NEW_PARALLEL_SPECS_REPORT}'
-
scripts/merge-html-reports ${NEW_PARALLEL_SPECS_REPORT} ${BASE_ARTIFACT_URL}${ARTIFACT_DIRS} qa/gitlab-qa-run-*/**/rspec.htm
-
scripts/merge-html-reports ${NEW_PARALLEL_SPECS_REPORT} ${BASE_ARTIFACT_URL}${ARTIFACT_DIRS} qa/gitlab-qa-run-*/**/rspec.htm
.review-performance-base
:
&review-performance-base
review-performance
:
<<
:
*
review-qa-base
extends
:
.
review-qa-base
allow_failure
:
true
allow_failure
:
true
before_script
:
before_script
:
-
export CI_ENVIRONMENT_URL="$(cat review_app_url.txt)"
-
export CI_ENVIRONMENT_URL="$(cat review_app_url.txt)"
...
@@ -222,18 +214,16 @@ parallel-spec-reports:
...
@@ -222,18 +214,16 @@ parallel-spec-reports:
reports
:
reports
:
performance
:
performance.json
performance
:
performance.json
review-performance
:
<<
:
*review-performance-base
schedule:review-performance:
schedule:review-performance:
<<
:
*review-performance-base
extends
:
<<
:
*review-schedules-only
-
review-performance
dependencies
:
-
.review-schedules-only
-
schedule:review-deploy
dependencies
:
[
"
schedule:review-deploy"
]
schedule:review-cleanup:
schedule:review-cleanup:
<<
:
*review-base
extends
:
<<
:
*review-schedules-only
-
.review-base
-
.review-schedules-only
stage
:
build
stage
:
build
allow_failure
:
true
allow_failure
:
true
environment
:
environment
:
...
@@ -246,11 +236,13 @@ schedule:review-cleanup:
...
@@ -246,11 +236,13 @@ schedule:review-cleanup:
-
ruby -rrubygems scripts/review_apps/automated_cleanup.rb
-
ruby -rrubygems scripts/review_apps/automated_cleanup.rb
danger-review
:
danger-review
:
extends
:
.dedicated-pull-cache-job
extends
:
-
.default-tags
-
.default-retry
-
.default-cache
image
:
registry.gitlab.com/gitlab-org/gitlab-build-images:danger
image
:
registry.gitlab.com/gitlab-org/gitlab-build-images:danger
stage
:
test
stage
:
test
dependencies
:
[]
dependencies
:
[]
before_script
:
[]
only
:
only
:
variables
:
variables
:
-
$DANGER_GITLAB_API_TOKEN
-
$DANGER_GITLAB_API_TOKEN
...
@@ -259,9 +251,8 @@ danger-review:
...
@@ -259,9 +251,8 @@ danger-review:
-
master
-
master
-
/^\d+-\d+-auto-deploy-\d+$/
-
/^\d+-\d+-auto-deploy-\d+$/
-
/^[\d-]+-stable(-ee)?$/
-
/^[\d-]+-stable(-ee)?$/
variables
:
-
/^ce-to-ee-.*/
-
$CI_COMMIT_REF_NAME =~ /^ce-to-ee-.*/
-
/.*-stable(-ee)?-prepare-.*/
-
$CI_COMMIT_REF_NAME =~ /.*-stable(-ee)?-prepare-.*/
script
:
script
:
-
git version
-
git version
-
node --version
-
node --version
...
...
.gitlab/ci/setup.gitlab-ci.yml
View file @
b881c772
# Insurance in case a gem needed by one of our releases gets yanked from
# Insurance in case a gem needed by one of our releases gets yanked from
# rubygems.org in the future.
# rubygems.org in the future.
cache gems
:
cache gems
:
extends
:
.dedicated-no-docs-no-db-pull-cache-job
extends
:
-
.default-tags
-
.default-retry
-
.default-cache
-
.default-before_script
-
.except-docs
dependencies
:
[
"
setup-test-env"
]
variables
:
SETUP_DB
:
"
false"
script
:
script
:
-
bundle package --all --all-platforms
-
bundle package --all --all-platforms
artifacts
:
artifacts
:
paths
:
paths
:
-
vendor/cache
-
vendor/cache
only
:
only
:
refs
:
-
master@gitlab-org/gitlab-ce
-
master@gitlab-org/gitlab-ce
-
master@gitlab-org/gitlab-ee
-
master@gitlab-org/gitlab-ee
-
tags
-
tags
dependencies
:
-
setup-test-env
gitlab_git_test
:
.minimal-job
:
extends
:
extends
:
-
.dedicated-runner
-
.default-tags
-
.no-docs-and-no-qa
-
.default-retry
variables
:
-
.except-docs-qa
SETUP_DB
:
"
false"
before_script
:
[]
dependencies
:
[]
dependencies
:
[]
cache
:
{}
gitlab_git_test
:
extends
:
.minimal-job
script
:
script
:
-
spec/support/prepare-gitlab-git-test-for-commit --check-for-changes
-
spec/support/prepare-gitlab-git-test-for-commit --check-for-changes
no_ee_check
:
no_ee_check
:
extends
:
extends
:
.minimal-job
-
.dedicated-runner
-
.no-docs-and-no-qa
variables
:
SETUP_DB
:
"
false"
before_script
:
[]
dependencies
:
[]
cache
:
{}
script
:
script
:
-
scripts/no-ee-check
-
scripts/no-ee-check
only
:
only
:
-
/.+/@gitlab-org/gitlab-ce
refs
:
-
branches@gitlab-org/gitlab-ce
.gitlab/ci/test-metadata.gitlab-ci.yml
View file @
b881c772
.tests-metadata-state
:
&tests-metadata-state
.tests-metadata-state
:
extends
:
.dedicated-runner
variables
:
variables
:
TESTS_METADATA_S3_BUCKET
:
"
gitlab-ce-cache"
TESTS_METADATA_S3_BUCKET
:
"
gitlab-ce-cache"
before_script
:
before_script
:
...
@@ -14,7 +13,7 @@
...
@@ -14,7 +13,7 @@
retrieve-tests-metadata
:
retrieve-tests-metadata
:
extends
:
extends
:
-
.tests-metadata-state
-
.tests-metadata-state
-
.
no-docs-and-no
-qa
-
.
except-docs
-qa
stage
:
prepare
stage
:
prepare
cache
:
cache
:
key
:
tests_metadata
key
:
tests_metadata
...
@@ -29,7 +28,7 @@ retrieve-tests-metadata:
...
@@ -29,7 +28,7 @@ retrieve-tests-metadata:
-
'
[[
-f
$FLAKY_RSPEC_SUITE_REPORT_PATH
]]
||
echo
"{}"
>
${FLAKY_RSPEC_SUITE_REPORT_PATH}'
-
'
[[
-f
$FLAKY_RSPEC_SUITE_REPORT_PATH
]]
||
echo
"{}"
>
${FLAKY_RSPEC_SUITE_REPORT_PATH}'
update-tests-metadata
:
update-tests-metadata
:
<<
:
*
tests-metadata-state
extends
:
.
tests-metadata-state
stage
:
post-test
stage
:
post-test
cache
:
cache
:
key
:
tests_metadata
key
:
tests_metadata
...
@@ -49,24 +48,23 @@ update-tests-metadata:
...
@@ -49,24 +48,23 @@ update-tests-metadata:
-
rm -f rspec_flaky/all_*.json rspec_flaky/new_*.json
-
rm -f rspec_flaky/all_*.json rspec_flaky/new_*.json
-
scripts/insert-rspec-profiling-data
-
scripts/insert-rspec-profiling-data
only
:
only
:
refs
:
-
master@gitlab-org/gitlab-ce
-
master@gitlab-org/gitlab-ce
-
master@gitlab-org/gitlab-ee
-
master@gitlab-org/gitlab-ee
-
master@gitlab/gitlabhq
-
master@gitlab/gitlabhq
-
master@gitlab/gitlab-ee
-
master@gitlab/gitlab-ee
flaky-examples-check
:
flaky-examples-check
:
extends
:
.dedicated-runner
extends
:
-
.default-tags
-
.default-retry
image
:
ruby:2.6-alpine
image
:
ruby:2.6-alpine
services
:
[]
stage
:
post-test
before_script
:
[]
variables
:
variables
:
SETUP_DB
:
"
false"
USE_BUNDLE_INSTALL
:
"
false"
NEW_FLAKY_SPECS_REPORT
:
rspec_flaky/report-new.json
NEW_FLAKY_SPECS_REPORT
:
rspec_flaky/report-new.json
stage
:
post-test
allow_failure
:
true
allow_failure
:
true
retry
:
0
only
:
only
:
refs
:
-
branches
-
branches
except
:
except
:
refs
:
refs
:
...
...
.gitlab/ci/yaml.gitlab-ci.yml
View file @
b881c772
# Yamllint of *.yml for .gitlab-ci.yml.
# Yamllint of *.yml for .gitlab-ci.yml.
# This uses rules from project root `.yamllint`.
# This uses rules from project root `.yamllint`.
lint-ci-gitlab
:
lint-ci-gitlab
:
extends
:
.dedicated-runner
extends
:
before_script
:
[]
-
.default-tags
dependencies
:
[]
-
.default-retry
image
:
sdesbure/yamllint:latest
image
:
sdesbure/yamllint:latest
dependencies
:
[]
script
:
script
:
-
yamllint .gitlab-ci.yml .gitlab/ci lib/gitlab/ci/templates changelogs
-
yamllint .gitlab-ci.yml .gitlab/ci lib/gitlab/ci/templates changelogs
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