.gitlab-ci.yml 24.2 KB
Newer Older
1
image: "dev.gitlab.org:5005/gitlab/gitlab-build-images:ruby-2.3.7-golang-1.9-git-2.17-chrome-65.0-node-8.x-yarn-1.2-postgresql-9.6"
2

3 4 5 6 7
.dedicated-runner: &dedicated-runner
  retry: 1
  tags:
    - gitlab-org

8
.default-cache: &default-cache
9
  key: "ruby-2.3.7-with-yarn"
10
  paths:
11 12
    - vendor/ruby
    - .yarn-cache/
13
    - vendor/gitaly-ruby
14 15 16 17 18 19 20 21 22 23

.push-cache: &push-cache
  cache:
    <<: *default-cache
    policy: push

.pull-cache: &pull-cache
  cache:
    <<: *default-cache
    policy: pull
24

25 26
variables:
  MYSQL_ALLOW_EMPTY_PASSWORD: "1"
Kamil Trzcinski's avatar
Kamil Trzcinski committed
27
  RAILS_ENV: "test"
Mike Greiling's avatar
Mike Greiling committed
28
  NODE_ENV: "test"
Kamil Trzcinski's avatar
Kamil Trzcinski committed
29
  SIMPLECOV: "true"
30
  GIT_DEPTH: "20"
31
  GIT_SUBMODULE_STRATEGY: "none"
32
  GET_SOURCES_ATTEMPTS: "3"
33
  KNAPSACK_RSPEC_SUITE_REPORT_PATH: knapsack/${CI_PROJECT_NAME}/rspec_report-master.json
34
  FLAKY_RSPEC_SUITE_REPORT_PATH: rspec_flaky/report-suite.json
35

Dmitriy Zaporozhets's avatar
Dmitriy Zaporozhets committed
36
before_script:
Kamil Trzcinski's avatar
Test  
Kamil Trzcinski committed
37
  - bundle --version
38
  - date
39
  - source scripts/utils.sh
40
  - date
41
  - source scripts/prepare_build.sh
42 43 44 45
  - date

after_script:
  - date
46

Kamil Trzcinski's avatar
Kamil Trzcinski committed
47
stages:
48 49 50 51 52
  - build
  - prepare
  - test
  - post-test
  - pages
53
  - post-cleanup
54

55
# Predefined scopes
56
.tests-metadata-state: &tests-metadata-state
57
  <<: *dedicated-runner
58
  variables:
59
    TESTS_METADATA_S3_BUCKET: "gitlab-ce-cache"
60 61
  before_script:
    - source scripts/utils.sh
62 63 64
  artifacts:
    expire_in: 31d
    paths:
65
      - knapsack/
66
      - rspec_flaky/
67

68 69
.use-pg: &use-pg
  services:
70 71 72
    # As of Jan 2018, we don't have a strong reason to upgrade to 9.6 for CI yet,
    # so using the least common denominator ensures backwards compatibility
    # (as many users are still using 9.2).
73
    - postgres:9.2
74 75 76
    - redis:alpine

.use-mysql: &use-mysql
77
  services:
78
    - mysql:5.7
79
    - redis:alpine
80

81 82 83 84 85 86 87 88 89 90 91 92 93
.rails5-variables: &rails5-variables
  script:
    - export RAILS5=${RAILS5}
    - export BUNDLE_GEMFILE=${BUNDLE_GEMFILE}

.rails5: &rails5
  allow_failure: true
  only:
    - /rails5/
  variables:
    BUNDLE_GEMFILE: "Gemfile.rails5"
    RAILS5: "true"

94 95 96
# Skip all jobs except the ones that begin with 'docs/'.
# Used for commits including ONLY documentation changes.
# https://docs.gitlab.com/ce/development/writing_documentation.html#testing
97 98
.except-docs: &except-docs
  except:
99
    - /(^docs[\/-].*|.*-docs$)/
100

101 102 103 104
.except-qa: &except-qa
  except:
    - /(^qa[\/-].*|.*-qa$)/

105 106 107 108 109
.except-docs-and-qa: &except-docs-and-qa
  except:
    - /(^docs[\/-].*|.*-docs$)/
    - /(^qa[\/-].*|.*-qa$)/

