-
Notifications
You must be signed in to change notification settings - Fork 8
68 lines (62 loc) · 2.12 KB
/
terraform.yml
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
---
name: 'Terraform'
on:
pull_request:
branches:
- main
- develop
jobs:
terraform:
name: 'Terraform'
runs-on: [ubuntu-latest]
environment: develop
timeout-minutes: 10
defaults:
run:
shell: bash
env:
TERRAFORM_VERSION: '~1.1.0'
steps:
# Checkout that allows the step render terraform docs to work properly on non main or develop branch
- name: 'Checkout'
uses: actions/checkout@v2
if: ${{ ! startsWith(github.ref, 'refs/heads/main') && ! startsWith(github.ref, 'refs/heads/develop') }}
with:
ref: ${{ github.event.pull_request.head.ref }}
- name: 'Checkout'
uses: actions/checkout@v2
if: ${{ startsWith(github.ref, 'refs/heads/main') || startsWith(github.ref, 'refs/heads/develop') }}
- name: Render terraform docs inside the README.md and push changes back to PR branch
uses: terraform-docs/gh-actions@v0.6.0
if: ${{ ! startsWith(github.ref, 'refs/heads/main') && ! startsWith(github.ref, 'refs/heads/develop') }}
with:
find-dir: modules
output-file: README.md
output-method: inject
git-push: "true"
- name: 'Setup Terraform'
uses: hashicorp/setup-terraform@v1
with:
terraform_version: ${{ env.TERRAFORM_VERSION }}
- name: 'Init and check Terraform modules'
run: |
set -euxo pipefail
terraform --version
TF_MODULES_DIR=$(find "${GITHUB_WORKSPACE}/" -type f -name 'main.tf' -print0 | xargs -0 -L1 dirname)
for MODULE_DIR in ${TF_MODULES_DIR}; do
pushd "${MODULE_DIR}" || exit
echo "Module: $(basename "${MODULE_DIR}")"
echo "Action: INIT"
terraform init -backend=false
echo "Action: CHECK SYNTAX"
terraform fmt -check
echo "Action: VALIDATE"
terraform validate
popd || exit
done
- name: clean
uses: docker://centos
if: ${{ always() }}
continue-on-error: true
with:
args: "/bin/rm /github/workspace -rf"