-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathparser_test.go
69 lines (59 loc) · 1.46 KB
/
parser_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
package sql_test
import (
"reflect"
"strings"
"testing"
"github.com/syst3mw0rm/sql-lexer-parser"
)
func TestParser_ParseStatement(t *testing.T) {
var tests = []struct {
s string
stmt *sql.SelectStatement
err string
}{
// Single field statement
{
s: `SELEcT name from tbl`,
stmt: &sql.SelectStatement{
Fields: []string{"name"},
TableName: "tbl",
},
},
// Multi field statement
{
s: `SELECT a, b from tbl`,
stmt: &sql.SelectStatement{
Fields: []string{"a", "b"},
TableName: "tbl",
},
},
// Select all statement
{
s: `SELECT * FROM tbl`,
stmt: &sql.SelectStatement{
Fields: []string{"*"},
TableName: "tbl",
},
},
// Errors
{s: `foo`, err: `found "foo", expected SELECT`},
{s: `SELECT !`, err: `found "!", expected field`},
{s: `SELECT field xxx`, err: `found "xxx", expected FROM`},
{s: `SELECT field FROM *`, err: `found "*", expected table name`},
}
for i, tt := range tests {
stmt, err := sql.NewParser(strings.NewReader(tt.s)).Parse()
if !reflect.DeepEqual(tt.err, errstring(err)) {
t.Errorf("%d. %q: error mismatch:\n exp=%s\n got=%s\n\n", i, tt.s, tt.err, err)
} else if tt.err == "" && !reflect.DeepEqual(tt.stmt, stmt) {
t.Errorf("%d. %q\n\nstmt mismatch:\n\nexp=%#v\n\ngot=%#v\n\n", i, tt.s, tt.stmt, stmt)
}
}
}
// errstring returns the string representation of an error.
func errstring(err error) string {
if err != nil {
return err.Error()
}
return ""
}