110 111 112
# Jobs that only need to pull cache
.dedicated-no-docs-pull-cache-job: &dedicated-no-docs-pull-cache-job
  <<: *dedicated-runner
113
  <<: *except-docs
114 115 116 117 118 119 120 121 122 123 124
  <<: *pull-cache
  dependencies:
    - setup-test-env
  stage: test

# Jobs that do not need a DB
.dedicated-no-docs-no-db-pull-cache-job: &dedicated-no-docs-no-db-pull-cache-job
  <<: *dedicated-no-docs-pull-cache-job
  variables:
    SETUP_DB: "false"

125 126 127 128
.dedicated-no-docs-and-no-qa-pull-cache-job: &dedicated-no-docs-and-no-qa-pull-cache-job
  <<: *dedicated-no-docs-pull-cache-job
  <<: *except-docs-and-qa

129 130 131 132 133
.rake-exec: &rake-exec
  <<: *dedicated-no-docs-no-db-pull-cache-job
  script:
    - bundle exec rake $CI_JOB_NAME

134
.rspec-metadata: &rspec-metadata
135
  <<: *dedicated-runner
136
  <<: *except-docs-and-qa
137
  <<: *pull-cache
138
  <<: *rails5-variables
139
  stage: test
140
  script:
141
    - JOB_NAME=( $CI_JOB_NAME )
142 143
    - export CI_NODE_INDEX=${JOB_NAME[-2]}
    - export CI_NODE_TOTAL=${JOB_NAME[-1]}
144
    - export KNAPSACK_REPORT_PATH=knapsack/${CI_PROJECT_NAME}/${JOB_NAME[0]}_node_${CI_NODE_INDEX}_${CI_NODE_TOTAL}_report.json
145
    - export KNAPSACK_GENERATE_REPORT=true
146 147 148
    - export SUITE_FLAKY_RSPEC_REPORT_PATH=${FLAKY_RSPEC_SUITE_REPORT_PATH}
    - export FLAKY_RSPEC_REPORT_PATH=rspec_flaky/all_${JOB_NAME[0]}_${CI_NODE_INDEX}_${CI_NODE_TOTAL}_report.json
    - export NEW_FLAKY_RSPEC_REPORT_PATH=rspec_flaky/new_${JOB_NAME[0]}_${CI_NODE_INDEX}_${CI_NODE_TOTAL}_report.json
149
    - export FLAKY_RSPEC_GENERATE_REPORT=true
150
    - export CACHE_CLASSES=true
151
    - cp ${KNAPSACK_RSPEC_SUITE_REPORT_PATH} ${KNAPSACK_REPORT_PATH}
152
    - '[[ -f $FLAKY_RSPEC_REPORT_PATH ]] || echo "{}" > ${FLAKY_RSPEC_REPORT_PATH}'
153
    - '[[ -f $NEW_FLAKY_RSPEC_REPORT_PATH ]] || echo "{}" > ${NEW_FLAKY_RSPEC_REPORT_PATH}'
Jacob Vosmaer's avatar
Jacob Vosmaer committed
154
    - scripts/gitaly-test-spawn
155 156 157
    - knapsack rspec "--color --format documentation"
  artifacts:
    expire_in: 31d
158
    when: always
159
    paths:
160 161
      - coverage/
      - knapsack/
162
      - rspec_flaky/
163
      - tmp/capybara/
164

165 166
.rspec-metadata-pg: &rspec-metadata-pg
  <<: *rspec-metadata
167 168
  <<: *use-pg

169 170 171 172
.rspec-metadata-pg-rails5: &rspec-metadata-pg-rails5
  <<: *rspec-metadata-pg
  <<: *rails5

173 174
.rspec-metadata-mysql: &rspec-metadata-mysql
  <<: *rspec-metadata
175 176
  <<: *use-mysql

177 178 179 180
.rspec-metadata-mysql-rails5: &rspec-metadata-mysql-rails5
  <<: *rspec-metadata-mysql
  <<: *rails5

181 182 183 184 185 186 187
.only-canonical-masters: &only-canonical-masters
  only:
    - master@gitlab-org/gitlab-ce
    - master@gitlab-org/gitlab-ee
    - master@gitlab/gitlabhq
    - master@gitlab/gitlab-ee

