Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/azure/terratest-terraform-fluent
Go module for Terraform module testing with fluent assertions
https://github.com/azure/terratest-terraform-fluent
go golang terraform terraform-module terratest testing
Last synced: 4 months ago
JSON representation
Go module for Terraform module testing with fluent assertions
- Host: GitHub
- URL: https://github.com/azure/terratest-terraform-fluent
- Owner: Azure
- License: mit
- Created: 2023-04-05T13:26:59.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-10-02T11:49:40.000Z (4 months ago)
- Last Synced: 2024-10-07T12:39:44.958Z (4 months ago)
- Topics: go, golang, terraform, terraform-module, terratest, testing
- Language: Go
- Homepage: https://pkg.go.dev/github.com/Azure/terratest-terraform-fluent
- Size: 14.7 MB
- Stars: 13
- Watchers: 4
- Forks: 2
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.md
- Support: SUPPORT.md
Awesome Lists containing this project
README
# terratest-terraform-fluent
[![codecov](https://codecov.io/gh/Azure/terratest-terraform-fluent/branch/main/graph/badge.svg?token=oBG1qFc8S6)](https://codecov.io/gh/Azure/terratest-terraform-fluent)
Terratest extension package for testing Terraform code with fluent assertions.
## Usage
```go
package testimport (
"testing""github.com/Azure/terratest-terraform-fluent/check"
"github.com/Azure/terratest-terraform-fluent/setuptest"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)const (
moduleDir = "../"
)func TestSomeTerraform(t *testing.T) {
// Set up the Terraform test and run terraform init, plan and show,
// saving the plan output to a struct.
// The returned struct in tftest contains the temp dir, the plan struct,
// the terraform options, and the clean up func.
//
// The Dirs inputs are the test root directory and the relative path to the test code.
// (this must be a subdirectory of the test root directory).
// To test the module in the current directory, use "" for the second input.
//
// The WithVars inputs are the Terraform variables to pass to the test.
// The InitPlanShow input is the testing.T pointer.
tftest, err := setuptest.Dirs(moduleDir, "").WithVars(nil).InitPlanShow(t)
require.NoError(t, err)// Defer the cleanup, which will delete the temporary directory and provide coherent logging.
// THIS IS VERY IMPORTANT :)
defer tftest.Cleanup()// Check that the plan contains the expected number of resources.
check.InPlan(tftest.Plan).NumberOfResourcesEquals(1).ErrorIsNil(t)// Check that the plan contains the expected resource, with an attribute called `my_attribute` and
// a corresponding value of `my_value`.
check.InPlan(tftest.Plan).That("my_terraform_resource.name").Key("my_attribute").HasValue("my_value").ErrorIsNil(t)// Check that the plan contains the expected resource, with an attribute called `my_complex_attribute` and
// a gjson query in a list called `mylist`, taking the first element, which is an object with a property
// called `property`, with a value of `my_value`. See: https://github.com/tidwall/gjson/blob/master/SYNTAX.md
check.InPlan(tftest.Plan).That("my_terraform_resource.name").Key("my_complex_attribute").Query("mylist.0.property").HasValue("my_value").ErrorIsNil(t)// Ensure that the terraform apply is idempotent.
defer tftest.Destroy()
tftest.ApplyIdempotent().ErrorIsNil(t)// Retrieve the value from the plan and check it using an external func.
val, err := check.InPlan(tftest.Plan).That("my_terraform_resource.name").Key("my_other_attribute").GetValue()
assert.NoError(t, err)
assert.NoError(t, myValidationFunc(val))// Check that the output contains the expected value.
tftest.Output("my_output").HasValue("my_output_value").ErrorIsNil(t)
}
```