mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-18 04:32:59 -06:00
fbed52a353
Object values returned from providers have their attributes marked as sensitive based on the provider schema. This was not fully implemented for nested attribute types, which is corrected in this commit.
183 lines
5.0 KiB
Go
183 lines
5.0 KiB
Go
package configschema
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/hashicorp/terraform/internal/lang/marks"
|
|
"github.com/zclconf/go-cty/cty"
|
|
)
|
|
|
|
func TestBlockValueMarks(t *testing.T) {
|
|
schema := &Block{
|
|
Attributes: map[string]*Attribute{
|
|
"unsensitive": {
|
|
Type: cty.String,
|
|
Optional: true,
|
|
},
|
|
"sensitive": {
|
|
Type: cty.String,
|
|
Sensitive: true,
|
|
},
|
|
"nested": {
|
|
NestedType: &Object{
|
|
Attributes: map[string]*Attribute{
|
|
"boop": {
|
|
Type: cty.String,
|
|
},
|
|
"honk": {
|
|
Type: cty.String,
|
|
Sensitive: true,
|
|
},
|
|
},
|
|
Nesting: NestingList,
|
|
},
|
|
},
|
|
},
|
|
|
|
BlockTypes: map[string]*NestedBlock{
|
|
"list": {
|
|
Nesting: NestingList,
|
|
Block: Block{
|
|
Attributes: map[string]*Attribute{
|
|
"unsensitive": {
|
|
Type: cty.String,
|
|
Optional: true,
|
|
},
|
|
"sensitive": {
|
|
Type: cty.String,
|
|
Sensitive: true,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
testCases := map[string]struct {
|
|
given cty.Value
|
|
expect cty.Value
|
|
}{
|
|
"unknown object": {
|
|
cty.UnknownVal(schema.ImpliedType()),
|
|
cty.UnknownVal(schema.ImpliedType()),
|
|
},
|
|
"null object": {
|
|
cty.NullVal(schema.ImpliedType()),
|
|
cty.NullVal(schema.ImpliedType()),
|
|
},
|
|
"object with unknown attributes and blocks": {
|
|
cty.ObjectVal(map[string]cty.Value{
|
|
"sensitive": cty.UnknownVal(cty.String),
|
|
"unsensitive": cty.UnknownVal(cty.String),
|
|
"nested": cty.NullVal(cty.List(cty.Object(map[string]cty.Type{
|
|
"boop": cty.String,
|
|
"honk": cty.String,
|
|
}))),
|
|
"list": cty.UnknownVal(schema.BlockTypes["list"].ImpliedType()),
|
|
}),
|
|
cty.ObjectVal(map[string]cty.Value{
|
|
"sensitive": cty.UnknownVal(cty.String).Mark(marks.Sensitive),
|
|
"unsensitive": cty.UnknownVal(cty.String),
|
|
"nested": cty.NullVal(cty.List(cty.Object(map[string]cty.Type{
|
|
"boop": cty.String,
|
|
"honk": cty.String,
|
|
}))),
|
|
"list": cty.UnknownVal(schema.BlockTypes["list"].ImpliedType()),
|
|
}),
|
|
},
|
|
"object with block value": {
|
|
cty.ObjectVal(map[string]cty.Value{
|
|
"sensitive": cty.NullVal(cty.String),
|
|
"unsensitive": cty.UnknownVal(cty.String),
|
|
"nested": cty.NullVal(cty.List(cty.Object(map[string]cty.Type{
|
|
"boop": cty.String,
|
|
"honk": cty.String,
|
|
}))),
|
|
"list": cty.ListVal([]cty.Value{
|
|
cty.ObjectVal(map[string]cty.Value{
|
|
"sensitive": cty.UnknownVal(cty.String),
|
|
"unsensitive": cty.UnknownVal(cty.String),
|
|
}),
|
|
cty.ObjectVal(map[string]cty.Value{
|
|
"sensitive": cty.NullVal(cty.String),
|
|
"unsensitive": cty.NullVal(cty.String),
|
|
}),
|
|
}),
|
|
}),
|
|
cty.ObjectVal(map[string]cty.Value{
|
|
"sensitive": cty.NullVal(cty.String).Mark(marks.Sensitive),
|
|
"unsensitive": cty.UnknownVal(cty.String),
|
|
"nested": cty.NullVal(cty.List(cty.Object(map[string]cty.Type{
|
|
"boop": cty.String,
|
|
"honk": cty.String,
|
|
}))),
|
|
"list": cty.ListVal([]cty.Value{
|
|
cty.ObjectVal(map[string]cty.Value{
|
|
"sensitive": cty.UnknownVal(cty.String).Mark(marks.Sensitive),
|
|
"unsensitive": cty.UnknownVal(cty.String),
|
|
}),
|
|
cty.ObjectVal(map[string]cty.Value{
|
|
"sensitive": cty.NullVal(cty.String).Mark(marks.Sensitive),
|
|
"unsensitive": cty.NullVal(cty.String),
|
|
}),
|
|
}),
|
|
}),
|
|
},
|
|
"object with known values and nested attribute": {
|
|
cty.ObjectVal(map[string]cty.Value{
|
|
"sensitive": cty.StringVal("foo"),
|
|
"unsensitive": cty.StringVal("bar"),
|
|
"nested": cty.ListVal([]cty.Value{
|
|
cty.ObjectVal(map[string]cty.Value{
|
|
"boop": cty.StringVal("foo"),
|
|
"honk": cty.StringVal("bar"),
|
|
}),
|
|
cty.ObjectVal(map[string]cty.Value{
|
|
"boop": cty.NullVal(cty.String),
|
|
"honk": cty.NullVal(cty.String),
|
|
}),
|
|
cty.ObjectVal(map[string]cty.Value{
|
|
"boop": cty.UnknownVal(cty.String),
|
|
"honk": cty.UnknownVal(cty.String),
|
|
}),
|
|
}),
|
|
"list": cty.NullVal(cty.List(cty.Object(map[string]cty.Type{
|
|
"sensitive": cty.String,
|
|
"unsensitive": cty.String,
|
|
}))),
|
|
}),
|
|
cty.ObjectVal(map[string]cty.Value{
|
|
"sensitive": cty.StringVal("foo").Mark(marks.Sensitive),
|
|
"unsensitive": cty.StringVal("bar"),
|
|
"nested": cty.ListVal([]cty.Value{
|
|
cty.ObjectVal(map[string]cty.Value{
|
|
"boop": cty.StringVal("foo"),
|
|
"honk": cty.StringVal("bar").Mark(marks.Sensitive),
|
|
}),
|
|
cty.ObjectVal(map[string]cty.Value{
|
|
"boop": cty.NullVal(cty.String),
|
|
"honk": cty.NullVal(cty.String).Mark(marks.Sensitive),
|
|
}),
|
|
cty.ObjectVal(map[string]cty.Value{
|
|
"boop": cty.UnknownVal(cty.String),
|
|
"honk": cty.UnknownVal(cty.String).Mark(marks.Sensitive),
|
|
}),
|
|
}),
|
|
"list": cty.NullVal(cty.List(cty.Object(map[string]cty.Type{
|
|
"sensitive": cty.String,
|
|
"unsensitive": cty.String,
|
|
}))),
|
|
}),
|
|
},
|
|
}
|
|
|
|
for name, tc := range testCases {
|
|
t.Run(name, func(t *testing.T) {
|
|
got := tc.given.MarkWithPaths(schema.ValueMarks(tc.given, nil))
|
|
if !got.RawEquals(tc.expect) {
|
|
t.Fatalf("\nexpected: %#v\ngot: %#v\n", tc.expect, got)
|
|
}
|
|
})
|
|
}
|
|
}
|