gitlab-org--gitlab-foss/.gitlab-ci.yml

228 lines
4.2 KiB
YAML
Raw Normal View History

2016-02-19 14:59:46 +00:00
image: "ruby:2.1"
2016-01-22 13:45:34 +00:00
services:
- mysql:latest
- redis:latest
2016-02-07 00:57:04 +00:00
cache:
2016-02-19 16:19:57 +00:00
key: "ruby21"
2016-02-07 00:57:04 +00:00
paths:
- vendor
2016-01-22 13:45:34 +00:00
variables:
MYSQL_ALLOW_EMPTY_PASSWORD: "1"
2015-11-12 09:52:20 +00:00
# retry tests only in CI environment
RSPEC_RETRY_RETRY_COUNT: "3"
2016-05-22 01:41:17 +00:00
RAILS_ENV: "test"
SIMPLECOV: "true"
2016-05-22 01:51:09 +00:00
USE_DB: "true"
2016-01-22 13:45:34 +00:00
before_script:
- source ./scripts/prepare_build.sh
2015-06-03 20:05:33 +00:00
- cp config/gitlab.yml.example config/gitlab.yml
2016-05-22 04:57:25 +00:00
#- retry gem install bundler
2016-03-09 20:22:25 +00:00
- retry bundle install --without postgres production --jobs $(nproc) "${FLAGS[@]}"
2016-05-22 01:51:09 +00:00
- '[ "$USE_DB" != "true" ] || bundle exec rake db:drop db:create db:schema:load db:migrate'
2016-05-22 01:17:15 +00:00
stages:
2016-05-22 01:41:17 +00:00
- build
2016-05-22 01:17:15 +00:00
- test
- notifications
2016-05-22 04:45:16 +00:00
test-bundler:
stage: build
2016-05-22 04:57:25 +00:00
variables:
USE_DB: "false"
2016-05-22 04:45:16 +00:00
script:
2016-05-22 04:57:25 +00:00
- retry gem install bundler
2016-05-22 04:45:16 +00:00
- bundle exec bundle --version
2016-05-22 01:41:17 +00:00
prepare:
stage: build
2016-05-22 01:51:09 +00:00
variables:
USE_DB: "false"
2016-05-22 01:41:17 +00:00
script:
- bundle exec rake assets:precompile
- echo "{}" > knapsack_rspec_report.json
- echo "{}" > knapsack_cucumber_report.json
artifacts:
paths:
2016-05-22 01:52:19 +00:00
- public/assets/
2016-05-22 01:41:17 +00:00
- knapsack_rspec_report.json
- knapsack_cucumber_report.json
2016-05-22 01:51:09 +00:00
.knapsack: &knapsack
stage: test
script:
2016-05-22 01:51:09 +00:00
- JOB_NAME=( $CI_BUILD_NAME )
- export CI_NODE_INDEX=${JOB_NAME[1]}
- export CI_NODE_TOTAL=${JOB_NAME[2]}
- bundle exec rake knapsack:${JOB_NAME[0]}
2016-05-22 01:51:09 +00:00
.exec: &exec
stage: test
script:
2016-05-22 01:51:09 +00:00
- bundle exec $CI_BUILD_NAME
rspec 0 10: *knapsack
rspec 1 10: *knapsack
rspec 2 10: *knapsack
rspec 3 10: *knapsack
rspec 4 10: *knapsack
rspec 5 10: *knapsack
rspec 6 10: *knapsack
rspec 7 10: *knapsack
rspec 8 10: *knapsack
rspec 9 10: *knapsack
spinach 0 10: *knapsack
spinach 1 10: *knapsack
spinach 2 10: *knapsack
spinach 3 10: *knapsack
spinach 4 10: *knapsack
spinach 5 10: *knapsack
spinach 6 10: *knapsack
spinach 7 10: *knapsack
spinach 8 10: *knapsack
spinach 9 10: *knapsack
teaspoon: *exec
rubocop: *exec
rake scss_lint: *exec
rake brakeman: *exec
rake flog: *exec
rake flay: *exec
rake db:migrate:reset: *exec
bundler:audit:
stage: test
2016-03-15 14:38:12 +00:00
only:
- master
script:
- "bundle exec bundle-audit check --update --ignore OSVDB-115941"
# Ruby 2.2 jobs
spec:feature:ruby22:
stage: test
image: ruby:2.2
only:
2016-03-15 14:38:12 +00:00
- master
script:
2016-05-22 01:41:17 +00:00
- bundle exec rake assets:precompile 2>/dev/null
- bundle exec rake spec:feature
cache:
key: "ruby22"
paths:
- vendor
spec:api:ruby22:
stage: test
image: ruby:2.2
only:
- master
script:
2016-05-22 01:41:17 +00:00
- bundle exec rake spec:api
cache:
key: "ruby22"
paths:
- vendor
spec:models:ruby22:
stage: test
image: ruby:2.2
only:
- master
script:
2016-05-22 01:41:17 +00:00
- bundle exec rake spec:models
cache:
key: "ruby22"
paths:
- vendor
spec:lib:ruby22:
stage: test
image: ruby:2.2
only:
- master
script:
2016-05-22 01:41:17 +00:00
- bundle exec rake spec:lib
cache:
key: "ruby22"
paths:
- vendor
spec:services:ruby22:
stage: test
image: ruby:2.2
only:
- master
script:
2016-05-22 01:41:17 +00:00
- bundle exec rake spec:services
cache:
key: "ruby22"
paths:
- vendor
spec:other:ruby22:
stage: test
image: ruby:2.2
only:
- master
script:
2016-05-22 01:41:17 +00:00
- bundle exec rake spec:other
cache:
key: "ruby22"
paths:
- vendor
spinach:project:half:ruby22:
stage: test
image: ruby:2.2
only:
- master
script:
2016-05-22 01:41:17 +00:00
- bundle exec rake assets:precompile 2>/dev/null
- bundle exec rake spinach:project:half
cache:
key: "ruby22"
paths:
- vendor
spinach:project:rest:ruby22:
stage: test
image: ruby:2.2
only:
- master
script:
2016-05-22 01:41:17 +00:00
- bundle exec rake assets:precompile 2>/dev/null
- bundle exec rake spinach:project:rest
cache:
key: "ruby22"
paths:
- vendor
spinach:other:ruby22:
stage: test
image: ruby:2.2
only:
- master
script:
2016-05-22 01:41:17 +00:00
- bundle exec rake assets:precompile 2>/dev/null
- bundle exec rake spinach:other
cache:
key: "ruby22"
paths:
- vendor
notify:slack:
stage: notifications
script:
2016-03-01 09:03:37 +00:00
- ./scripts/notify_slack.sh "#builds" "Build on \`$CI_BUILD_REF_NAME\` failed! Commit \`$(git log -1 --oneline)\` See <https://gitlab.com/gitlab-org/$(basename "$PWD")/commit/"$CI_BUILD_REF"/builds>"
when: on_failure
only:
- master@gitlab-org/gitlab-ce
- tags@gitlab-org/gitlab-ce
- master@gitlab-org/gitlab-ee
- tags@gitlab-org/gitlab-ee