debian-mirror-gitlab/.gitlab/ci/review.gitlab-ci.yml

264 lines
7.7 KiB
YAML
Raw Normal View History

2020-05-24 23:13:21 +05:30
review-cleanup:
2019-12-21 20:55:43 +05:30
extends:
- .default-retry
2020-03-13 15:44:24 +05:30
- .review:rules:review-cleanup
2021-10-27 15:23:28 +05:30
image: registry.gitlab.com/gitlab-org/gitlab-build-images:gitlab-helm3-kubectl1.14
2019-12-21 20:55:43 +05:30
stage: prepare
environment:
name: review/auto-cleanup
action: stop
before_script:
- source scripts/utils.sh
2020-05-24 23:13:21 +05:30
- source scripts/review_apps/gcp_cleanup.sh
2019-12-21 20:55:43 +05:30
- install_gitlab_gem
2020-05-24 23:13:21 +05:30
- setup_gcp_dependencies
2019-12-21 20:55:43 +05:30
script:
- ruby -rrubygems scripts/review_apps/automated_cleanup.rb
2020-04-22 19:07:51 +05:30
- gcp_cleanup
2021-01-03 14:25:43 +05:30
.base-before_script: &base-before_script
- source ./scripts/utils.sh
- source ./scripts/review_apps/review-apps.sh
- install_api_client_dependencies_with_apk
2020-07-28 23:09:34 +05:30
review-build-cng:
extends:
- .default-retry
- .review:rules:review-build-cng
2021-09-30 23:02:18 +05:30
image: ${GITLAB_DEPENDENCY_PROXY}ruby:2.7-alpine3.13
2020-07-28 23:09:34 +05:30
stage: review-prepare
needs:
- job: compile-production-assets
artifacts: false
2021-10-27 15:23:28 +05:30
variables:
CNG_PROJECT_ACCESS_TOKEN: "${CNG_MIRROR_PROJECT_ACCESS_TOKEN}" # "Multi-pipeline (from 'gitlab-org/gitlab' 'review-build-cng' job)" at https://gitlab.com/gitlab-org/build/CNG-mirror/-/settings/access_tokens
CNG_PROJECT_PATH: "gitlab-org/build/CNG-mirror"
before_script:
- source ./scripts/utils.sh
- install_gitlab_gem
2020-07-28 23:09:34 +05:30
script:
2021-06-08 01:23:25 +05:30
- ./scripts/trigger-build cng
2019-07-31 22:56:46 +05:30
2019-12-26 22:10:19 +05:30
.review-workflow-base:
2019-12-21 20:55:43 +05:30
extends:
- .default-retry
2021-09-04 01:27:46 +05:30
image: registry.gitlab.com/gitlab-org/gitlab-build-images:gitlab-helm3.5-kubectl1.17
2019-07-31 22:56:46 +05:30
variables:
HOST_SUFFIX: "${CI_ENVIRONMENT_SLUG}"
DOMAIN: "-${CI_ENVIRONMENT_SLUG}.${REVIEW_APPS_DOMAIN}"
2021-10-27 15:23:28 +05:30
GITLAB_HELM_CHART_REF: "v5.1.0"
2019-12-04 20:38:33 +05:30
environment:
2020-11-24 15:15:51 +05:30
name: review/${CI_COMMIT_REF_SLUG}${FREQUENCY}
2019-07-31 22:56:46 +05:30
url: https://gitlab-${CI_ENVIRONMENT_SLUG}.${REVIEW_APPS_DOMAIN}
on_stop: review-stop
2020-04-08 14:13:33 +05:30
auto_stop_in: 48 hours
2019-12-26 22:10:19 +05:30
2020-07-28 23:09:34 +05:30
review-deploy:
extends:
- .review-workflow-base
2020-11-24 15:15:51 +05:30
- .review:rules:review-deploy
2020-07-28 23:09:34 +05:30
stage: review
2021-06-08 01:23:25 +05:30
needs: ["review-build-cng"]
2020-07-28 23:09:34 +05:30
resource_group: "review/${CI_COMMIT_REF_NAME}"
before_script:
- export GITLAB_SHELL_VERSION=$(<GITLAB_SHELL_VERSION)
- export GITALY_VERSION=$(<GITALY_SERVER_VERSION)
- export GITLAB_WORKHORSE_VERSION=$(<GITLAB_WORKHORSE_VERSION)
- echo "${CI_ENVIRONMENT_URL}" > environment_url.txt
2021-01-03 14:25:43 +05:30
- *base-before_script
2020-07-28 23:09:34 +05:30
script:
- check_kube_domain
- download_chart
- date
- deploy || (display_deployment_debug && exit 1)
2021-09-04 01:27:46 +05:30
- verify_deploy || exit 1
2021-01-03 14:25:43 +05:30
- disable_sign_ups || (delete_release && exit 1)
2020-11-24 15:15:51 +05:30
after_script:
# Run seed-dast-test-data.sh only when DAST_RUN is set to true. This is to pupulate review app with data for DAST scan.
# Set DAST_RUN to true when jobs are manually scheduled.
- if [ "$DAST_RUN" == "true" ]; then source scripts/review_apps/seed-dast-test-data.sh; TRACE=1 trigger_proj_user_creation; fi
2020-07-28 23:09:34 +05:30
artifacts:
2021-09-04 01:27:46 +05:30
paths:
- environment_url.txt
- curl_output.txt
2021-01-03 14:25:43 +05:30
expire_in: 7 days
2020-07-28 23:09:34 +05:30
when: always
2019-07-31 22:56:46 +05:30
2020-03-13 15:44:24 +05:30
.review-stop-base:
extends: .review-workflow-base
2019-07-31 22:56:46 +05:30
environment:
action: stop
2020-03-13 15:44:24 +05:30
dependencies: []
2019-12-04 20:38:33 +05:30
variables:
2020-03-13 15:44:24 +05:30
# We're cloning the repo instead of downloading the script for now
# because some repos are private and CI_JOB_TOKEN cannot access files.
# See https://gitlab.com/gitlab-org/gitlab/issues/191273
GIT_DEPTH: 1
2019-12-04 20:38:33 +05:30
before_script:
2021-01-03 14:25:43 +05:30
- *base-before_script
2019-07-31 22:56:46 +05:30
2021-09-30 23:02:18 +05:30
review-delete-deployment:
2020-03-13 15:44:24 +05:30
extends:
- .review-stop-base
2021-09-30 23:02:18 +05:30
- .review:rules:review-delete-deployment
2019-12-04 20:38:33 +05:30
stage: prepare
script:
2021-09-30 23:02:18 +05:30
- delete_release
2019-12-04 20:38:33 +05:30
2019-12-26 22:10:19 +05:30
review-stop:
2020-03-13 15:44:24 +05:30
extends:
- .review-stop-base
2020-11-24 15:15:51 +05:30
- .review:rules:review-stop
stage: post-qa
2019-12-26 22:10:19 +05:30
script:
2021-09-30 23:02:18 +05:30
- delete_k8s_release_namespace
2019-12-26 22:10:19 +05:30
2020-07-28 23:09:34 +05:30
.review-qa-base:
extends:
- .use-docker-in-docker
2021-09-30 23:02:18 +05:30
image:
2021-10-27 15:23:28 +05:30
name: ${QA_IMAGE}
2021-09-30 23:02:18 +05:30
entrypoint: [""]
2020-07-28 23:09:34 +05:30
stage: qa
2021-09-30 23:02:18 +05:30
needs: ["build-qa-image", "review-deploy"]
2020-07-28 23:09:34 +05:30
variables:
QA_DEBUG: "true"
2021-09-30 23:02:18 +05:30
QA_CAN_TEST_GIT_PROTOCOL_V2: "false"
2021-09-04 01:27:46 +05:30
QA_GENERATE_ALLURE_REPORT: "true"
2020-07-28 23:09:34 +05:30
GITLAB_USERNAME: "root"
GITLAB_PASSWORD: "${REVIEW_APPS_ROOT_PASSWORD}"
GITLAB_ADMIN_USERNAME: "root"
GITLAB_ADMIN_PASSWORD: "${REVIEW_APPS_ROOT_PASSWORD}"
GITHUB_ACCESS_TOKEN: "${REVIEW_APPS_QA_GITHUB_ACCESS_TOKEN}"
EE_LICENSE: "${REVIEW_APPS_EE_LICENSE}"
SIGNUP_DISABLED: "true"
before_script:
2021-09-30 23:02:18 +05:30
# Use $CI_MERGE_REQUEST_SOURCE_BRANCH_SHA so that GitLab image built in omnibus-gitlab-mirror and QA image are in sync.
- if [ -n "$CI_MERGE_REQUEST_SOURCE_BRANCH_SHA" ]; then
git checkout -f ${CI_MERGE_REQUEST_SOURCE_BRANCH_SHA};
fi
2020-07-28 23:09:34 +05:30
- export CI_ENVIRONMENT_URL="$(cat environment_url.txt)"
- echo "${CI_ENVIRONMENT_URL}"
2021-09-30 23:02:18 +05:30
- cd qa
2020-07-28 23:09:34 +05:30
artifacts:
paths:
2021-09-30 23:02:18 +05:30
- qa/tmp
2020-07-28 23:09:34 +05:30
expire_in: 7 days
when: always
2021-09-04 01:27:46 +05:30
.allure-report-base:
image:
2021-09-30 23:02:18 +05:30
name: ${GITLAB_DEPENDENCY_PROXY}andrcuns/allure-report-publisher:0.3.4
2021-09-04 01:27:46 +05:30
entrypoint: [""]
stage: post-qa
variables:
GIT_STRATEGY: none
STORAGE_CREDENTIALS: $QA_ALLURE_REPORT_GCS_CREDENTIALS
GITLAB_AUTH_TOKEN: $GITLAB_QA_MR_ALLURE_REPORT_TOKEN
allow_failure: true
script:
- |
allure-report-publisher upload gcs \
2021-09-30 23:02:18 +05:30
--results-glob="qa/tmp/allure-results/*" \
2021-09-04 01:27:46 +05:30
--bucket="gitlab-qa-allure-reports" \
--prefix="$ALLURE_REPORT_PATH_PREFIX/$CI_COMMIT_REF_SLUG" \
--update-pr="comment" \
--copy-latest \
--ignore-missing-results \
--color
2020-07-28 23:09:34 +05:30
review-qa-smoke:
extends:
- .review-qa-base
- .review:rules:review-qa-smoke
2021-09-04 01:27:46 +05:30
retry: 1 # This is confusing but this means "2 runs at max".
2020-07-28 23:09:34 +05:30
script:
2021-09-30 23:02:18 +05:30
- bin/test Test::Instance::Smoke "${CI_ENVIRONMENT_URL}"
2020-07-28 23:09:34 +05:30
review-qa-all:
extends:
- .review-qa-base
2021-04-29 21:17:54 +05:30
- .review:rules:review-qa-all
2020-07-28 23:09:34 +05:30
parallel: 5
script:
- export KNAPSACK_REPORT_PATH=knapsack/master_report.json
- export KNAPSACK_TEST_FILE_PATTERN=qa/specs/features/**/*_spec.rb
2021-09-30 23:02:18 +05:30
- |
bin/test Test::Instance::All "${CI_ENVIRONMENT_URL}" \
-- \
--color --format documentation \
--format RspecJunitFormatter --out tmp/rspec.xml
artifacts:
reports:
junit: qa/tmp/rspec.xml
2020-07-28 23:09:34 +05:30
review-performance:
extends:
- .default-retry
2020-11-24 15:15:51 +05:30
- .review:rules:review-performance
2020-07-28 23:09:34 +05:30
image:
2021-01-03 14:25:43 +05:30
name: sitespeedio/sitespeed.io
2020-07-28 23:09:34 +05:30
entrypoint: [""]
stage: qa
2021-06-08 01:23:25 +05:30
needs: ["review-deploy"]
2020-07-28 23:09:34 +05:30
before_script:
- export CI_ENVIRONMENT_URL="$(cat environment_url.txt)"
- echo "${CI_ENVIRONMENT_URL}"
- mkdir -p gitlab-exporter
- wget -O ./gitlab-exporter/index.js https://gitlab.com/gitlab-org/gl-performance/raw/master/index.js
- mkdir -p sitespeed-results
script:
- /start.sh --plugins.add ./gitlab-exporter --outputFolder sitespeed-results "${CI_ENVIRONMENT_URL}"
after_script:
- mv sitespeed-results/data/performance.json performance.json
artifacts:
paths:
- sitespeed-results/
reports:
performance: performance.json
expire_in: 31d
2021-09-04 01:27:46 +05:30
allure-report-qa-smoke:
extends:
- .allure-report-base
- .review:rules:review-qa-smoke-report
needs: ["review-qa-smoke"]
variables:
ALLURE_REPORT_PATH_PREFIX: gitlab-review-smoke
ALLURE_JOB_NAME: review-qa-smoke
allure-report-qa-all:
extends:
- .allure-report-base
- .review:rules:review-qa-all-report
needs: ["review-qa-all"]
variables:
ALLURE_REPORT_PATH_PREFIX: gitlab-review-all
ALLURE_JOB_NAME: review-qa-all
2019-07-31 22:56:46 +05:30
danger-review:
2019-12-04 20:38:33 +05:30
extends:
- .default-retry
2021-04-17 20:07:23 +05:30
- .danger-review-cache
2020-03-13 15:44:24 +05:30
- .review:rules:danger
2019-07-31 22:56:46 +05:30
stage: test
2020-04-08 14:13:33 +05:30
needs: []
2021-04-17 20:07:23 +05:30
before_script:
2021-06-08 01:23:25 +05:30
- source scripts/utils.sh
- bundle_install_script "--with danger"
2021-01-03 14:25:43 +05:30
- run_timed_command "retry yarn install --frozen-lockfile"
2021-04-17 20:07:23 +05:30
script:
2021-04-29 21:17:54 +05:30
- >
if [ -z "$DANGER_GITLAB_API_TOKEN" ]; then
2021-09-30 23:02:18 +05:30
run_timed_command danger_as_local
2021-04-29 21:17:54 +05:30
else
run_timed_command "bundle exec danger --fail-on-errors=true --verbose"
fi
2021-09-30 23:02:18 +05:30
danger-review-local:
extends:
- danger-review
- .review:rules:danger-local
script:
- run_timed_command danger_as_local