188
.gitlab-setup: &gitlab-setup
189
  <<: *dedicated-no-docs-and-no-qa-pull-cache-job
190 191 192
  <<: *use-pg
  variables:
    CREATE_DB_USER: "true"
193
  script:
194 195 196 197 198 199 200 201 202 203 204
    # 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
205

206 207
# Review docs base
.review-docs: &review-docs
208
  <<: *dedicated-runner
209
  <<: *except-qa
210
  image: ruby:2.4-alpine
211 212
  before_script:
    - gem install gitlab --no-doc
213 214 215 216 217 218 219 220
    # We need to download the script rather than clone the repo since the
    # review-docs-cleanup job will not be able to run when the branch gets
    # deleted (when merging the MR).
    - apk add --update openssl
    - wget https://gitlab.com/gitlab-org/gitlab-ce/raw/master/scripts/trigger-build-docs
    - chmod 755 trigger-build-docs
  cache: {}
  dependencies: []
221
  variables:
222
    GIT_STRATEGY: none
223 224 225 226
  when: manual
  only:
    - branches

227 228
# DB migration, rollback, and seed jobs
.db-migrate-reset: &db-migrate-reset
229
  <<: *dedicated-no-docs-and-no-qa-pull-cache-job
230 231 232 233
  script:
    - bundle exec rake db:migrate:reset

.migration-paths: &migration-paths
234
  <<: *dedicated-no-docs-and-no-qa-pull-cache-job
235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254
  variables:
    CREATE_DB_USER: "true"
  script:
    - git fetch https://gitlab.com/gitlab-org/gitlab-ce.git v9.3.0
    - git checkout -f FETCH_HEAD
    - 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 $CI_COMMIT_SHA
    - bundle install $BUNDLE_INSTALL_FLAGS
    - date
    - . scripts/prepare_build.sh
    - date
    - bundle exec rake db:migrate

##
# Trigger a package build in omnibus-gitlab repository
#
255
package-and-qa:
256 257 258 259 260
  image: ruby:2.4-alpine
  before_script: []
  stage: build
  cache: {}
  when: manual
261 262
  variables:
    GIT_STRATEGY: none
263
  retry: 0
264 265 266 267 268
  before_script:
    # We need to download the script rather than clone the repo since the
    # package-and-qa job will not be able to run when the branch gets
    # deleted (when merging the MR).
    - apk add --update openssl
269
    - wget https://gitlab.com/$CI_PROJECT_PATH/raw/$CI_COMMIT_SHA/scripts/trigger-build-omnibus
270
    - chmod 755 trigger-build-omnibus
271
  script:
272
    - ./trigger-build-omnibus
273 274 275 276
  only:
    - //@gitlab-org/gitlab-ce
    - //@gitlab-org/gitlab-ee

277 278 279 280 281 282 283
# Trigger a docs build in gitlab-docs
# Useful to preview the docs changes live
review-docs-deploy:
  <<: *review-docs
  stage: build
  environment:
    name: review-docs/$CI_COMMIT_REF_NAME
284 285
    # DOCS_REVIEW_APPS_DOMAIN and DOCS_GITLAB_REPO_SUFFIX are secret variables
    # Discussion: https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/14236/diffs#note_40140693
286
    url: http://$DOCS_GITLAB_REPO_SUFFIX-$CI_COMMIT_REF_SLUG.$DOCS_REVIEW_APPS_DOMAIN/$DOCS_GITLAB_REPO_SUFFIX
287 288
    on_stop: review-docs-cleanup
  script:
289
    - ./trigger-build-docs deploy
290 291 292 293 294 295 296 297 298

# Cleanup remote environment of gitlab-docs
review-docs-cleanup:
  <<: *review-docs
  stage: post-cleanup
  environment:
    name: review-docs/$CI_COMMIT_REF_NAME
    action: stop
  script:
299
    - ./trigger-build-docs cleanup
300

301 302 303
# Retrieve knapsack and rspec_flaky reports
retrieve-tests-metadata:
  <<: *tests-metadata-state
304
  <<: *except-docs-and-qa
305
  stage: prepare
306
  cache:
307
    key: tests_metadata
308
    policy: pull
309
  script:
