Skip to content

Commit

Permalink
test workflow
Browse files Browse the repository at this point in the history
  • Loading branch information
baksetercx committed May 6, 2024
1 parent d2bbfb3 commit c4b5be8
Show file tree
Hide file tree
Showing 4 changed files with 48 additions and 30 deletions.
50 changes: 35 additions & 15 deletions .github/workflows/deploy.yml
Original file line number Diff line number Diff line change
@@ -1,19 +1,22 @@
name: 'Deploy'

on:
pull_request:
push:
branches: ['workshop/*']

jobs:
set_name:
name: 'Get name from branch name and set env'
set-name:
name: 'Get name from branch name and set output'
outputs:
my_name: ${{ steps.set-name.outputs.my_name }}
runs-on: ubuntu-latest
steps:
- run: echo "MY_NAME=${BRANCH##*/}" >> "$GITHUB_ENV"
- name: 'Set name'
id: set-name
run: echo "my_name=${BRANCH##*/}" >> "$GITHUB_OUTPUT"
env:
BRANCH: ${{ github.ref_name }}

run_tests:
run-tests:
name: 'Run frontend tests'
runs-on: ubuntu-latest
defaults:
Expand Down Expand Up @@ -44,36 +47,46 @@ jobs:
build:
name: 'Build Docker image and push to registry'
# Task A.2:
# needs: [set_name]
# needs: [set-name]
# Answer A.2:
needs: [set_name, run_tests]
needs: [set-name, run-tests]
#
runs-on: ubuntu-latest
permissions:
contents: read
packages: write
steps:
- name: Checkout repository
uses: actions/checkout@v4

- name: Login to GitHub Container Registry
uses: docker/login-action@v3
with:
registry: 'ghcr.io'
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}

- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3

- name: Build and push image to registry
uses: docker/build-push-action@v5
with:
push: 'true'
tags: 'ghcr.io/${{ github.repository }}/${{ env.MY_NAME }}:latest'
file: 'frontend/Dockerfile'
tags: 'ghcr.io/${{ github.repository }}/${{ needs.set-name.outputs.my_name }}:latest'
context: 'frontend'

deploy:
name: 'Deploy using Terraform'
runs-on: ubuntu-latest
needs: [build]
env:
TF_VAR_revision_suffix: ${{ github.sha }}
TF_VAR_my_name: ${{ env.MY_NAME }}
ARM_CLIENT_ID: ${{ vars.ARM_CLIENT_ID }}
ARM_CLIENT_SECRET: ${{ secrets.ARM_CLIENT_SECRET }}
ARM_SUBSCRIPTION_ID: ${{ vars.ARM_SUBSCRIPTION_ID }}
ARM_TENANT_ID: ${{ vars.ARM_TENANT_ID }}
TF_VAR_my_name: ${{ needs.set-name.outputs.my_name }}
permissions:
contents: read
id-token: write
environment: prod
defaults:
run:
working-directory: 'terraform'
Expand All @@ -84,6 +97,13 @@ jobs:
- name: Setup Terraform
uses: hashicorp/setup-terraform@v3

- name: Authenticate with Azure
uses: azure/login@v2
with:
client-id: ${{ vars.ARM_CLIENT_ID }}
tenant-id: ${{ vars.ARM_TENANT_ID }}
subscription-id: ${{ vars.ARM_SUBSCRIPTION_ID }}

- name: Init Terraform
run: terraform init

Expand Down
9 changes: 9 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -229,3 +229,12 @@ resource "azurerm_container_app" "devops" {
```

</details>

# Setup (ikke en del av workshop'en)

1. Få den en Azure subscription.

2. Lag en ny Storage Account i Azure for å lagre Terraform state.
Bruk skriptet `bootstrap.sh` for å sette opp en ny Storage Account.

3. Lag en App Registration i Entra, og pek den mot riktig GitHub repo/environment.
11 changes: 0 additions & 11 deletions bootstrap.sh
Original file line number Diff line number Diff line change
Expand Up @@ -9,12 +9,6 @@ create() {
local location="$4"
local subscription_id="$5"

# Create service principal
az ad sp create-for-rbac \
--name "terraform" \
--role "Contributor" \
--scopes "/subscriptions/$subscription_id"

# Create resource group
az group create \
--name "$resource_group_name" \
Expand Down Expand Up @@ -78,11 +72,6 @@ delete() {
az group delete \
--name "$resource_group_name" \
--yes

# Delete service principal
local sp_name
sp_name=$(az ad sp list --display-name terraform --query '[0].appId' -o tsv)
az ad sp delete --id "$sp_name"
}

main() {
Expand Down
8 changes: 4 additions & 4 deletions terraform/providers.tf
Original file line number Diff line number Diff line change
Expand Up @@ -7,10 +7,10 @@ terraform {
}

backend "azurerm" {
resource_group_name = "tfstate"
storage_account_name = "tfstate24321"
container_name = "tfstate"
key = "terraform.tfstate"
resource_group_name = "tfstate"
storage_account_name = "tfstate27968"
container_name = "tfstate"
key = "terraform.tfstate"
}
}

Expand Down

0 comments on commit c4b5be8

Please sign in to comment.