forked from mirror/viper
141 lines
2.3 KiB
Go
141 lines
2.3 KiB
Go
|
package hcl
|
||
|
|
||
|
import (
|
||
|
"reflect"
|
||
|
"testing"
|
||
|
)
|
||
|
|
||
|
// original form of the data
|
||
|
const original = `# key-value pair
|
||
|
"key" = "value"
|
||
|
|
||
|
// list
|
||
|
"list" = ["item1", "item2", "item3"]
|
||
|
|
||
|
/* map */
|
||
|
"map" = {
|
||
|
"key" = "value"
|
||
|
}
|
||
|
|
||
|
/*
|
||
|
nested map
|
||
|
*/
|
||
|
"nested_map" "map" {
|
||
|
"key" = "value"
|
||
|
|
||
|
"list" = ["item1", "item2", "item3"]
|
||
|
}`
|
||
|
|
||
|
// encoded form of the data
|
||
|
const encoded = `"key" = "value"
|
||
|
|
||
|
"list" = ["item1", "item2", "item3"]
|
||
|
|
||
|
"map" = {
|
||
|
"key" = "value"
|
||
|
}
|
||
|
|
||
|
"nested_map" "map" {
|
||
|
"key" = "value"
|
||
|
|
||
|
"list" = ["item1", "item2", "item3"]
|
||
|
}`
|
||
|
|
||
|
// decoded form of the data
|
||
|
//
|
||
|
// in case of HCL it's slightly different from Viper's internal representation
|
||
|
// (eg. map is decoded into a list of maps)
|
||
|
var decoded = map[string]interface{}{
|
||
|
"key": "value",
|
||
|
"list": []interface{}{
|
||
|
"item1",
|
||
|
"item2",
|
||
|
"item3",
|
||
|
},
|
||
|
"map": []map[string]interface{}{
|
||
|
{
|
||
|
"key": "value",
|
||
|
},
|
||
|
},
|
||
|
"nested_map": []map[string]interface{}{
|
||
|
{
|
||
|
"map": []map[string]interface{}{
|
||
|
{
|
||
|
"key": "value",
|
||
|
"list": []interface{}{
|
||
|
"item1",
|
||
|
"item2",
|
||
|
"item3",
|
||
|
},
|
||
|
},
|
||
|
},
|
||
|
},
|
||
|
},
|
||
|
}
|
||
|
|
||
|
// Viper's internal representation
|
||
|
var data = map[string]interface{}{
|
||
|
"key": "value",
|
||
|
"list": []interface{}{
|
||
|
"item1",
|
||
|
"item2",
|
||
|
"item3",
|
||
|
},
|
||
|
"map": map[string]interface{}{
|
||
|
"key": "value",
|
||
|
},
|
||
|
"nested_map": map[string]interface{}{
|
||
|
"map": map[string]interface{}{
|
||
|
"key": "value",
|
||
|
"list": []interface{}{
|
||
|
"item1",
|
||
|
"item2",
|
||
|
"item3",
|
||
|
},
|
||
|
},
|
||
|
},
|
||
|
}
|
||
|
|
||
|
func TestCodec_Encode(t *testing.T) {
|
||
|
codec := Codec{}
|
||
|
|
||
|
b, err := codec.Encode(data)
|
||
|
if err != nil {
|
||
|
t.Fatal(err)
|
||
|
}
|
||
|
|
||
|
if encoded != string(b) {
|
||
|
t.Fatalf("decoded value does not match the expected one\nactual: %#v\nexpected: %#v", string(b), encoded)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
func TestCodec_Decode(t *testing.T) {
|
||
|
t.Run("OK", func(t *testing.T) {
|
||
|
codec := Codec{}
|
||
|
|
||
|
v := map[string]interface{}{}
|
||
|
|
||
|
err := codec.Decode([]byte(original), v)
|
||
|
if err != nil {
|
||
|
t.Fatal(err)
|
||
|
}
|
||
|
|
||
|
if !reflect.DeepEqual(decoded, v) {
|
||
|
t.Fatalf("decoded value does not match the expected one\nactual: %#v\nexpected: %#v", v, decoded)
|
||
|
}
|
||
|
})
|
||
|
|
||
|
t.Run("InvalidData", func(t *testing.T) {
|
||
|
codec := Codec{}
|
||
|
|
||
|
v := map[string]interface{}{}
|
||
|
|
||
|
err := codec.Decode([]byte(`invalid data`), v)
|
||
|
if err == nil {
|
||
|
t.Fatal("expected decoding to fail")
|
||
|
}
|
||
|
|
||
|
t.Logf("decoding failed as expected: %s", err)
|
||
|
})
|
||
|
}
|