310
    - mkdir -p knapsack/${CI_PROJECT_NAME}/
311
    - wget -O $KNAPSACK_RSPEC_SUITE_REPORT_PATH http://${TESTS_METADATA_S3_BUCKET}.s3.amazonaws.com/$KNAPSACK_RSPEC_SUITE_REPORT_PATH || rm $KNAPSACK_RSPEC_SUITE_REPORT_PATH
312
    - '[[ -f $KNAPSACK_RSPEC_SUITE_REPORT_PATH ]] || echo "{}" > ${KNAPSACK_RSPEC_SUITE_REPORT_PATH}'
313
    - mkdir -p rspec_flaky/
314 315
    - wget -O $FLAKY_RSPEC_SUITE_REPORT_PATH http://${TESTS_METADATA_S3_BUCKET}.s3.amazonaws.com/$FLAKY_RSPEC_SUITE_REPORT_PATH || rm $FLAKY_RSPEC_SUITE_REPORT_PATH
    - '[[ -f $FLAKY_RSPEC_SUITE_REPORT_PATH ]] || echo "{}" > ${FLAKY_RSPEC_SUITE_REPORT_PATH}'
316

317 318
update-tests-metadata:
  <<: *tests-metadata-state
319
  <<: *only-canonical-masters
320
  stage: post-test
321
  cache:
322
    key: tests_metadata
323 324
    paths:
      - knapsack/
325
      - rspec_flaky/
326
    policy: push
327
  script:
328
    - retry gem install fog-aws mime-types activesupport
329
    - scripts/merge-reports ${KNAPSACK_RSPEC_SUITE_REPORT_PATH} knapsack/${CI_PROJECT_NAME}/rspec-pg_node_*.json
330
    - scripts/merge-reports ${FLAKY_RSPEC_SUITE_REPORT_PATH} rspec_flaky/all_*_*.json
331
    - FLAKY_RSPEC_GENERATE_REPORT=1 scripts/prune-old-flaky-specs ${FLAKY_RSPEC_SUITE_REPORT_PATH}
blackst0ne's avatar
blackst0ne committed
332
    - '[[ -z ${TESTS_METADATA_S3_BUCKET} ]] || scripts/sync-reports put $TESTS_METADATA_S3_BUCKET $KNAPSACK_RSPEC_SUITE_REPORT_PATH'
333
    - '[[ -z ${TESTS_METADATA_S3_BUCKET} ]] || scripts/sync-reports put $TESTS_METADATA_S3_BUCKET $FLAKY_RSPEC_SUITE_REPORT_PATH'
