2014-07-31 20:56:51 +00:00
|
|
|
package hcl
|
|
|
|
|
|
|
|
import (
|
|
|
|
"io/ioutil"
|
|
|
|
"path/filepath"
|
|
|
|
"reflect"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestLex(t *testing.T) {
|
|
|
|
cases := []struct {
|
|
|
|
Input string
|
|
|
|
Output []int
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
"comment.hcl",
|
|
|
|
[]int{IDENTIFIER, EQUAL, STRING, lexEOF},
|
|
|
|
},
|
2014-07-31 21:50:53 +00:00
|
|
|
{
|
|
|
|
"structure_basic.hcl",
|
|
|
|
[]int{
|
|
|
|
IDENTIFIER, LEFTBRACE,
|
|
|
|
IDENTIFIER, EQUAL, NUMBER,
|
|
|
|
RIGHTBRACE, lexEOF,
|
|
|
|
},
|
|
|
|
},
|
2014-07-31 20:56:51 +00:00
|
|
|
{
|
|
|
|
"structure.hcl",
|
|
|
|
[]int{
|
|
|
|
IDENTIFIER, IDENTIFIER, STRING, LEFTBRACE,
|
|
|
|
IDENTIFIER, EQUAL, NUMBER, SEMICOLON,
|
|
|
|
RIGHTBRACE, lexEOF,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tc := range cases {
|
|
|
|
d, err := ioutil.ReadFile(filepath.Join(fixtureDir, tc.Input))
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
l := &hclLex{Input: string(d)}
|
|
|
|
var actual []int
|
|
|
|
for {
|
|
|
|
token := l.Lex(new(hclSymType))
|
|
|
|
actual = append(actual, token)
|
|
|
|
|
|
|
|
if token == lexEOF {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(actual) > 500 {
|
|
|
|
t.Fatalf("Input:%s\n\nExausted.", tc.Input)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if !reflect.DeepEqual(actual, tc.Output) {
|
|
|
|
t.Fatalf("Input: %s\n\nBad: %#v", tc.Input, actual)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|