mirror of
https://github.com/opentofu/opentofu.git
synced 2024-12-30 10:47:14 -06:00
c5d10bdef1
In order to include condition block results in the JSON plan output, we must store them in the plan and its serialization. Terraform can evaluate condition blocks multiple times, so we must be able to update the result. Accordingly, the plan.Conditions object is a map with keys representing the condition block's address. Condition blocks are not referenceable in any other context, so this address form cannot be used anywhere in the configuration. The commit includes a new test case for the JSON output of a refresh-only plan, which is currently the only way for a failing condition result to be rendered through this path.
132 lines
2.9 KiB
Go
132 lines
2.9 KiB
Go
package addrs
|
|
|
|
import (
|
|
"fmt"
|
|
"strings"
|
|
"testing"
|
|
|
|
"github.com/go-test/deep"
|
|
)
|
|
|
|
func TestAbsOutputValueInstanceEqual_true(t *testing.T) {
|
|
foo, diags := ParseModuleInstanceStr("module.foo")
|
|
if len(diags) > 0 {
|
|
t.Fatalf("unexpected diags: %s", diags.Err())
|
|
}
|
|
foobar, diags := ParseModuleInstanceStr("module.foo[1].module.bar")
|
|
if len(diags) > 0 {
|
|
t.Fatalf("unexpected diags: %s", diags.Err())
|
|
}
|
|
|
|
ovs := []AbsOutputValue{
|
|
foo.OutputValue("a"),
|
|
foobar.OutputValue("b"),
|
|
}
|
|
for _, r := range ovs {
|
|
t.Run(r.String(), func(t *testing.T) {
|
|
if !r.Equal(r) {
|
|
t.Fatalf("expected %#v to be equal to itself", r)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestAbsOutputValueInstanceEqual_false(t *testing.T) {
|
|
foo, diags := ParseModuleInstanceStr("module.foo")
|
|
if len(diags) > 0 {
|
|
t.Fatalf("unexpected diags: %s", diags.Err())
|
|
}
|
|
foobar, diags := ParseModuleInstanceStr("module.foo[1].module.bar")
|
|
if len(diags) > 0 {
|
|
t.Fatalf("unexpected diags: %s", diags.Err())
|
|
}
|
|
|
|
testCases := []struct {
|
|
left AbsOutputValue
|
|
right AbsOutputValue
|
|
}{
|
|
{
|
|
foo.OutputValue("a"),
|
|
foo.OutputValue("b"),
|
|
},
|
|
{
|
|
foo.OutputValue("a"),
|
|
foobar.OutputValue("a"),
|
|
},
|
|
}
|
|
for _, tc := range testCases {
|
|
t.Run(fmt.Sprintf("%s = %s", tc.left, tc.right), func(t *testing.T) {
|
|
if tc.left.Equal(tc.right) {
|
|
t.Fatalf("expected %#v not to be equal to %#v", tc.left, tc.right)
|
|
}
|
|
|
|
if tc.right.Equal(tc.left) {
|
|
t.Fatalf("expected %#v not to be equal to %#v", tc.right, tc.left)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestParseAbsOutputValueStr(t *testing.T) {
|
|
tests := map[string]struct {
|
|
want AbsOutputValue
|
|
wantErr string
|
|
}{
|
|
"module.foo": {
|
|
wantErr: "An output name is required",
|
|
},
|
|
"module.foo.output": {
|
|
wantErr: "An output name is required",
|
|
},
|
|
"module.foo.boop.beep": {
|
|
wantErr: "Output address must start with \"output.\"",
|
|
},
|
|
"module.foo.output[0]": {
|
|
wantErr: "An output name is required",
|
|
},
|
|
"output": {
|
|
wantErr: "An output name is required",
|
|
},
|
|
"output[0]": {
|
|
wantErr: "An output name is required",
|
|
},
|
|
"output.boop": {
|
|
want: AbsOutputValue{
|
|
Module: RootModuleInstance,
|
|
OutputValue: OutputValue{
|
|
Name: "boop",
|
|
},
|
|
},
|
|
},
|
|
"module.foo.output.beep": {
|
|
want: AbsOutputValue{
|
|
Module: mustParseModuleInstanceStr("module.foo"),
|
|
OutputValue: OutputValue{
|
|
Name: "beep",
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
for input, tc := range tests {
|
|
t.Run(input, func(t *testing.T) {
|
|
got, diags := ParseAbsOutputValueStr(input)
|
|
for _, problem := range deep.Equal(got, tc.want) {
|
|
t.Errorf(problem)
|
|
}
|
|
if len(diags) > 0 {
|
|
gotErr := diags.Err().Error()
|
|
if tc.wantErr == "" {
|
|
t.Errorf("got error, expected success: %s", gotErr)
|
|
} else if !strings.Contains(gotErr, tc.wantErr) {
|
|
t.Errorf("unexpected error\n got: %s\nwant: %s", gotErr, tc.wantErr)
|
|
}
|
|
} else {
|
|
if tc.wantErr != "" {
|
|
t.Errorf("got success, expected error: %s", tc.wantErr)
|
|
}
|
|
}
|
|
})
|
|
}
|
|
}
|