-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathparser_delete_query_test.go
61 lines (52 loc) · 1.4 KB
/
parser_delete_query_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
package SQLParser_test
import (
"reflect"
"strings"
"testing"
"SQLParser"
)
func Test_DELETE_QueryParser(t *testing.T) {
var tests = []struct {
s string
stmt *SQLParser.DeleteStatement
err string
}{
// Single field statement
{
s: `DELETE name FROM tbl`,
stmt: &SQLParser.DeleteStatement{
Fields: []string{"name"},
TableName: "tbl",
},
},
// Multi-field statement
{
s: `DELETE first_name, last_name, age FROM my_table`,
stmt: &SQLParser.DeleteStatement{
Fields: []string{"first_name", "last_name", "age"},
TableName: "my_table",
},
},
// delete all statement
{
s: `DELETE * FROM my_table`,
stmt: &SQLParser.DeleteStatement{
Fields: []string{"*"},
TableName: "my_table",
},
},
//
{s: `foo`, err: `found "foo", expected DELETE`},
{s: `DELETE !`, err: `found "!", expected field`},
{s: `DELETE field xxx`, err: `found "xxx", expected FROM`},
{s: `DELETE field FROM *`, err: `found "*", expected table name`},
}
for i, tt := range tests {
stmt, err := SQLParser.NewParser(strings.NewReader(tt.s)).ParseDeleteStatements()
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)
}
}
}