opentofu/terraform/transform_module_variable_test.go

66 lines
1.4 KiB
Go
Raw Normal View History

package terraform
import (
"strings"
"testing"
)
func TestModuleVariableTransformer(t *testing.T) {
g := Graph{Path: RootModulePath}
module := testModule(t, "transform-module-var-basic")
{
tf := &RootVariableTransformer{Module: module}
if err := tf.Transform(&g); err != nil {
t.Fatalf("err: %s", err)
}
}
{
tf := &ModuleVariableTransformer{Module: module, DisablePrune: true}
if err := tf.Transform(&g); err != nil {
t.Fatalf("err: %s", err)
}
}
actual := strings.TrimSpace(g.String())
expected := strings.TrimSpace(testTransformModuleVarBasicStr)
if actual != expected {
t.Fatalf("bad:\n\n%s", actual)
}
}
func TestModuleVariableTransformer_nested(t *testing.T) {
g := Graph{Path: RootModulePath}
module := testModule(t, "transform-module-var-nested")
{
tf := &RootVariableTransformer{Module: module}
if err := tf.Transform(&g); err != nil {
t.Fatalf("err: %s", err)
}
}
{
tf := &ModuleVariableTransformer{Module: module, DisablePrune: true}
if err := tf.Transform(&g); err != nil {
t.Fatalf("err: %s", err)
}
}
actual := strings.TrimSpace(g.String())
expected := strings.TrimSpace(testTransformModuleVarNestedStr)
if actual != expected {
t.Fatalf("bad:\n\n%s", actual)
}
}
const testTransformModuleVarBasicStr = `
module.child.var.value
`
const testTransformModuleVarNestedStr = `
module.child.module.child.var.value
module.child.var.value
`