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:
parent
cec773f974
commit
e3e49cc099
@ -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))...)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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 {
|
||||||
|
Loading…
Reference in New Issue
Block a user