chore: support parsing any type with `fromYaml`
Signed-off-by: Jakob Probst <git@jakobprobst.de>
This commit is contained in:
		
							parent
							
								
									c41f3e88d2
								
							
						
					
					
						commit
						aaac224a1f
					
				|  | @ -19,7 +19,7 @@ func CastKeysToStrings(s any) (map[string]any, error) { | |||
| 				return nil, fmt.Errorf("unexpected type of key in map: expected string, got %T: value=%v, map=%v", typedK, typedK, src) | ||||
| 			} | ||||
| 
 | ||||
| 			castedV, err := recursivelyStringifyMapKey(v) | ||||
| 			castedV, err := RecursivelyStringifyMapKey(v) | ||||
| 			if err != nil { | ||||
| 				return nil, err | ||||
| 			} | ||||
|  | @ -28,7 +28,7 @@ func CastKeysToStrings(s any) (map[string]any, error) { | |||
| 		} | ||||
| 	case map[string]any: | ||||
| 		for k, v := range src { | ||||
| 			castedV, err := recursivelyStringifyMapKey(v) | ||||
| 			castedV, err := RecursivelyStringifyMapKey(v) | ||||
| 			if err != nil { | ||||
| 				return nil, err | ||||
| 			} | ||||
|  | @ -39,7 +39,7 @@ func CastKeysToStrings(s any) (map[string]any, error) { | |||
| 	return new, nil | ||||
| } | ||||
| 
 | ||||
| func recursivelyStringifyMapKey(v any) (any, error) { | ||||
| func RecursivelyStringifyMapKey(v any) (any, error) { | ||||
| 	var castedV any | ||||
| 	switch typedV := v.(type) { | ||||
| 	case map[any]any, map[string]any: | ||||
|  | @ -51,7 +51,7 @@ func recursivelyStringifyMapKey(v any) (any, error) { | |||
| 	case []any: | ||||
| 		a := []any{} | ||||
| 		for i := range typedV { | ||||
| 			res, err := recursivelyStringifyMapKey(typedV[i]) | ||||
| 			res, err := RecursivelyStringifyMapKey(typedV[i]) | ||||
| 			if err != nil { | ||||
| 				return nil, err | ||||
| 			} | ||||
|  |  | |||
|  | @ -307,14 +307,14 @@ func ToYaml(v any) (string, error) { | |||
| 	return string(data), nil | ||||
| } | ||||
| 
 | ||||
| func FromYaml(str string) (Values, error) { | ||||
| 	m := map[string]any{} | ||||
| func FromYaml(str string) (any, error) { | ||||
| 	var m any | ||||
| 
 | ||||
| 	if err := yaml.Unmarshal([]byte(str), &m); err != nil { | ||||
| 		return nil, fmt.Errorf("%s, offending yaml: %s", err, str) | ||||
| 	} | ||||
| 
 | ||||
| 	m, err := maputil.CastKeysToStrings(m) | ||||
| 	m, err := maputil.RecursivelyStringifyMapKey(m) | ||||
| 	if err != nil { | ||||
| 		return nil, fmt.Errorf("%s, offending yaml: %s", err, str) | ||||
| 	} | ||||
|  |  | |||
|  | @ -200,7 +200,88 @@ func TestToYaml(t *testing.T) { | |||
| 	require.Equal(t, expected, actual) | ||||
| } | ||||
| 
 | ||||
| func testFromYaml(t *testing.T, goccyGoYaml bool, expected Values) { | ||||
| func testFromYamlObject(t *testing.T) { | ||||
| 	raw := `foo: | ||||
|   bar: BAR | ||||
| ` | ||||
| 
 | ||||
| 	actual, err := FromYaml(raw) | ||||
| 	require.NoError(t, err) | ||||
| 	require.Equal( | ||||
| 		t, | ||||
| 		map[string]any{ | ||||
| 			"foo": map[string]any{ | ||||
| 				"bar": "BAR", | ||||
| 			}, | ||||
| 		}, | ||||
| 		actual, | ||||
| 	) | ||||
| } | ||||
| 
 | ||||
| func testFromYamlArray(t *testing.T) { | ||||
| 	raw := `- foo | ||||
| - bar: BAR | ||||
| ` | ||||
| 
 | ||||
| 	actual, err := FromYaml(raw) | ||||
| 	require.NoError(t, err) | ||||
| 	require.Equal( | ||||
| 		t, | ||||
| 		[]any{ | ||||
| 			"foo", | ||||
| 			map[string]any{ | ||||
| 				"bar": "BAR", | ||||
| 			}, | ||||
| 		}, | ||||
| 		actual, | ||||
| 	) | ||||
| } | ||||
| 
 | ||||
| func testFromYamlString(t *testing.T) { | ||||
| 	raw := `foo | ||||
| ` | ||||
| 
 | ||||
| 	actual, err := FromYaml(raw) | ||||
| 	require.NoError(t, err) | ||||
| 	require.Equal(t, "foo", actual) | ||||
| } | ||||
| 
 | ||||
| func testFromYamlNumber(t *testing.T) { | ||||
| 	raw := `1234 | ||||
| ` | ||||
| 
 | ||||
| 	actual, err := FromYaml(raw) | ||||
| 	require.NoError(t, err) | ||||
| 
 | ||||
| 	switch a := actual.(type) { | ||||
| 	case int: | ||||
| 		require.Equal(t, 1234, a) | ||||
| 	case uint64: | ||||
| 		require.Equal(t, uint64(1234), a) | ||||
| 	default: | ||||
| 		t.Errorf("unexpected type: %T", a) | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func testFromYamlBoolean(t *testing.T) { | ||||
| 	raw := `true | ||||
| ` | ||||
| 
 | ||||
| 	actual, err := FromYaml(raw) | ||||
| 	require.NoError(t, err) | ||||
| 	require.Equal(t, true, actual) | ||||
| } | ||||
| 
 | ||||
| func testFromYamlNull(t *testing.T) { | ||||
| 	raw := `null | ||||
| ` | ||||
| 
 | ||||
| 	actual, err := FromYaml(raw) | ||||
| 	require.NoError(t, err) | ||||
| 	require.Equal(t, nil, actual) | ||||
| } | ||||
| 
 | ||||
| func testFromYaml(t *testing.T, goccyGoYaml bool) { | ||||
| 	t.Helper() | ||||
| 
 | ||||
| 	v := runtime.GoccyGoYaml | ||||
|  | @ -209,39 +290,26 @@ func testFromYaml(t *testing.T, goccyGoYaml bool, expected Values) { | |||
| 		runtime.GoccyGoYaml = v | ||||
| 	}) | ||||
| 
 | ||||
| 	raw := `foo: | ||||
|   bar: BAR | ||||
| ` | ||||
| 	actual, err := FromYaml(raw) | ||||
| 	require.NoError(t, err) | ||||
| 	require.Equal(t, expected, actual) | ||||
| 	t.Run("test unmarshalling object", testFromYamlObject) | ||||
| 
 | ||||
| 	t.Run("test unmarshalling array", testFromYamlArray) | ||||
| 
 | ||||
| 	t.Run("test unmarshalling string", testFromYamlString) | ||||
| 
 | ||||
| 	t.Run("test unmarshalling number", testFromYamlNumber) | ||||
| 
 | ||||
| 	t.Run("test unmarshalling boolean", testFromYamlBoolean) | ||||
| 
 | ||||
| 	t.Run("test unmarshalling null", testFromYamlNull) | ||||
| } | ||||
| 
 | ||||
| func TestFromYaml(t *testing.T) { | ||||
| 	t.Run("with goccy/go-yaml", func(t *testing.T) { | ||||
| 		testFromYaml( | ||||
| 			t, | ||||
| 			true, | ||||
| 			// nolint: unconvert
 | ||||
| 			Values(map[string]any{ | ||||
| 				"foo": map[string]any{ | ||||
| 					"bar": "BAR", | ||||
| 				}, | ||||
| 			}), | ||||
| 		) | ||||
| 		testFromYaml(t, true) | ||||
| 	}) | ||||
| 
 | ||||
| 	t.Run("with gopkg.in/yaml.v2", func(t *testing.T) { | ||||
| 		testFromYaml( | ||||
| 			t, | ||||
| 			false, | ||||
| 			// nolint: unconvert
 | ||||
| 			Values(map[string]any{ | ||||
| 				"foo": map[string]any{ | ||||
| 					"bar": "BAR", | ||||
| 				}, | ||||
| 			}), | ||||
| 		) | ||||
| 		testFromYaml(t, false) | ||||
| 	}) | ||||
| } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue