opentofu/terraform/plan_test.go

78 lines
1.5 KiB
Go
Raw Normal View History

package terraform
import (
"bytes"
2014-09-24 16:56:48 -05:00
"strings"
"testing"
)
func TestReadWritePlan(t *testing.T) {
plan := &Plan{
2014-09-24 16:56:48 -05:00
Module: testModule(t, "new-good"),
Diff: &Diff{
Modules: []*ModuleDiff{
&ModuleDiff{
Path: rootModulePath,
Resources: map[string]*InstanceDiff{
"nodeA": &InstanceDiff{
Attributes: map[string]*ResourceAttrDiff{
"foo": &ResourceAttrDiff{
Old: "foo",
New: "bar",
},
"bar": &ResourceAttrDiff{
Old: "foo",
NewComputed: true,
},
"longfoo": &ResourceAttrDiff{
Old: "foo",
New: "bar",
RequiresNew: true,
},
},
Meta: map[string]interface{}{
"foo": []interface{}{1, 2, 3},
},
},
},
},
},
},
State: &State{
2014-09-16 17:09:40 -05:00
Modules: []*ModuleState{
&ModuleState{
Path: rootModulePath,
Resources: map[string]*ResourceState{
"foo": &ResourceState{
Primary: &InstanceState{
ID: "bar",
},
},
},
},
},
},
Vars: map[string]interface{}{
"foo": "bar",
},
}
buf := new(bytes.Buffer)
if err := WritePlan(plan, buf); err != nil {
t.Fatalf("err: %s", err)
}
actual, err := ReadPlan(buf)
if err != nil {
t.Fatalf("err: %s", err)
}
2014-09-24 16:56:48 -05:00
actualStr := strings.TrimSpace(actual.String())
expectedStr := strings.TrimSpace(plan.String())
if actualStr != expectedStr {
t.Fatalf("bad:\n\n%s\n\nexpected:\n\n%s", actualStr, expectedStr)
}
}