334
    - rm -f knapsack/${CI_PROJECT_NAME}/*_node_*.json
335
    - rm -f rspec_flaky/all_*.json rspec_flaky/new_*.json
336 337 338

flaky-examples-check:
  <<: *dedicated-runner
339
  image: ruby:2.4-alpine
340 341 342 343 344
  services: []
  before_script: []
  variables:
    SETUP_DB: "false"
    USE_BUNDLE_INSTALL: "false"
345
    NEW_FLAKY_SPECS_REPORT: rspec_flaky/report-new.json
346
  stage: post-test
347
  allow_failure: true
348
  retry: 0
349 350 351 352
  only:
    - branches
  except:
    - master
353
    - /(^docs[\/-].*|.*-docs$)/
354
    - /(^qa[\/-].*|.*-qa$)/
355 356 357 358 359 360
  artifacts:
    expire_in: 30d
    paths:
      - rspec_flaky/
  script:
    - '[[ -f $NEW_FLAKY_SPECS_REPORT ]] || echo "{}" > ${NEW_FLAKY_SPECS_REPORT}'
361
    - scripts/merge-reports ${NEW_FLAKY_SPECS_REPORT} rspec_flaky/new_*_*.json
362
    - scripts/detect-new-flaky-examples $NEW_FLAKY_SPECS_REPORT
363

364
compile-assets:
365
  <<: *dedicated-runner
366
  <<: *except-docs
367
  <<: *use-pg
368
  stage: prepare
369 370
  cache:
    <<: *default-cache
371
  script:
372
    - node --version
373
    - date
374
    - yarn install --frozen-lockfile --cache-folder .yarn-cache
375
    - date
Mike Greiling's avatar
Mike Greiling committed
376
    - bundle exec rake gitlab:assets:compile
377 378 379
  artifacts:
    expire_in: 7d
    paths:
380
      - node_modules
381
      - public/assets
382 383 384 385 386 387 388 389 390 391 392 393 394 395

setup-test-env:
  <<: *dedicated-runner
  <<: *except-docs
  <<: *use-pg
  stage: prepare
  cache:
    <<: *default-cache
  script:
    - bundle exec ruby -Ispec -e 'require "spec_helper" ; TestEnv.init'
    - scripts/gitaly-test-build # Do not use 'bundle exec' here
  artifacts:
    expire_in: 7d
    paths:
396
      - tmp/tests
397
      - config/secrets.yml
398
      - vendor/gitaly-ruby
399

blackst0ne's avatar
blackst0ne committed
400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522
rspec-pg 0 30: *rspec-metadata-pg
rspec-pg 1 30: *rspec-metadata-pg
rspec-pg 2 30: *rspec-metadata-pg
rspec-pg 3 30: *rspec-metadata-pg
rspec-pg 4 30: *rspec-metadata-pg
rspec-pg 5 30: *rspec-metadata-pg
rspec-pg 6 30: *rspec-metadata-pg
rspec-pg 7 30: *rspec-metadata-pg
rspec-pg 8 30: *rspec-metadata-pg
rspec-pg 9 30: *rspec-metadata-pg
rspec-pg 10 30: *rspec-metadata-pg
rspec-pg 11 30: *rspec-metadata-pg
rspec-pg 12 30: *rspec-metadata-pg
rspec-pg 13 30: *rspec-metadata-pg
rspec-pg 14 30: *rspec-metadata-pg
rspec-pg 15 30: *rspec-metadata-pg
rspec-pg 16 30: *rspec-metadata-pg
rspec-pg 17 30: *rspec-metadata-pg
rspec-pg 18 30: *rspec-metadata-pg
rspec-pg 19 30: *rspec-metadata-pg
rspec-pg 20 30: *rspec-metadata-pg
rspec-pg 21 30: *rspec-metadata-pg
rspec-pg 22 30: *rspec-metadata-pg
rspec-pg 23 30: *rspec-metadata-pg
rspec-pg 24 30: *rspec-metadata-pg
rspec-pg 25 30: *rspec-metadata-pg
rspec-pg 26 30: *rspec-metadata-pg
rspec-pg 27 30: *rspec-metadata-pg
rspec-pg 28 30: *rspec-metadata-pg
rspec-pg 29 30: *rspec-metadata-pg

rspec-mysql 0 30: *rspec-metadata-mysql
rspec-mysql 1 30: *rspec-metadata-mysql
rspec-mysql 2 30: *rspec-metadata-mysql
rspec-mysql 3 30: *rspec-metadata-mysql
rspec-mysql 4 30: *rspec-metadata-mysql
rspec-mysql 5 30: *rspec-metadata-mysql
rspec-mysql 6 30: *rspec-metadata-mysql
rspec-mysql 7 30: *rspec-metadata-mysql
rspec-mysql 8 30: *rspec-metadata-mysql
rspec-mysql 9 30: *rspec-metadata-mysql
rspec-mysql 10 30: *rspec-metadata-mysql
rspec-mysql 11 30: *rspec-metadata-mysql
rspec-mysql 12 30: *rspec-metadata-mysql
rspec-mysql 13 30: *rspec-metadata-mysql
rspec-mysql 14 30: *rspec-metadata-mysql
rspec-mysql 15 30: *rspec-metadata-mysql
rspec-mysql 16 30: *rspec-metadata-mysql
rspec-mysql 17 30: *rspec-metadata-mysql
rspec-mysql 18 30: *rspec-metadata-mysql
rspec-mysql 19 30: *rspec-metadata-mysql
rspec-mysql 20 30: *rspec-metadata-mysql
rspec-mysql 21 30: *rspec-metadata-mysql
rspec-mysql 22 30: *rspec-metadata-mysql
rspec-mysql 23 30: *rspec-metadata-mysql
rspec-mysql 24 30: *rspec-metadata-mysql
rspec-mysql 25 30: *rspec-metadata-mysql
rspec-mysql 26 30: *rspec-metadata-mysql
rspec-mysql 27 30: *rspec-metadata-mysql
rspec-mysql 28 30: *rspec-metadata-mysql
rspec-mysql 29 30: *rspec-metadata-mysql

rspec-pg-rails5 0 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 1 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 2 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 3 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 4 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 5 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 6 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 7 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 8 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 9 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 10 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 11 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 12 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 13 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 14 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 15 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 16 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 17 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 18 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 19 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 20 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 21 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 22 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 23 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 24 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 25 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 26 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 27 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 28 30: *rspec-metadata-pg-rails5
rspec-pg-rails5 29 30: *rspec-metadata-pg-rails5

rspec-mysql-rails5 0 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 1 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 2 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 3 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 4 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 5 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 6 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 7 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 8 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 9 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 10 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 11 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 12 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 13 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 14 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 15 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 16 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 17 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 18 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 19 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 20 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 21 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 22 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 23 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 24 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 25 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 26 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 27 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 28 30: *rspec-metadata-mysql-rails5
rspec-mysql-rails5 29 30: *rspec-metadata-mysql-rails5
523

524
static-analysis:
525 526 527 528
  <<: *dedicated-no-docs-no-db-pull-cache-job
  dependencies:
    - compile-assets
    - setup-test-env
529
  script:
530
    - scripts/static-analysis
Lin Jen-Shin's avatar
Lin Jen-Shin committed
531
  cache:
532
    key: "ruby-2.3.7-with-yarn-and-rubocop"
Lin Jen-Shin's avatar
Lin Jen-Shin committed
533 534 535 536
    paths:
      - vendor/ruby
      - .yarn-cache/
      - tmp/rubocop_cache
537

538 539 540 541
# Documentation checks:
# - Check validity of relative links
# - Make sure cURL examples in API docs use the full switches
docs lint:
542
  <<: *dedicated-runner
543
  <<: *except-qa
544 545 546 547 548 549
  image: "registry.gitlab.com/gitlab-org/gitlab-build-images:nanoc-bootstrap-ruby-2.4-alpine"
  stage: test
  cache: {}
  dependencies: []
  before_script: []
  script:
550
    - scripts/lint-doc.sh
551
    - scripts/lint-changelog-yaml
552 553 554 555 556 557 558
    - mv doc/ /nanoc/content/
    - cd /nanoc
    # Build HTML from Markdown
    - bundle exec nanoc
    # Check the internal links
    - bundle exec nanoc check internal_links

559 560
downtime_check:
  <<: *rake-exec
561 562 563 564
  except:
    - master
    - tags
    - /^[\d-]+-stable(-ee)?$/
565
    - /(^docs[\/-].*|.*-docs$)/
566
    - /(^qa[\/-].*|.*-qa$)/
567

568 569
ee_compat_check:
  <<: *rake-exec
570 571 572
  except:
    - master
    - tags
573
    - /^[\d-]+-stable(-ee)?/
574
    - /^security-/
575 576
    - branches@gitlab-org/gitlab-ee
    - branches@gitlab/gitlab-ee
577
  retry: 0
578
  artifacts:
579
    name: "${CI_JOB_NAME}_${CI_COMIT_REF_NAME}_${CI_COMMIT_SHA}"
580
    when: always
581 582 583 584
    expire_in: 10d
    paths:
      - ee_compat_check/patches/*.patch

585
db:migrate:reset-pg:
586 587 588
  <<: *db-migrate-reset
  <<: *use-pg

589
db:migrate:reset-mysql:
590 591 592
  <<: *db-migrate-reset
  <<: *use-mysql

593 594 595 596 597 598
db:check-schema-pg:
  <<: *db-migrate-reset
  <<: *use-pg
  script:
    - source scripts/schema_changed.sh

599 600 601 602 603 604 605 606
migration:path-pg:
  <<: *migration-paths
  <<: *use-pg

migration:path-mysql:
  <<: *migration-paths
  <<: *use-mysql

607
.db-rollback: &db-rollback
608
  <<: *dedicated-no-docs-and-no-qa-pull-cache-job
609
  script:
610
    - bundle exec rake db:migrate VERSION=20170523121229
611
    - bundle exec rake db:migrate
612

613
db:rollback-pg:
614 615 616
  <<: *db-rollback
  <<: *use-pg

617
db:rollback-mysql:
618 619 620
  <<: *db-rollback
  <<: *use-mysql

621 622
gitlab:setup-pg:
  <<: *gitlab-setup
623 624
  <<: *use-pg

625 626
gitlab:setup-mysql:
  <<: *gitlab-setup
627 628
  <<: *use-mysql

629
# Frontend-related jobs
630
gitlab:assets:compile:
631
  <<: *dedicated-no-docs-and-no-qa-pull-cache-job
632 633 634 635 636 637
  dependencies: []
  variables:
    NODE_ENV: "production"
    RAILS_ENV: "production"
    SETUP_DB: "false"
    SKIP_STORAGE_VALIDATION: "true"
638
    WEBPACK_REPORT: "true"
Mike Greiling's avatar
Mike Greiling committed
639
    NO_COMPRESSION: "true"
640
  script:
641
    - date
642
    - yarn install --frozen-lockfile --production --cache-folder .yarn-cache
643
    - date
644
    - bundle exec rake gitlab:assets:compile
645 646 647 648
  artifacts:
    name: webpack-report
    expire_in: 31d
    paths:
649
      - webpack-report/
650

651
karma:
652
  <<: *dedicated-no-docs-and-no-qa-pull-cache-job
653
  <<: *use-pg
654 655 656
  dependencies:
    - compile-assets
    - setup-test-env
657
  script:
658
    - export BABEL_ENV=coverage CHROME_LOG_FILE=chrome_debug.log
659
    - date
Jacob Vosmaer's avatar
Jacob Vosmaer committed
660
    - scripts/gitaly-test-spawn
661
    - date
662
    - bundle exec rake karma
663
  coverage: '/^Statements *: (\d+\.\d+%)/'
664 665 666
  artifacts:
    name: coverage-javascript
    expire_in: 31d
667
    when: always
668
    paths:
669 670
      - chrome_debug.log
      - coverage-javascript/
671

672
codequality:
673
  <<: *dedicated-no-docs-no-db-pull-cache-job
674 675
  image: docker:stable
  allow_failure: true
676 677 678
  # gitlab-org runners set `privileged: false` but we need to have it set to true
  # since we're using Docker in Docker
  tags: []
679
  before_script: []
680
  services:
681
    - docker:stable-dind
682 683 684 685 686
  variables:
    SETUP_DB: "false"
    DOCKER_DRIVER: overlay2
  cache: {}
  dependencies: []
687
  script:
688 689 690
    # Extract "MAJOR.MINOR" from CI_SERVER_VERSION and generate "MAJOR-MINOR-stable" for Security Products
    - export SP_VERSION=$(echo "$CI_SERVER_VERSION" | sed 's/^\([0-9]*\)\.\([0-9]*\).*/\1-\2-stable/')
    - docker run --env SOURCE_CODE="$PWD" --volume "$PWD":/code --volume /var/run/docker.sock:/var/run/docker.sock "registry.gitlab.com/gitlab-org/security-products/codequality:$SP_VERSION" /code
