Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/xsalazar/terraform-github-actions-example
Small examples showing how to use Terraform GitHub Actions within a repository
https://github.com/xsalazar/terraform-github-actions-example
github-actions terraform
Last synced: about 2 months ago
JSON representation
Small examples showing how to use Terraform GitHub Actions within a repository
- Host: GitHub
- URL: https://github.com/xsalazar/terraform-github-actions-example
- Owner: xsalazar
- Created: 2019-10-21T15:37:57.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2023-01-07T01:22:43.000Z (about 2 years ago)
- Last Synced: 2024-05-01T16:46:49.997Z (8 months ago)
- Topics: github-actions, terraform
- Language: HCL
- Homepage:
- Size: 258 KB
- Stars: 23
- Watchers: 4
- Forks: 12
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
Awesome Lists containing this project
README
# Terraform GitHub Actions Examples
This repository is a set of small examples that show how to use the official [Terraform GitHub Actions](https://github.com/hashicorp/setup-terraform) to run on your personal repositories.## Getting Started
The official Terraform documentation can be found [here](https://www.terraform.io/docs/github-actions/index.html)### Setting up secrets
In order to run `terraform plan` or `terraform apply`, you will potentially need to setup credentials to allow for the workflow to properly communicate with any cloud providers you may be using. In this example, since I am setting up an AWS provider and creating an EC2 instance, I need to pass through AWS credentials.You provision these per-repository. You can setup these secrets by going to the repository Settings > Secrets > Add new secret.
![Adding secrets](assets/secrets.png)
Once created, you can reference those secrets from the workflow by using `${{ secrets.AWS_ACCESS_KEY_ID }}` or `${{ secrets.AWS_SECRET_ACCESS_KEY }}`. This Action uses the [configure-aws-credentials](https://github.com/aws-actions/configure-aws-credentials) Action to set up the environment.
It is worth noting that `GITHUB_TOKEN` is [automatically provided](https://help.github.com/en/actions/automating-your-workflow-with-github-actions/authenticating-with-the-github_token) to workflows, and you do not need to manually set this up.
## Actions
### `terraform fmt`
You can see an example of this command being run in [this pull request](https://github.com/xsalazar/terraform-github-actions-example/pull/19).
![terraform fmt](assets/format.png)### `terraform validate`
You can see an example of this command being run in [this pull request](https://github.com/xsalazar/terraform-github-actions-example/pull/21).
![terraform validate](assets/validate.png)### `terraform plan`
You can see an example of this command being run in [this pull request](https://github.com/xsalazar/terraform-github-actions-example/pull/20). The plan output is too long to include here, but you can expand the output in the original comment.
![terraform plan](assets/plan.png)