mirror of
https://github.com/sidpalas/devops-directive-terraform-course.git
synced 2025-12-10 12:51:14 +00:00
[Feature] Add github action workflow (#1)
This commit is contained in:
24
.github/workflows/terraform.yml
vendored
24
.github/workflows/terraform.yml
vendored
@@ -4,6 +4,8 @@ on:
|
|||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
- main
|
- main
|
||||||
|
tags:
|
||||||
|
- v\d+\.\d+\.\d+$
|
||||||
pull_request:
|
pull_request:
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
@@ -36,7 +38,7 @@ jobs:
|
|||||||
- name: Terraform Plan
|
- name: Terraform Plan
|
||||||
id: plan
|
id: plan
|
||||||
if: github.event_name == 'pull_request'
|
if: github.event_name == 'pull_request'
|
||||||
run: terraform plan -no-color
|
run: terraform plan -var db_pass=${{secrets.DB_PASS }} -no-color
|
||||||
continue-on-error: true
|
continue-on-error: true
|
||||||
|
|
||||||
- uses: actions/github-script@0.9.0
|
- uses: actions/github-script@0.9.0
|
||||||
@@ -70,6 +72,20 @@ jobs:
|
|||||||
if: steps.plan.outcome == 'failure'
|
if: steps.plan.outcome == 'failure'
|
||||||
run: exit 1
|
run: exit 1
|
||||||
|
|
||||||
# - name: Terraform Apply
|
- name: Check tag
|
||||||
# if: github.ref == 'refs/heads/main' && github.event_name == 'push'
|
id: check-tag
|
||||||
# run: terraform apply -auto-approve
|
run: |
|
||||||
|
if [[ ${{ github.ref }} =~ ^refs/tags/vd+\.d+\.d+$ ]]; then echo ::set-output name=environment::production
|
||||||
|
elif [[ github.ref == 'refs/heads/main' ]]; then echo ::set-output name=environment::staging
|
||||||
|
else echo ::set-output name=environment::unknown
|
||||||
|
fi
|
||||||
|
|
||||||
|
- name: Terraform Apply Staging
|
||||||
|
if: steps.check-tag.outputs.environment == 'production' && github.event_name == 'push'
|
||||||
|
working-directory: 07-managing-multiple-environments/file-structure/staging
|
||||||
|
run: terraform apply -var db_pass=${{secrets.DB_PASS }} -auto-approve
|
||||||
|
|
||||||
|
- name: Terraform Apply Production
|
||||||
|
if: steps.check-tag.outputs.environment == 'staging' && github.event_name == 'push'
|
||||||
|
working-directory: 07-managing-multiple-environments/file-structure/production
|
||||||
|
run: terraform apply -var db_pass=${{secrets.DB_PASS }} -auto-approve
|
||||||
|
|||||||
@@ -0,0 +1,27 @@
|
|||||||
|
terraform {
|
||||||
|
# Assumes s3 bucket and dynamo DB table already set up
|
||||||
|
# See /code/03-basics/aws-backend
|
||||||
|
backend "s3" {
|
||||||
|
bucket = "devops-directive-tf-state"
|
||||||
|
key = "07-managing-multiple-environments/global/terraform.tfstate"
|
||||||
|
region = "us-east-1"
|
||||||
|
dynamodb_table = "terraform-state-locking"
|
||||||
|
encrypt = true
|
||||||
|
}
|
||||||
|
|
||||||
|
required_providers {
|
||||||
|
aws = {
|
||||||
|
source = "hashicorp/aws"
|
||||||
|
version = "~> 3.0"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
provider "aws" {
|
||||||
|
region = "us-east-1"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Route53 zone is shared across staging and production
|
||||||
|
resource "aws_route53_zone" "primary" {
|
||||||
|
name = "mysuperawesomesite.com"
|
||||||
|
}
|
||||||
@@ -39,7 +39,7 @@ module "web_app" {
|
|||||||
domain = "mysuperawesomesite.com"
|
domain = "mysuperawesomesite.com"
|
||||||
environment_name = local.environment_name
|
environment_name = local.environment_name
|
||||||
instance_type = "t2.small"
|
instance_type = "t2.small"
|
||||||
create_dns_zone = true
|
create_dns_zone = false
|
||||||
db_name = "${local.environment_name}mydb"
|
db_name = "${local.environment_name}mydb"
|
||||||
db_user = "foo"
|
db_user = "foo"
|
||||||
db_pass = var.db_pass
|
db_pass = var.db_pass
|
||||||
|
|||||||
Reference in New Issue
Block a user