691 692
  artifacts:
    paths: [codeclimate.json]
693
    expire_in: 1 week
694

695
sast:
696 697
  <<: *dedicated-no-docs-no-db-pull-cache-job
  image: docker:stable
698
  variables:
699 700 701 702
    SAST_CONFIDENCE_LEVEL: 2
    DOCKER_DRIVER: overlay2
  allow_failure: true
  tags: []
703
  before_script: []
704 705 706 707
  cache: {}
  dependencies: []
  services:
    - docker:stable-dind
708
  script:
709 710 711 712 713 714
    - export SP_VERSION=$(echo "$CI_SERVER_VERSION" | sed 's/^\([0-9]*\)\.\([0-9]*\).*/\1-\2-stable/')
    - docker run
        --env SAST_CONFIDENCE_LEVEL="${SAST_CONFIDENCE_LEVEL:-3}"
        --volume "$PWD:/code"
        --volume /var/run/docker.sock:/var/run/docker.sock
        "registry.gitlab.com/gitlab-org/security-products/sast:$SP_VERSION" /app/bin/run /code
715 716 717
  artifacts:
    paths: [gl-sast-report.json]

718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739
dependency_scanning:
  <<: *dedicated-no-docs-no-db-pull-cache-job
  image: docker:stable
  variables:
    DOCKER_DRIVER: overlay2
  allow_failure: true
  tags: []
  before_script: []
  cache: {}
  dependencies: []
  services:
    - docker:stable-dind
  script:
    - export SP_VERSION=$(echo "$CI_SERVER_VERSION" | sed 's/^\([0-9]*\)\.\([0-9]*\).*/\1-\2-stable/')
    - docker run
        --env DEP_SCAN_DISABLE_REMOTE_CHECKS="${DEP_SCAN_DISABLE_REMOTE_CHECKS:-false}"
        --volume "$PWD:/code"
        --volume /var/run/docker.sock:/var/run/docker.sock
        "registry.gitlab.com/gitlab-org/security-products/dependency-scanning:$SP_VERSION" /code
  artifacts:
    paths: [gl-dependency-scanning-report.json]

