Commit 40c027d4 authored by Stan Hu's avatar Stan Hu

Merge branch 'feature-branch-gather-jobs-data-ee' into 'master'

[EE] Reduce the complexity of our CI configuration

Closes gitlab-ce#51367 and gitlab-ce#65702

See merge request gitlab-org/gitlab-ee!15121
parents 6c74fcf5 7b585abc
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"
...@@ -17,26 +27,9 @@ variables: ...@@ -17,26 +27,9 @@ variables:
ELASTIC_URL: "http://elastic:changeme@docker.elastic.co-elasticsearch-elasticsearch:9200" ELASTIC_URL: "http://elastic:changeme@docker.elastic.co-elasticsearch-elasticsearch:9200"
EE_KNAPSACK_RSPEC_SUITE_REPORT_PATH: knapsack/${CI_PROJECT_NAME}/rspec_report-master-ee.json EE_KNAPSACK_RSPEC_SUITE_REPORT_PATH: knapsack/${CI_PROJECT_NAME}/rspec_report-master-ee.json
before_script:
- date
- source scripts/utils.sh
- source scripts/prepare_build.sh
- date
after_script: after_script:
- date - date
stages:
- build
- prepare
- merge
- quick-test
- 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
...@@ -51,3 +44,4 @@ include: ...@@ -51,3 +44,4 @@ include:
- local: .gitlab/ci/setup.gitlab-ci.yml - local: .gitlab/ci/setup.gitlab-ci.yml
- local: .gitlab/ci/test-metadata.gitlab-ci.yml - local: .gitlab/ci/test-metadata.gitlab-ci.yml
- local: .gitlab/ci/yaml.gitlab-ci.yml - local: .gitlab/ci/yaml.gitlab-ci.yml
- local: ee/.gitlab/ci/ee-specific-checks.gitlab-ci.yml
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
.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$)/
.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
......
.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
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"
......
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
.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
......
.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-ee.git v11.11.0-ee
- 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:
- master - master
- tags - tags
- /[\d-]+-stable(-ee)?/
- /[\d-]+-auto-deploy-\d{7}/
- /^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-ee.git v11.11.0-ee
- 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:
...@@ -286,21 +302,10 @@ coverage: ...@@ -286,21 +302,10 @@ coverage:
- coverage/index.html - coverage/index.html
- coverage/assets/ - coverage/assets/
- tmp/memory_test/ - tmp/memory_test/
except:
- /(^docs[\/-].*|.*-docs$)/
- /(^qa[\/-].*|.*-qa$)/
## EE-specific content ## EE-specific content
.use-pg-with-elasticsearch: &use-pg-with-elasticsearch .rspec-base-ee:
services: extends: .rspec-base
- name: postgres:9.6
command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
- name: redis:alpine
- name: docker.elastic.co/elasticsearch/elasticsearch:5.6.12
.rspec-metadata-ee: &rspec-metadata-ee
<<: *rspec-metadata
stage: test
script: script:
- JOB_NAME=( $CI_JOB_NAME ) - JOB_NAME=( $CI_JOB_NAME )
- TEST_TOOL=${JOB_NAME[0]} - TEST_TOOL=${JOB_NAME[0]}
...@@ -318,25 +323,28 @@ coverage: ...@@ -318,25 +323,28 @@ coverage:
- knapsack rspec "--color --format documentation --format RspecJunitFormatter --out junit_rspec.xml --tag level:${TEST_LEVEL} --tag ~geo" - knapsack rspec "--color --format documentation --format RspecJunitFormatter --out junit_rspec.xml --tag level:${TEST_LEVEL} --tag ~geo"
- date - date
.rspec-metadata-pg-ee: &rspec-metadata-pg-ee .rspec-base-pg-ee:
<<: *rspec-metadata-ee extends: .rspec-base-ee
<<: *use-pg-with-elasticsearch services:
- name: postgres:9.6
command: ["postgres", "-c", "fsync=off", "-c", "synchronous_commit=off", "-c", "full_page_writes=off"]
- name: redis:alpine
- name: docker.elastic.co/elasticsearch/elasticsearch:5.6.12
rspec unit pg ee: rspec unit pg ee:
<<: *rspec-metadata-pg-ee extends: .rspec-base-pg-ee
parallel: 7 parallel: 7
rspec integration pg ee: rspec integration pg ee:
<<: *rspec-metadata-pg-ee extends: .rspec-base-pg-ee
parallel: 3 parallel: 3
rspec system pg ee: rspec system pg ee:
<<: *rspec-metadata-pg-ee extends: .rspec-base-pg-ee
parallel: 5 parallel: 5
.rspec-metadata-pg-geo: &rspec-metadata-pg-geo .rspec-base-pg-geo:
<<: *rspec-metadata extends: .rspec-base
stage: test
script: script:
- JOB_NAME=( $CI_JOB_NAME ) - JOB_NAME=( $CI_JOB_NAME )
- TEST_TOOL=${JOB_NAME[0]} - TEST_TOOL=${JOB_NAME[0]}
...@@ -352,51 +360,51 @@ rspec system pg ee: ...@@ -352,51 +360,51 @@ rspec system pg ee:
- knapsack rspec "-Ispec --color --format documentation --format RspecJunitFormatter --out junit_rspec.xml --tag geo" - knapsack rspec "-Ispec --color --format documentation --format RspecJunitFormatter --out junit_rspec.xml --tag geo"
rspec geo pg ee: rspec geo pg ee:
<<: *rspec-metadata-pg-geo extends:
<<: *use-pg - .rspec-base-pg-geo
- .use-pg
- .except-docs-qa-geo
parallel: 3 parallel: 3
except:
- /(^geo[\/-].*|.*-geo$)/
- /(^docs[\/-].*|.*-docs$)/
- /(^qa[\/-].*|.*-qa$)/
rspec geo pg-10 ee: rspec geo pg-10 ee:
<<: *rspec-metadata-pg-geo extends:
<<: *use-pg-10 - .rspec-base-pg-geo
- .use-pg-10
- .except-docs-qa-geo
parallel: 3 parallel: 3
except:
- /(^geo[\/-].*|.*-geo$)/
- /(^docs[\/-].*|.*-docs$)/
- /(^qa[\/-].*|.*-qa$)/
quick-rspec geo pg ee: quick-rspec geo pg ee:
<<: *rspec-metadata-pg-geo extends:
<<: *use-pg - .rspec-base-pg-geo
- .use-pg
stage: quick-test stage: quick-test
only: only:
- /(^geo[\/-].*|.*-geo$)/ - /(^geo[\/-].*|.*-geo$)/
quick-rspec geo pg-10 ee: quick-rspec geo pg-10 ee:
<<: *rspec-metadata-pg-geo extends:
<<: *use-pg-10 - .rspec-base-pg-geo
- .use-pg-10
stage: quick-test stage: quick-test
only: only:
- /(^geo[\/-].*|.*-geo$)/ - /(^geo[\/-].*|.*-geo$)/
.rspec-quarantine-ee: &rspec-quarantine-ee rspec quarantine pg ee:
<<: *only-schedules-master extends: rspec quarantine pg
allow_failure: true
script: script:
- export NO_KNAPSACK=1 CACHE_CLASSES=true - export NO_KNAPSACK=1 CACHE_CLASSES=true
- scripts/gitaly-test-spawn - scripts/gitaly-test-spawn
- bin/rspec --color --format documentation --format RspecJunitFormatter --out junit_rspec.xml --tag quarantine -- ee/spec/ - bin/rspec --color --format documentation --format RspecJunitFormatter --out junit_rspec.xml --tag quarantine -- ee/spec/
rspec quarantine pg ee: migration:upgrade-pg-ce-to-ee:
<<: *rspec-quarantine-ee extends:
<<: *rspec-metadata-pg - .default-tags
- .default-retry
.migration-paths-upgrade-ce-to-ee: &migration-paths-upgrade-ce-to-ee - .default-cache
extends: .dedicated-no-docs-and-no-qa-pull-cache-job - .default-before_script
- .use-pg
- .except-docs-qa
dependencies: ["setup-test-env"]
variables: variables:
SETUP_DB: "false" SETUP_DB: "false"
script: script:
...@@ -412,16 +420,9 @@ rspec quarantine pg ee: ...@@ -412,16 +420,9 @@ rspec quarantine pg ee:
- . scripts/prepare_build.sh - . scripts/prepare_build.sh
- date - date
- bundle exec rake db:migrate - bundle exec rake db:migrate
dependencies:
- setup-test-env
migration:upgrade-pg-ce-to-ee:
<<: *migration-paths-upgrade-ce-to-ee
<<: *use-pg
db:rollback-pg-geo: db:rollback geo:
<<: *db-rollback extends: db:rollback
<<: *use-pg
script: script:
- bundle exec rake geo:db:migrate VERSION=20170627195211 - bundle exec rake geo:db:migrate VERSION=20170627195211
- bundle exec rake geo:db:migrate - bundle exec rake geo:db:migrate
......
...@@ -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: {}
.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
services: [] stage: 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
......
# 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
.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,12 +28,9 @@ retrieve-tests-metadata: ...@@ -29,12 +28,9 @@ 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}'
- wget -O $EE_KNAPSACK_RSPEC_SUITE_REPORT_PATH http://${TESTS_METADATA_S3_BUCKET}.s3.amazonaws.com/$EE_KNAPSACK_RSPEC_SUITE_REPORT_PATH || rm $EE_KNAPSACK_RSPEC_SUITE_REPORT_PATH - wget -O $EE_KNAPSACK_RSPEC_SUITE_REPORT_PATH http://${TESTS_METADATA_S3_BUCKET}.s3.amazonaws.com/$EE_KNAPSACK_RSPEC_SUITE_REPORT_PATH || rm $EE_KNAPSACK_RSPEC_SUITE_REPORT_PATH
- '[[ -f $EE_KNAPSACK_RSPEC_SUITE_REPORT_PATH ]] || echo "{}" > ${EE_KNAPSACK_RSPEC_SUITE_REPORT_PATH}' - '[[ -f $EE_KNAPSACK_RSPEC_SUITE_REPORT_PATH ]] || echo "{}" > ${EE_KNAPSACK_RSPEC_SUITE_REPORT_PATH}'
except:
- /(^docs[\/-].*|.*-docs$)/
- /(^qa[\/-].*|.*-qa$)/
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
...@@ -57,24 +53,23 @@ update-tests-metadata: ...@@ -57,24 +53,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:
...@@ -89,35 +84,3 @@ flaky-examples-check: ...@@ -89,35 +84,3 @@ flaky-examples-check:
- '[[ -f $NEW_FLAKY_SPECS_REPORT ]] || echo "{}" > ${NEW_FLAKY_SPECS_REPORT}' - '[[ -f $NEW_FLAKY_SPECS_REPORT ]] || echo "{}" > ${NEW_FLAKY_SPECS_REPORT}'
- scripts/merge-reports ${NEW_FLAKY_SPECS_REPORT} rspec_flaky/new_*_*.json - scripts/merge-reports ${NEW_FLAKY_SPECS_REPORT} rspec_flaky/new_*_*.json
- scripts/detect-new-flaky-examples $NEW_FLAKY_SPECS_REPORT - scripts/detect-new-flaky-examples $NEW_FLAKY_SPECS_REPORT
## EE-specific content
.ee-specific-check: &ee-specific-check
extends: .dedicated-runner
stage: test
dependencies: []
before_script: []
cache: {}
retry: 0
only:
- branches
- branches@gitlab-org/gitlab-ee
except:
- master
- tags
- /[\d-]+-stable(-ee)?/
- /[\d-]+-auto-deploy-\d{7}/
- /^security-/
- /\bce\-to\-ee\b/
ee-files-location-check:
<<: *ee-specific-check
script:
- scripts/ee-files-location-check
ee-specific-lines-check:
<<: *ee-specific-check
script:
- scripts/ee-specific-lines-check
# END of EE-specific content
# 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
.ee-specific-check:
extends: .default-tags
dependencies: []
only:
- branches@gitlab-org/gitlab-ee
except:
- master
- tags
- /[\d-]+-stable(-ee)?/
- /[\d-]+-auto-deploy-\d{7}/
- /^security-/
- /\bce\-to\-ee\b/
ee-files-location-check:
extends: .ee-specific-check
script:
- scripts/ee-files-location-check
ee-specific-lines-check:
extends: .ee-specific-check
script:
- scripts/ee-specific-lines-check
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