mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-15 19:22:46 -06:00
1b3f5fcbfb
In terraform-providers/terraform-provider-aws#2935, we have been cleaning code duplication by benefiting from the "NormalizeJsonString" present in the "structure" helper. It appears that tests in the AWS provider are covering more use-cases, which are added in this work.
92 lines
2.1 KiB
Go
92 lines
2.1 KiB
Go
package structure
|
|
|
|
import (
|
|
"testing"
|
|
)
|
|
|
|
func TestNormalizeJsonString_valid(t *testing.T) {
|
|
// 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 square 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", actual, invalidJson)
|
|
}
|
|
|
|
// Verify that it leaves strings alone
|
|
testString := "2016-07-28t04:07:02z\nsomething else"
|
|
expected = "2016-07-28t04:07:02z\nsomething else"
|
|
actual, err = NormalizeJsonString(testString)
|
|
if err == nil {
|
|
t.Fatalf("Expected 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)
|
|
}
|
|
}
|
|
|
|
func TestNormalizeJsonString_invalid(t *testing.T) {
|
|
// Well formatted but not valid,
|
|
// missing closing squre bracket.
|
|
invalidJson := `{
|
|
"abc": {
|
|
"def": 123,
|
|
"xyz": [
|
|
{
|
|
"a": "1"
|
|
}
|
|
}
|
|
}
|
|
}`
|
|
expected := `{"abc":{"def":123,"xyz":[{"a":"ホリネズミ"},{"b":"1\\n2"}]}}`
|
|
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)
|
|
}
|
|
}
|