Terraform Cloud Action
ActionsTags
(2)An action to run Terraform Cloud workspaces
This action submits a run to a Terraform Cloud workspace which performs a plan and apply. Once the run is succesfully submitted the action returns a success, leaving the plan and apply to continue to run in Terraform Cloud.
Terraform Cloud requires a .tar.gz archive containing the Terraform configuration, and build artifacts if required. The example shows a GitHub workflow archiving Lambda functions (in the build
directory) alongside a Terraform configuration (in the infrastructure
directory) for deployment. The archive is then passed to the action for deployment by Terraform Cloud.
- name: Create tar gz file
run: tar --exclude *.terraform* -zcvf build.tar.gz build infrastructure
- name: Terraform Cloud
uses: addresscloud/terraform-cloud-action@master
with:
tfToken: ${{ secrets.TERRAFORM_TOKEN }}
tfOrg: '<ORGANISATION>'
tfWorkspace: 'my-lambda-service'
filePath: './build.tar.gz'
identifier: ${{ github.sha }}
The inputs below are required by the action to submit the run to Terraform Cloud. Additional workspace variables and settings should be configured using the Terraform Cloud UI.
Required - Terraform Cloud access token.
Required - Terraform Cloud organization.
Required - Name of existing Terraform Cloud workspace.
Required - Path to .tar.gz archive with Terraform configuration.
Required - Unique identifier for the run (e.g. git commit sha). Reduced to 7 characters for brevity.
The identfier of the run in Terraform Cloud.
If your repository contains multiple modules, upload the top-level directory and configure the root workspace path in the Terraform Cloud UI. For example, to deploy
infrastructure/dev/services/lambda/main.tf
which has references to modules in infrastructure/modules/services/lambda/module.tf
upload the entire infrastructure
directory and configure infrastructure/dev/services/lambda/
as the root of the workspace in the Terraform Cloud UI.
PRs accepted with unit tests.
To run tests:
npm run test
To check code lint:
npm run lint
Small note: If editing the README, please conform to the standard-readme specification.
This Action was based on the example Terraform Enterprise script at: https://github.com/hashicorp/terraform-guides/tree/master/operations/automation-script
MPL-2.0 © 2019 Addresscloud Limited
Terraform Cloud Action is not certified by GitHub. It is provided by a third-party and is governed by separate terms of service, privacy policy, and support documentation.