mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-06 14:13:16 -06:00
Add normalizeJsonString and validateJsonString functions.
This commit adds ValidateFunc to the policy attribute so that JSON parsing errors can be caught early. Generally, when there is a ValidateFunc set for the attribute, one can safely assume that before any of the creation and/or update of the existing resource would happen it would have to succeed validation. Also adds support for new helper function which is used to normalise JSON string. Signed-off-by: Krzysztof Wilczynski <krzysztof.wilczynski@linux.com>
This commit is contained in:
parent
5697a52b4f
commit
e999ae77ba
24
builtin/providers/azurerm/structure.go
Normal file
24
builtin/providers/azurerm/structure.go
Normal file
@ -0,0 +1,24 @@
|
||||
package azurerm
|
||||
|
||||
import "encoding/json"
|
||||
|
||||
// Takes a value containing JSON string and passes it through
|
||||
// the JSON parser to normalize it, returns either a parsing
|
||||
// error or normalized JSON string.
|
||||
func normalizeJsonString(jsonString interface{}) (string, error) {
|
||||
var j interface{}
|
||||
|
||||
if jsonString == nil || jsonString.(string) == "" {
|
||||
return "", nil
|
||||
}
|
||||
|
||||
s := jsonString.(string)
|
||||
|
||||
err := json.Unmarshal([]byte(s), &j)
|
||||
if err != nil {
|
||||
return s, err
|
||||
}
|
||||
|
||||
bytes, _ := json.Marshal(j)
|
||||
return string(bytes[:]), nil
|
||||
}
|
55
builtin/providers/azurerm/structure_test.go
Normal file
55
builtin/providers/azurerm/structure_test.go
Normal file
@ -0,0 +1,55 @@
|
||||
package azurerm
|
||||
|
||||
import "testing"
|
||||
|
||||
func TestNormalizeJsonString(t *testing.T) {
|
||||
var err error
|
||||
var actual string
|
||||
|
||||
// Well formatted and valid.
|
||||
validJson := `{
|
||||
"abc": {
|
||||
"def": 123,
|
||||
"xyz": [
|
||||
{
|
||||
"a": "ホリネズミ"
|
||||
},
|
||||
{
|
||||
"b": "1\\n2"
|
||||
}
|
||||
]
|
||||
}
|
||||
}`
|
||||
expected := `{"abc":{"def":123,"xyz":[{"a":"ホリネズミ"},{"b":"1\\n2"}]}}`
|
||||
|
||||
actual, err = normalizeJsonString(validJson)
|
||||
if err != nil {
|
||||
t.Fatalf("Expected not to throw an error while parsing JSON, but got: %s", err)
|
||||
}
|
||||
|
||||
if actual != expected {
|
||||
t.Fatalf("Got:\n\n%s\n\nExpected:\n\n%s\n", actual, expected)
|
||||
}
|
||||
|
||||
// Well formatted but not valid,
|
||||
// missing closing squre bracket.
|
||||
invalidJson := `{
|
||||
"abc": {
|
||||
"def": 123,
|
||||
"xyz": [
|
||||
{
|
||||
"a": "1"
|
||||
}
|
||||
}
|
||||
}
|
||||
}`
|
||||
actual, err = normalizeJsonString(invalidJson)
|
||||
if err == nil {
|
||||
t.Fatalf("Expected to throw an error while parsing JSON, but got: %s", err)
|
||||
}
|
||||
|
||||
// We expect the invalid JSON to be shown back to us again.
|
||||
if actual != invalidJson {
|
||||
t.Fatalf("Got:\n\n%s\n\nExpected:\n\n%s\n", expected, invalidJson)
|
||||
}
|
||||
}
|
10
builtin/providers/azurerm/validators.go
Normal file
10
builtin/providers/azurerm/validators.go
Normal file
@ -0,0 +1,10 @@
|
||||
package azurerm
|
||||
|
||||
import "fmt"
|
||||
|
||||
func validateJsonString(v interface{}, k string) (ws []string, errors []error) {
|
||||
if _, err := normalizeJsonString(v); err != nil {
|
||||
errors = append(errors, fmt.Errorf("%q contains an invalid JSON: %s", k, err))
|
||||
}
|
||||
return
|
||||
}
|
58
builtin/providers/azurerm/validators_test.go
Normal file
58
builtin/providers/azurerm/validators_test.go
Normal file
@ -0,0 +1,58 @@
|
||||
package azurerm
|
||||
|
||||
import "testing"
|
||||
|
||||
func TestValidateJsonString(t *testing.T) {
|
||||
type testCases struct {
|
||||
Value string
|
||||
ErrCount int
|
||||
}
|
||||
|
||||
invalidCases := []testCases{
|
||||
{
|
||||
Value: `{0:"1"}`,
|
||||
ErrCount: 1,
|
||||
},
|
||||
{
|
||||
Value: `{'abc':1}`,
|
||||
ErrCount: 1,
|
||||
},
|
||||
{
|
||||
Value: `{"def":}`,
|
||||
ErrCount: 1,
|
||||
},
|
||||
{
|
||||
Value: `{"xyz":[}}`,
|
||||
ErrCount: 1,
|
||||
},
|
||||
}
|
||||
|
||||
for _, tc := range invalidCases {
|
||||
_, errors := validateJsonString(tc.Value, "json")
|
||||
if len(errors) != tc.ErrCount {
|
||||
t.Fatalf("Expected %q to trigger a validation error.", tc.Value)
|
||||
}
|
||||
}
|
||||
|
||||
validCases := []testCases{
|
||||
{
|
||||
Value: ``,
|
||||
ErrCount: 0,
|
||||
},
|
||||
{
|
||||
Value: `{}`,
|
||||
ErrCount: 0,
|
||||
},
|
||||
{
|
||||
Value: `{"abc":["1","2"]}`,
|
||||
ErrCount: 0,
|
||||
},
|
||||
}
|
||||
|
||||
for _, tc := range validCases {
|
||||
_, errors := validateJsonString(tc.Value, "json")
|
||||
if len(errors) != tc.ErrCount {
|
||||
t.Fatalf("Expected %q not to trigger a validation error.", tc.Value)
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user