mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-16 11:42:58 -06:00
a1727ec4c2
Forward-port the plan state check from the 0.9 series. 0.10 has improved the serial handling for the state, so this adds relevant comments and some more test coverage for the case of an incrementing serial during apply.
170 lines
3.3 KiB
Go
170 lines
3.3 KiB
Go
package terraform
|
|
|
|
import (
|
|
"bytes"
|
|
"reflect"
|
|
"strings"
|
|
"testing"
|
|
|
|
"github.com/hashicorp/terraform/config/module"
|
|
)
|
|
|
|
func TestPlanContextOpts(t *testing.T) {
|
|
plan := &Plan{
|
|
Diff: &Diff{
|
|
Modules: []*ModuleDiff{
|
|
{
|
|
Path: []string{"test"},
|
|
},
|
|
},
|
|
},
|
|
Module: module.NewTree("test", nil),
|
|
State: &State{
|
|
TFVersion: "sigil",
|
|
},
|
|
Vars: map[string]interface{}{"foo": "bar"},
|
|
Targets: []string{"baz"},
|
|
|
|
TerraformVersion: VersionString(),
|
|
ProviderSHA256s: map[string][]byte{
|
|
"test": []byte("placeholder"),
|
|
},
|
|
}
|
|
|
|
got, err := plan.contextOpts(&ContextOpts{})
|
|
if err != nil {
|
|
t.Fatalf("error creating context: %s", err)
|
|
}
|
|
|
|
want := &ContextOpts{
|
|
Diff: plan.Diff,
|
|
Module: plan.Module,
|
|
State: plan.State,
|
|
Variables: plan.Vars,
|
|
Targets: plan.Targets,
|
|
ProviderSHA256s: plan.ProviderSHA256s,
|
|
}
|
|
|
|
if !reflect.DeepEqual(got, want) {
|
|
t.Errorf("wrong result\ngot: %#v\nwant %#v", got, want)
|
|
}
|
|
}
|
|
|
|
func TestReadWritePlan(t *testing.T) {
|
|
plan := &Plan{
|
|
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{
|
|
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)
|
|
}
|
|
|
|
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)
|
|
}
|
|
}
|
|
|
|
func TestPlanContextOptsOverrideStateGood(t *testing.T) {
|
|
plan := &Plan{
|
|
Diff: &Diff{
|
|
Modules: []*ModuleDiff{
|
|
{
|
|
Path: []string{"test"},
|
|
},
|
|
},
|
|
},
|
|
Module: module.NewTree("test", nil),
|
|
State: &State{
|
|
TFVersion: "sigil",
|
|
Serial: 1,
|
|
},
|
|
Vars: map[string]interface{}{"foo": "bar"},
|
|
Targets: []string{"baz"},
|
|
|
|
TerraformVersion: VersionString(),
|
|
ProviderSHA256s: map[string][]byte{
|
|
"test": []byte("placeholder"),
|
|
},
|
|
}
|
|
|
|
base := &ContextOpts{
|
|
State: &State{
|
|
TFVersion: "sigil",
|
|
Serial: 2,
|
|
},
|
|
}
|
|
|
|
got, err := plan.contextOpts(base)
|
|
if err != nil {
|
|
t.Fatalf("error creating context: %s", err)
|
|
}
|
|
|
|
want := &ContextOpts{
|
|
Diff: plan.Diff,
|
|
Module: plan.Module,
|
|
State: base.State,
|
|
Variables: plan.Vars,
|
|
Targets: plan.Targets,
|
|
ProviderSHA256s: plan.ProviderSHA256s,
|
|
}
|
|
|
|
if !reflect.DeepEqual(got, want) {
|
|
t.Errorf("wrong result\ngot: %#v\nwant %#v", got, want)
|
|
}
|
|
}
|