2022-10-03 11:09:42 -04:00
default :
interruptible : true
2021-10-14 11:14:02 -04:00
stages :
- prepare
- deploy
- qa
- post-qa
- dast
include :
- local : .gitlab/ci/global.gitlab-ci.yml
- local : .gitlab/ci/rules.gitlab-ci.yml
2022-09-15 02:12:51 -04:00
- local : .gitlab/ci/review-apps/rules.gitlab-ci.yml
2021-10-14 11:14:02 -04:00
- local : .gitlab/ci/review-apps/qa.gitlab-ci.yml
- local : .gitlab/ci/review-apps/dast.gitlab-ci.yml
.base-before_script : &base-before_script
- source ./scripts/utils.sh
- source ./scripts/review_apps/review-apps.sh
2022-07-21 11:09:12 -04:00
- apt-get update && apt-get install -y jq
2021-10-14 11:14:02 -04:00
2022-10-03 11:09:42 -04:00
dont-interrupt-me :
extends : .rules:dont-interrupt
stage : prepare
interruptible : false
script :
- echo "This jobs makes sure this pipeline won't be interrupted! See https://docs.gitlab.com/ee/ci/yaml/#interruptible."
2022-02-15 07:14:49 -05:00
review-build-cng-env :
2021-10-14 11:14:02 -04:00
extends :
- .default-retry
- .review:rules:review-build-cng
2022-07-04 11:10:24 -04:00
image : ${GITLAB_DEPENDENCY_PROXY}ruby:3.0-alpine3.13
2021-10-14 11:14:02 -04:00
stage : prepare
2022-02-15 07:14:49 -05:00
needs : [ ]
2021-10-14 11:14:02 -04:00
before_script :
- source ./scripts/utils.sh
- install_gitlab_gem
script :
2022-02-15 07:14:49 -05:00
- 'ruby -r./scripts/trigger-build.rb -e "puts Trigger.variables_for_env_file(Trigger::CNG.new.variables)" > build.env'
- cat build.env
artifacts :
reports :
dotenv : build.env
paths :
- build.env
expire_in : 7 days
when : always
review-build-cng :
extends : .review:rules:review-build-cng
stage : prepare
needs : [ "review-build-cng-env" ]
inherit :
variables : false
variables :
TOP_UPSTREAM_SOURCE_PROJECT : "${TOP_UPSTREAM_SOURCE_PROJECT}"
TOP_UPSTREAM_SOURCE_REF : "${TOP_UPSTREAM_SOURCE_REF}"
TOP_UPSTREAM_SOURCE_JOB : "${TOP_UPSTREAM_SOURCE_JOB}"
TOP_UPSTREAM_SOURCE_SHA : "${TOP_UPSTREAM_SOURCE_SHA}"
TOP_UPSTREAM_MERGE_REQUEST_PROJECT_ID : "${TOP_UPSTREAM_MERGE_REQUEST_PROJECT_ID}"
TOP_UPSTREAM_MERGE_REQUEST_IID : "${TOP_UPSTREAM_MERGE_REQUEST_IID}"
GITLAB_REF_SLUG : "${GITLAB_REF_SLUG}"
# CNG pipeline specific variables
GITLAB_VERSION : "${GITLAB_VERSION}"
GITLAB_TAG : "${GITLAB_TAG}"
GITLAB_ASSETS_TAG : "${GITLAB_ASSETS_TAG}"
FORCE_RAILS_IMAGE_BUILDS : "${FORCE_RAILS_IMAGE_BUILDS}"
CE_PIPELINE : "${CE_PIPELINE}" # Based on https://docs.gitlab.com/ee/ci/jobs/job_control.html#check-if-a-variable-exists, `if: '$CE_PIPELINE'` will evaluate to `false` when this variable is empty
EE_PIPELINE : "${EE_PIPELINE}" # Based on https://docs.gitlab.com/ee/ci/jobs/job_control.html#check-if-a-variable-exists, `if: '$EE_PIPELINE'` will evaluate to `false` when this variable is empty
GITLAB_SHELL_VERSION : "${GITLAB_SHELL_VERSION}"
GITLAB_ELASTICSEARCH_INDEXER_VERSION : "${GITLAB_ELASTICSEARCH_INDEXER_VERSION}"
GITLAB_KAS_VERSION : "${GITLAB_KAS_VERSION}"
GITLAB_WORKHORSE_VERSION : "${GITLAB_WORKHORSE_VERSION}"
GITLAB_PAGES_VERSION : "${GITLAB_PAGES_VERSION}"
GITALY_SERVER_VERSION : "${GITALY_SERVER_VERSION}"
trigger :
project : gitlab-org/build/CNG-mirror
branch : $TRIGGER_BRANCH
strategy : depend
2021-10-14 11:14:02 -04:00
.review-workflow-base :
extends :
- .default-retry
2022-07-21 11:09:12 -04:00
image : ${REVIEW_APPS_IMAGE}
2021-10-14 11:14:02 -04:00
variables :
HOST_SUFFIX : "${CI_ENVIRONMENT_SLUG}"
DOMAIN : "-${CI_ENVIRONMENT_SLUG}.${REVIEW_APPS_DOMAIN}"
2022-07-18 14:08:47 -04:00
GITLAB_HELM_CHART_REF : "138c146a5ba787942f66d4c7d795d224d6ba206a"
2021-10-14 11:14:02 -04:00
environment :
2022-07-04 11:10:24 -04:00
name : review/${CI_COMMIT_REF_SLUG}${SCHEDULE_TYPE} # No separator for SCHEDULE_TYPE so it's compatible as before and looks nice without it
2021-10-14 11:14:02 -04:00
url : https://gitlab-${CI_ENVIRONMENT_SLUG}.${REVIEW_APPS_DOMAIN}
on_stop : review-stop
auto_stop_in : 48 hours
review-deploy :
extends :
- .review-workflow-base
- .review:rules:review-deploy
stage : deploy
needs : [ "review-build-cng" ]
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
2022-09-15 02:12:51 -04:00
- echo "QA_GITLAB_URL=${CI_ENVIRONMENT_URL}" > environment.env
2021-10-14 11:14:02 -04:00
- *base-before_script
script :
- check_kube_domain
- download_chart
- date
- deploy || (display_deployment_debug && exit 1)
- verify_deploy || exit 1
- disable_sign_ups || (delete_release && exit 1)
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
artifacts :
paths :
- environment_url.txt
2022-09-15 02:12:51 -04:00
reports :
dotenv : environment.env
2021-10-14 11:14:02 -04:00
expire_in : 7 days
when : always
2022-09-01 17:10:22 -04:00
review-deploy-sample-projects :
extends :
- .review-workflow-base
- .review:rules:review-deploy
stage : deploy
needs : [ "review-deploy" ]
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
- *base-before_script
script :
- date
- create_sample_projects
2021-10-14 11:14:02 -04:00
.review-stop-base :
extends : .review-workflow-base
environment :
action : stop
dependencies : [ ]
variables :
# 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
before_script :
- *base-before_script
review-delete-deployment :
extends :
- .review-stop-base
- .review:rules:review-delete-deployment
stage : prepare
script :
- delete_release
review-stop :
extends :
- .review-stop-base
- .review:rules:review-stop
2022-07-21 17:10:17 -04:00
resource_group : review/${CI_COMMIT_REF_SLUG}${SCHEDULE_TYPE} # CI_ENVIRONMENT_SLUG is not available here and we want this to be the same as the environment
2021-10-29 02:09:33 -04:00
stage : deploy
needs : [ ]
2021-10-14 11:14:02 -04:00
script :
2021-12-15 10:15:54 -05:00
- delete_namespace