2014-08-02 22:44:45 +00:00
|
|
|
package hcl
|
|
|
|
|
|
|
|
import (
|
|
|
|
"io/ioutil"
|
|
|
|
"path/filepath"
|
|
|
|
"reflect"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestDecode(t *testing.T) {
|
|
|
|
cases := []struct {
|
|
|
|
File string
|
|
|
|
Err bool
|
|
|
|
Out interface{}
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
"basic.hcl",
|
|
|
|
false,
|
|
|
|
map[string]interface{}{
|
|
|
|
"foo": "bar",
|
|
|
|
},
|
|
|
|
},
|
2014-08-03 05:12:51 +00:00
|
|
|
/*
|
|
|
|
{
|
|
|
|
"structure.hcl",
|
|
|
|
false,
|
|
|
|
map[string]interface{}{
|
|
|
|
"foo": []interface{}{
|
|
|
|
map[string]interface{}{
|
|
|
|
"baz": []interface{}{
|
|
|
|
map[string]interface{}{
|
|
|
|
"foo": "bar",
|
|
|
|
"key": 7,
|
|
|
|
},
|
2014-08-03 03:40:41 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2014-08-02 23:07:54 +00:00
|
|
|
},
|
2014-08-03 05:12:51 +00:00
|
|
|
*/
|
2014-08-02 22:44:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range cases {
|
|
|
|
d, err := ioutil.ReadFile(filepath.Join(fixtureDir, tc.File))
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
2014-08-03 05:05:21 +00:00
|
|
|
var out interface{}
|
2014-08-02 22:44:45 +00:00
|
|
|
err = Decode(&out, string(d))
|
|
|
|
if (err != nil) != tc.Err {
|
|
|
|
t.Fatalf("Input: %s\n\nError: %s", tc.File, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if !reflect.DeepEqual(out, tc.Out) {
|
2014-08-03 05:12:51 +00:00
|
|
|
t.Fatalf("Input: %s\n\n%#v\n\n%#v", tc.File, out, tc.Out)
|
2014-08-02 22:44:45 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2014-08-03 03:48:36 +00:00
|
|
|
|
|
|
|
func TestDecode_equal(t *testing.T) {
|
|
|
|
cases := []struct {
|
|
|
|
One, Two string
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
"basic.hcl",
|
|
|
|
"basic.json",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"structure.hcl",
|
|
|
|
"structure.json",
|
|
|
|
},
|
2014-08-03 04:29:59 +00:00
|
|
|
{
|
|
|
|
"structure.hcl",
|
|
|
|
"structure_flat.json",
|
|
|
|
},
|
2014-08-03 05:05:21 +00:00
|
|
|
{
|
|
|
|
"structure_multi.hcl",
|
|
|
|
"structure_multi.json",
|
|
|
|
},
|
2014-08-03 05:18:39 +00:00
|
|
|
{
|
|
|
|
"structure2.hcl",
|
|
|
|
"structure2.json",
|
|
|
|
},
|
2014-08-03 03:48:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range cases {
|
|
|
|
p1 := filepath.Join(fixtureDir, tc.One)
|
|
|
|
p2 := filepath.Join(fixtureDir, tc.Two)
|
|
|
|
|
|
|
|
d1, err := ioutil.ReadFile(p1)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
d2, err := ioutil.ReadFile(p2)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
var i1, i2 interface{}
|
|
|
|
err = Decode(&i1, string(d1))
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
err = Decode(&i2, string(d2))
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if !reflect.DeepEqual(i1, i2) {
|
2014-08-03 04:29:59 +00:00
|
|
|
t.Fatalf(
|
|
|
|
"%s != %s\n\n%#v\n\n%#v",
|
|
|
|
tc.One, tc.Two,
|
|
|
|
i1, i2)
|
2014-08-03 03:48:36 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2014-08-03 20:09:08 +00:00
|
|
|
|
|
|
|
func TestDecode_flatMap(t *testing.T) {
|
|
|
|
var val map[string]map[string]string
|
|
|
|
|
|
|
|
err := Decode(&val, testReadFile(t, "structure_flatmap.hcl"))
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
expected := map[string]map[string]string{
|
|
|
|
"foo": map[string]string{
|
|
|
|
"foo": "bar",
|
|
|
|
"key": "7",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
if !reflect.DeepEqual(val, expected) {
|
|
|
|
t.Fatalf("Actual: %#v\n\nExpected: %#v", val, expected)
|
|
|
|
}
|
|
|
|
}
|
2014-08-03 21:06:18 +00:00
|
|
|
|
|
|
|
func TestDecode_structure(t *testing.T) {
|
|
|
|
type V struct {
|
|
|
|
Key int
|
|
|
|
Foo string
|
|
|
|
}
|
|
|
|
|
|
|
|
var actual V
|
|
|
|
|
|
|
|
err := Decode(&actual, testReadFile(t, "flat.hcl"))
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
expected := V{
|
|
|
|
Key: 7,
|
|
|
|
Foo: "bar",
|
|
|
|
}
|
|
|
|
|
|
|
|
if !reflect.DeepEqual(actual, expected) {
|
|
|
|
t.Fatalf("Actual: %#v\n\nExpected: %#v", actual, expected)
|
|
|
|
}
|
|
|
|
}
|
2014-08-04 00:17:17 +00:00
|
|
|
|
|
|
|
func TestDecode_structurePtr(t *testing.T) {
|
|
|
|
type V struct {
|
|
|
|
Key int
|
|
|
|
Foo string
|
|
|
|
}
|
|
|
|
|
|
|
|
var actual *V
|
|
|
|
|
|
|
|
err := Decode(&actual, testReadFile(t, "flat.hcl"))
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
expected := &V{
|
|
|
|
Key: 7,
|
|
|
|
Foo: "bar",
|
|
|
|
}
|
|
|
|
|
|
|
|
if !reflect.DeepEqual(actual, expected) {
|
|
|
|
t.Fatalf("Actual: %#v\n\nExpected: %#v", actual, expected)
|
|
|
|
}
|
|
|
|
}
|
2014-08-08 21:59:28 +00:00
|
|
|
|
|
|
|
func TestDecode_structureArray(t *testing.T) {
|
|
|
|
// This test is extracted from a failure in Consul (consul.io),
|
|
|
|
// hence the interesting structure naming.
|
|
|
|
|
|
|
|
type KeyPolicy struct {
|
|
|
|
Prefix string `hcl:",key"`
|
|
|
|
Policy string
|
|
|
|
}
|
|
|
|
|
|
|
|
type Policy struct {
|
|
|
|
Keys []KeyPolicy `hcl:"key"`
|
|
|
|
}
|
|
|
|
|
|
|
|
expected := Policy{
|
|
|
|
Keys: []KeyPolicy{
|
|
|
|
KeyPolicy{
|
|
|
|
Prefix: "",
|
|
|
|
Policy: "read",
|
|
|
|
},
|
|
|
|
KeyPolicy{
|
|
|
|
Prefix: "foo/",
|
|
|
|
Policy: "write",
|
|
|
|
},
|
|
|
|
KeyPolicy{
|
|
|
|
Prefix: "foo/bar/",
|
|
|
|
Policy: "read",
|
|
|
|
},
|
|
|
|
KeyPolicy{
|
|
|
|
Prefix: "foo/bar/baz",
|
|
|
|
Policy: "deny",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2014-08-08 22:58:34 +00:00
|
|
|
files := []string{
|
|
|
|
"decode_policy.hcl",
|
|
|
|
"decode_policy.json",
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, f := range files {
|
|
|
|
var actual Policy
|
|
|
|
|
|
|
|
err := Decode(&actual, testReadFile(t, f))
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if !reflect.DeepEqual(actual, expected) {
|
|
|
|
t.Fatalf("Input: %s\n\nActual: %#v\n\nExpected: %#v", f, actual, expected)
|
|
|
|
}
|
2014-08-08 21:59:28 +00:00
|
|
|
}
|
|
|
|
}
|