740
qa:internal:
741
  <<: *dedicated-no-docs-no-db-pull-cache-job
742 743 744 745 746 747
  services: []
  script:
    - cd qa/
    - bundle install
    - bundle exec rspec

748
qa:selectors:
749
  <<: *dedicated-no-docs-no-db-pull-cache-job
750 751 752 753
  services: []
  script:
    - cd qa/
    - bundle install
754
    - bundle exec bin/qa Test::Sanity::Selectors
755

756
coverage:
757 758 759 760 761 762 763
  # 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
  <<: *dedicated-runner
  <<: *except-docs-and-qa
  <<: *pull-cache
  variables:
    SETUP_DB: "false"
764
  stage: post-test
765 766
  script:
    - bundle exec scripts/merge-simplecov
767
  coverage: '/LOC \((\d+\.\d+%)\) covered.$/'
768 769 770 771 772 773 774
  artifacts:
    name: coverage
    expire_in: 31d
    paths:
    - coverage/index.html
    - coverage/assets/

775
lint:javascript:report:
776
  <<: *dedicated-no-docs-and-no-qa-pull-cache-job
777
  stage: post-test
778
  dependencies:
779
    - compile-assets
780
    - setup-test-env
781
  before_script: []
782
  script:
783
    - date
784
    - find app/ spec/ -name '*.js' -exec sed --in-place 's|/\* eslint-disable .*\*/||' {} \; # run report over all files
