-
Notifications
You must be signed in to change notification settings - Fork 0
101 lines (83 loc) · 3.07 KB
/
terraform-modules-test-runs.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
name: terraform-modules-test-runs
on:
## push:
workflow_dispatch:
inputs:
directory:
description: 'Which resource to create'
required: true
default: ''
type: choice
options:
- aks
- loganalytics-ws
- managed-identity
- storage-account
- vmss-linux
- vnet
action:
description: 'Choose action: apply or destroy'
required: true
default: 'apply'
type: choice
options:
- apply
- destroy
#These environment variables are used by the terraform azure provider to setup OIDD authenticate.
env:
ARM_CLIENT_ID: "${{ secrets.AZURE_CLIENT_ID }}"
ARM_SUBSCRIPTION_ID: "${{ secrets.AZURE_SUBSCRIPTION_ID }}"
ARM_TENANT_ID: "${{ secrets.ARM_TENANT_ID }}"
ARM_CLIENT_SECRET: "${{ secrets.ARM_CLIENT_SECRET }}"
run-name: terraform-modules-runs - ${{ inputs.directory }} - ${{ inputs.action }}
jobs:
terraform-modules-test-runs:
runs-on: ubuntu-latest
steps:
- name: checkout repo
uses: actions/checkout@v4
- name: checking files
run: ls -la
- name: Token generator
uses: githubofkrishnadhas/github-access-using-githubapp@v2
id: app-token
with:
github_app_id: ${{ secrets.TOKEN_GENERATOR_APPID }}
github_app_private_key: ${{ secrets.TOKEN_GENERATOR_PRIVATE_KEY }}
owner: 'devwithkrishna'
repositories: 'azure-terraform-modules'
- name: Print the token
run: echo "Generated token ${{ steps.app-token.outputs.token }}"
- name: Token generator current repo
uses: githubofkrishnadhas/github-access-using-githubapp@v2
id: app-token1
with:
github_app_id: ${{ secrets.TOKEN_GENERATOR_APPID }}
github_app_private_key: ${{ secrets.TOKEN_GENERATOR_PRIVATE_KEY }}
- name: Print the token1
run: echo "Generated token ${{ steps.app-token1.outputs.token }}"
- name: setup for tfmodule
env:
token: ${{ steps.app-token.outputs.token }}
run: |
git config --local --remove-section http."https://github.com/"
git config --global url."https://githubofkrishnadhas:${{ steps.app-token.outputs.token }}@github.com/devwithkrishna".insteadOf "https://github.com/devwithkrishna"
- name: git config
run: git config --list --show-origin
- name: terraform setup
uses: hashicorp/setup-terraform@v3
with:
terraform_version: "1.5.7"
- name: terraform checking
run: |
terraform --version
- name: terraform init
run: terraform -chdir=${{ inputs.directory }} init
- name: Terraform Plan
run: terraform -chdir=${{ inputs.directory }} plan -out=planfile ${{ github.event.inputs.action == 'destroy' && '-destroy' || '' }}
- name: Terraform Apply
if: ${{ github.event.inputs.action == 'apply' }}
run: terraform -chdir=${{ inputs.directory }} apply -auto-approve planfile
- name: Terraform Destroy
if: ${{ github.event.inputs.action == 'destroy' }}
run: terraform -chdir=${{ inputs.directory }} apply -auto-approve planfile