Skip to content

Commit

Permalink
Fix slice value length assertion in conversion.Convert
Browse files Browse the repository at this point in the history
Signed-off-by: Alper Rifat Ulucinar <ulucinar@users.noreply.github.com>
  • Loading branch information
ulucinar committed Apr 19, 2024
1 parent 6600707 commit 0c57170
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 9 deletions.
2 changes: 1 addition & 1 deletion pkg/config/conversion/conversions.go
Original file line number Diff line number Diff line change
Expand Up @@ -209,7 +209,7 @@ func (s *singletonListConverter) ConvertPaved(src, target *fieldpath.Paved) (boo
return true, errors.Errorf("value at path %s is not a map[string]any", pathForProvider)
}
if _, err := Convert(m, s.crdPaths, s.mode); err != nil {
return true, errors.Wrapf(err, "failed to convert the source map in mode %q with %s", s.mode, s.baseConversion)
return true, errors.Wrapf(err, "failed to convert the source map in mode %q with %s", s.mode, s.baseConversion.String())
}
return true, errors.Wrapf(target.SetValue(pathForProvider, m), "failed to set the %s value for conversion in mode %q", pathForProvider, s.mode)
}
Expand Down
19 changes: 11 additions & 8 deletions pkg/config/conversion/runtime_conversion.go
Original file line number Diff line number Diff line change
Expand Up @@ -103,14 +103,17 @@ func Convert(params map[string]any, paths []string, mode Mode) (map[string]any,
return nil, errors.Wrapf(err, "cannot set the singleton list's value at the field path %s", exp[0])
}
case ToEmbeddedObject:
s, ok := v.([]any)
if !ok || len(s) > 1 {
// if len(s) is 0, then it's not a slice
return nil, errors.Errorf("singleton list, at the field path %s, must have a length of 1 but it has a length of %d", exp[0], len(s))
}
var newVal any = map[string]any{}
if len(s) > 0 {
newVal = s[0]
var newVal any = nil
if v != nil {
newVal = map[string]any{}
s, ok := v.([]any)
if !ok || len(s) > 1 {
// if len(s) is 0, then it's not a slice
return nil, errors.Errorf("singleton list, at the field path %s, must have a length of at most 1 but it has a length of %d", exp[0], len(s))
}
if len(s) > 0 {
newVal = s[0]
}
}
if err := setValue(pv, newVal, exp[0]); err != nil {
return nil, errors.Wrapf(err, "cannot set the embedded object's value at the field path %s", exp[0])
Expand Down

0 comments on commit 0c57170

Please sign in to comment.