Skip to content
Snippets Groups Projects
.gitlab-ci.yml 1.87 KiB
Newer Older
Nathan Rodet's avatar
Nathan Rodet committed
default:
  image: registry.gitlab.com/gitlab-org/terraform-images/stable:latest

variables:
Nathan Rodet's avatar
Nathan Rodet committed
  SSH_KEY_PATH: /tmp/sshkey
Nathan Rodet's avatar
Nathan Rodet committed
  ANSIBLE_ROOT: ${CI_PROJECT_DIR}/ansible
Nathan Rodet's avatar
Nathan Rodet committed
  ANSIBLE_HOST_FILE_PATH: ${CI_PROJECT_DIR}/ansible/hosts.yaml
  SCRIPTS_ROOT: ${CI_PROJECT_DIR}/scripts
Nathan Rodet's avatar
Nathan Rodet committed
  TF_ROOT: ${CI_PROJECT_DIR}/terraform
  TF_ADDRESS: ${CI_API_V4_URL}/projects/${CI_PROJECT_ID}/terraform/state/${TF_STATE_NAME}
Nathan Rodet's avatar
Nathan Rodet committed
  TF_STATE_NAME: ${ENVIRONMENT}-update
Nathan Rodet's avatar
Nathan Rodet committed
  TF_CACHE_KEY: default

before_script:
Nathan Rodet's avatar
Nathan Rodet committed
  - ssh-keygen -b 2048 -t rsa -C "${ENVIRONMENT}-cma-update-tmp" -f ${SSH_KEY_PATH} -q -N ""
Nathan Rodet's avatar
Nathan Rodet committed
  - cd ${TF_ROOT}
  - export TF_VAR_SCW_ACCESS_KEY=${TF_VAR_SCW_ACCESS_KEY}
  - export TF_VAR_SCW_SECRET_KEY=${TF_VAR_SCW_SECRET_KEY}
  - export TF_VAR_SCW_PROJECT_ID=${TF_VAR_SCW_PROJECT_ID}
Nathan RODET's avatar
Nathan RODET committed
  - export TF_VAR_ENVIRONMENT=${ENVIRONMENT}
  - export TF_VAR_INSTANCE_COUNT=${TF_VAR_INSTANCE_COUNT}
Nathan Rodet's avatar
Nathan Rodet committed
  - export TF_VAR_SSH_PUBLIC_KEY=$(cat ${SSH_KEY_PATH}.pub)
Nathan Rodet's avatar
Nathan Rodet committed

stages:
  - prepare
  - build
Nathan Rodet's avatar
Nathan Rodet committed
  - plan
Nathan Rodet's avatar
Nathan Rodet committed
  - deploy
  - destroy

Nathan Rodet's avatar
Nathan Rodet committed
sshkey:
Nathan Rodet's avatar
Nathan Rodet committed
  stage: prepare
  script:
Nathan Rodet's avatar
Nathan Rodet committed
    - echo ${TF_VAR_SSH_PUBLIC_KEY}
Nathan Rodet's avatar
Nathan Rodet committed
ansible-hosts-file:
  stage: prepare
  script:
Nathan Rodet's avatar
Nathan Rodet committed
    - chmod +x ${SCRIPTS_ROOT}/build-ansible-hosts.sh
Nathan Rodet's avatar
Nathan Rodet committed
    - . ${SCRIPTS_ROOT}/build-ansible-hosts.sh
Nathan Rodet's avatar
Nathan Rodet committed

Nathan Rodet's avatar
Nathan Rodet committed
init:
Nathan Rodet's avatar
Nathan Rodet committed
  stage: prepare
  script:
    - gitlab-terraform init

Nathan Rodet's avatar
Nathan Rodet committed
validate:
Nathan Rodet's avatar
Nathan Rodet committed
  stage: prepare
Nathan Rodet's avatar
Nathan Rodet committed
  script:
    - gitlab-terraform validate

Nathan Rodet's avatar
Nathan Rodet committed
plan:
Nathan Rodet's avatar
Nathan Rodet committed
  stage: build
  script:
    - gitlab-terraform plan
    - gitlab-terraform plan-json
  artifacts:
    name: plan
    paths:
      - ${TF_ROOT}/plan.cache
    reports:
      terraform: ${TF_ROOT}/plan.json

Nathan Rodet's avatar
Nathan Rodet committed
apply:
Nathan Rodet's avatar
Nathan Rodet committed
  stage: deploy
  environment:
    name: ${ENVIRONMENT}
  script:
    - gitlab-terraform apply
  dependencies:
    - plan

Nathan Rodet's avatar
Nathan Rodet committed
ansible:
Nathan Rodet's avatar
Nathan Rodet committed
  stage: deploy
  script:
Nathan Rodet's avatar
Nathan Rodet committed
    - ansible-playbook -i ${ANSIBLE_ROOT}/tasks/update.yaml --private-key ${SSH_KEY_PATH}
Nathan Rodet's avatar
Nathan Rodet committed
destroy:
Nathan Rodet's avatar
Nathan Rodet committed
  stage: destroy
  environment:
    name: ${ENVIRONMENT}
  script:
Nathan Rodet's avatar
Nathan Rodet committed
    - gitlab-terraform destroy