gohcl/decode.go: fix decoding value slices

Currently, if user tries to decode such scenario, it results in
"slice index out of range".

Fixes regression introduced in 42351b1d15.

Signed-off-by: Mateusz Gozdek <mateusz@kinvolk.io>
This commit is contained in:
Mateusz Gozdek 2020-01-15 13:30:47 +01:00
parent cec773f974
commit e3e49cc099
No known key found for this signature in database
GPG Key ID: 8DBCFB00F79374C3
2 changed files with 34 additions and 0 deletions

View File

@ -185,6 +185,9 @@ func decodeBodyToStruct(body hcl.Body, ctx *hcl.EvalContext, val reflect.Value)
diags = append(diags, decodeBlockToValue(block, ctx, v.Elem())...) diags = append(diags, decodeBlockToValue(block, ctx, v.Elem())...)
sli.Index(i).Set(v) sli.Index(i).Set(v)
} else { } else {
if i >= sli.Len() {
sli = reflect.Append(sli, reflect.Indirect(reflect.New(ty)))
}
diags = append(diags, decodeBlockToValue(block, ctx, sli.Index(i))...) diags = append(diags, decodeBlockToValue(block, ctx, sli.Index(i))...)
} }
} }

View File

@ -37,6 +37,10 @@ func TestDecodeBody(t *testing.T) {
Nested []*withTwoAttributes `hcl:"nested,block"` Nested []*withTwoAttributes `hcl:"nested,block"`
} }
type withListofNestedBlocksNoPointers struct {
Nested []withTwoAttributes `hcl:"nested,block"`
}
tests := []struct { tests := []struct {
Body map[string]interface{} Body map[string]interface{}
Target func() interface{} Target func() interface{}
@ -623,6 +627,33 @@ func TestDecodeBody(t *testing.T) {
}, },
0, 0,
}, },
{
// Make sure decoding value slices works the same as pointer slices.
map[string]interface{}{
"nested": []map[string]interface{}{
{
"b": "bar",
},
{
"b": "baz",
},
},
},
func() interface{} {
return &withListofNestedBlocksNoPointers{
Nested: []withTwoAttributes{
{
B: "foo",
},
},
}
},
func(gotI interface{}) bool {
n := gotI.(withListofNestedBlocksNoPointers)
return n.Nested[0].B == "bar" && len(n.Nested) == 2
},
0,
},
} }
for i, test := range tests { for i, test := range tests {