Skip to content

Commit

Permalink
Merge branch 'main' into github_script
Browse files Browse the repository at this point in the history
  • Loading branch information
arnol377 committed Aug 15, 2024
2 parents c309667 + 83e0349 commit e89a87b
Show file tree
Hide file tree
Showing 3 changed files with 64 additions and 87 deletions.
64 changes: 32 additions & 32 deletions .terraform.lock.hcl

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

8 changes: 8 additions & 0 deletions image-pipeline.tf
Original file line number Diff line number Diff line change
Expand Up @@ -84,6 +84,10 @@ module "aws_image_pipeline" {
{
repo_name = "aws-image-pipeline",
directory = null
git_owner = {
name = "arnol377"
email = "david.j.arnold.jr@census.gov"
}
}
)
},
Expand Down Expand Up @@ -129,6 +133,10 @@ module "terraform_aws_image_pipeline" {
{
repo_name = "aws-image-pipeline",
directory = "./examples"
git_owner = {
name = "arnol377"
email = "david.j.arnold.jr@census.gov"
}
}
)
}
Expand Down
79 changes: 24 additions & 55 deletions workflows/terraform-plan.yaml.tpl
Original file line number Diff line number Diff line change
Expand Up @@ -33,15 +33,22 @@ jobs:
- uses: CSVD/gh-actions-setup-terraform@v2
with:
terraform_version: $${{ vars.terraform_version }}

- name: Terraform Format
id: fmt
continue-on-error: true
%{ if directory != null }
working-directory: ${directory}
%{ endif }
run: |
terraform fmt -check
terraform fmt
if ! git diff-index --quiet HEAD; then
git config --global user.name '${git_owner.name}'
git config --global user.email '${git_owner.email}'
git commit -am "Autoformatting TF Code"
git push
echo "auto_format=true" >> $GITHUB_ENV
fi

- name: Autoformat Halt
if: env.auto_format == 'true'
run: exit 1

- name: Terraform Init
id: init
Expand All @@ -65,60 +72,22 @@ jobs:
run: terraform plan
continue-on-error: true

- uses: actions/github-script@v7
- name: Update Pull Request
uses: CSVD/gh-actions-github-script@v6
if: github.event_name == 'pull_request'
env:
PLAN: "terraform\n$${{ steps.plan.outputs.stdout }}"
with:
github-token: $${{ secrets.GH_TOKEN }}
script: |
// 1. Retrieve existing bot comments for the PR
const { data: comments } = await github.rest.issues.listComments({
owner: context.repo.owner,
repo: context.repo.repo,
issue_number: context.issue.number,
})
const botComment = comments.find(comment => {
return comment.user.type === 'Bot' && comment.body.includes('Terraform Format and Style')
})

// 2. Prepare format of the comment
const output = `#### Terraform Format and Style 🖌\`$${{ steps.fmt.outcome }}\`
#### Terraform Initialization ⚙️\`$${{ steps.init.outcome }}\`
#### Terraform Validation 🤖\`$${{ steps.validate.outcome }}\`
<details><summary>Validation Output</summary>
#### Terraform Plan:
$${{ steps.plan.outcome }}
*Pushed by: @$${{ github.actor }}, Action: \`$${{ github.event_name }}\`*`;

\`\`\`\n
$${{ steps.validate.outputs.stdout }}
\`\`\`

</details>

#### Terraform Plan 📖\`$${{ steps.plan.outcome }}\`

<details><summary>Show Plan</summary>

\`\`\`\n
$${process.env.PLAN}
\`\`\`

</details>

*Pusher: @$${{ github.actor }}, Action: \`$${{ github.event_name }}\`, Working Directory: \`$${{ env.tf_actions_working_dir }}\`, Workflow: \`$${{ github.workflow }}\`*`;

// 3. If we have a comment, update it, otherwise create a new one
if (botComment) {
github.rest.issues.updateComment({
owner: context.repo.owner,
repo: context.repo.repo,
comment_id: botComment.id,
body: output
})
} else {
github.rest.issues.createComment({
issue_number: context.issue.number,
owner: context.repo.owner,
repo: context.repo.repo,
body: output
})
}
github.rest.issues.createComment({
issue_number: context.issue.number,
owner: context.repo.owner,
repo: context.repo.repo,
body: output
})

0 comments on commit e89a87b

Please sign in to comment.