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-02 23:07:54 +00:00
|
|
|
{
|
|
|
|
"structure.hcl",
|
|
|
|
false,
|
|
|
|
map[string]interface{}{
|
2014-08-03 03:40:41 +00:00
|
|
|
"foo": []interface{}{
|
|
|
|
map[string]interface{}{
|
|
|
|
"baz": []interface{}{
|
|
|
|
map[string]interface{}{
|
|
|
|
"key": 7,
|
|
|
|
"foo": "bar",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2014-08-02 23:07:54 +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)
|
|
|
|
}
|
|
|
|
|
|
|
|
var out map[string]interface{}
|
|
|
|
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) {
|
|
|
|
t.Fatalf("Input: %s\n\n%#v", tc.File, out)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|