Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion internal/client/clienttools.go
Original file line number Diff line number Diff line change
Expand Up @@ -96,7 +96,7 @@
if err != nil {
return nil
}
parsed.Path = path
parsed.Path = parsed.Path + path

Check warning on line 99 in internal/client/clienttools.go

View check run for this annotation

Codecov / codecov/patch

internal/client/clienttools.go#L99

Added line #L99 was not covered by tests
parsed.RawQuery = params.Encode()
return parsed
}
Expand Down
7 changes: 6 additions & 1 deletion internal/restResources/support.go
Original file line number Diff line number Diff line change
Expand Up @@ -422,7 +422,12 @@
for k, v := range *body {
for _, identifier := range clientInfo.Resource.Identifiers {
if k == identifier {
err := unstructured.SetNestedField(mg.Object, text.GenericToString(v), "status", identifier)
stringValue, err := text.GenericToString(v)
if err != nil {
log.Err(err).Msg("Converting value to string")
return err
}
err = unstructured.SetNestedField(mg.Object, stringValue, "status", identifier)

Check warning on line 430 in internal/restResources/support.go

View check run for this annotation

Codecov / codecov/patch

internal/restResources/support.go#L425-L430

Added lines #L425 - L430 were not covered by tests
if err != nil {
log.Err(err).Msg("Setting identifier")
return err
Expand Down
14 changes: 8 additions & 6 deletions internal/text/genericstringer.go
Original file line number Diff line number Diff line change
@@ -1,22 +1,24 @@
package text

import (
"encoding/json"
"fmt"
"reflect"
)

func GenericToString(i interface{}) string {
func GenericToString(i interface{}) (string, error) {
if reflect.TypeOf(i).Kind() == reflect.String {
return i.(string)
return i.(string), nil
}
if reflect.TypeOf(i).Kind() == reflect.Float32 || reflect.TypeOf(i).Kind() == reflect.Float64 {
return fmt.Sprintf("%d", int(i.(float64)))
return fmt.Sprintf("%d", int(i.(float64))), nil
}
if reflect.TypeOf(i).Kind() == reflect.Int || reflect.TypeOf(i).Kind() == reflect.Int32 || reflect.TypeOf(i).Kind() == reflect.Int64 || reflect.TypeOf(i).Kind() == reflect.Uint || reflect.TypeOf(i).Kind() == reflect.Uint32 || reflect.TypeOf(i).Kind() == reflect.Uint64 {
return fmt.Sprintf("%d", i)
return fmt.Sprintf("%d", i), nil
}
if reflect.TypeOf(i).Kind() == reflect.Bool {
return fmt.Sprintf("%t", i.(bool))
return fmt.Sprintf("%t", i.(bool)), nil
}
return ""
b, err := json.Marshal(i)
return string(b), err
}
30 changes: 30 additions & 0 deletions internal/text/genericstringer_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
package text

import (
"testing"
)

func TestGenericToString(t *testing.T) {
tests := []struct {
input interface{}
expected string
hasError bool
}{
{"hello", "hello", false},
{123, "123", false},
{123.456, "123", false},
{true, "true", false},
{false, "false", false},
{[]int{1, 2, 3}, "[1,2,3]", false},
}

for _, test := range tests {
result, err := GenericToString(test.input)
if (err != nil) != test.hasError {
t.Errorf("GenericToString(%v) returned error: %v, expected error: %v", test.input, err, test.hasError)
}
if result != test.expected {
t.Errorf("GenericToString(%v) = %v, expected %v", test.input, result, test.expected)
}
}
}
Loading