Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

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: 2 months ago
JSON representation

Go module for Terraform module testing with fluent assertions

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 test

import (
"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)
}
```