785
    - date
786
    - yarn run eslint-report || true # ignore exit code
787 788 789 790
  artifacts:
    name: eslint-report
    expire_in: 31d
    paths:
791
      - eslint-report.html
792 793

pages:
794
  <<: *dedicated-no-docs-no-db-pull-cache-job
795 796 797 798
  before_script: []
  stage: pages
  dependencies:
    - coverage
799 800
    - karma
    - gitlab:assets:compile
801
    - lint:javascript:report
802 803 804
  script:
    - mv public/ .public/
    - mkdir public/
805
    - mv coverage/ public/coverage-ruby/ || true
806
    - mv coverage-javascript/ public/coverage-javascript/ || true
807
    - mv eslint-report.html public/ || true
808
    - mv webpack-report/ public/webpack-report/ || true
809 810 811 812
  artifacts:
    paths:
      - public
  only:
813
    - master@gitlab-org/gitlab-ce
814
    - master@gitlab-org/gitlab-ee
815 816 817 818

# Insurance in case a gem needed by one of our releases gets yanked from
# rubygems.org in the future.
cache gems:
819
  <<: *dedicated-no-docs-no-db-pull-cache-job
820 821 822 823 824
  script:
    - bundle package --all --all-platforms
  artifacts:
    paths:
      - vendor/cache
825 826
  only:
    - master@gitlab-org/gitlab-ce
827
    - master@gitlab-org/gitlab-ee
828
    - tags
829 830

gitlab_git_test:
831
  <<: *dedicated-runner
832
  <<: *except-docs-and-qa
833 834
  variables:
    SETUP_DB: "false"
835 836
  before_script: []
  cache: {}
837 838
  script:
    - spec/support/prepare-gitlab-git-test-for-commit --check-for-changes