-
Notifications
You must be signed in to change notification settings - Fork 0
/
delete_test.go
67 lines (63 loc) · 1.38 KB
/
delete_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
package squl
import (
"fmt"
"testing"
"github.com/stretchr/testify/assert"
)
func TestDelete_dump(t *testing.T) {
testCases := []struct {
shouldFail bool
output string
args []interface{}
expected *Delete
}{
{
false,
"DELETE FROM products WHERE obsoletion_date = 'today' RETURNING *",
[]interface{}{},
&Delete{
Relation: &RangeVar{
Name: "products",
},
Where: &Expr{
Type: ExprTypeOp,
Name: "=",
LHS: &ColumnRef{Fields: "obsoletion_date"},
RHS: &Const{Value: "today"},
},
Returning: &ResTarget{
Value: &ColumnRef{Fields: "*"},
},
},
},
{
false,
"DELETE FROM link USING link_tmp WHERE link.id = link_tmp.id",
[]interface{}{},
&Delete{
Relation: &RangeVar{
Name: "link",
},
Using: &RangeVar{
Name: "link_tmp",
},
Where: &Expr{
Type: ExprTypeOp,
Name: "=",
LHS: &ColumnRef{Fields: []string{"link", "id"}},
RHS: &ColumnRef{Fields: []string{"link_tmp", "id"}},
},
},
},
}
for i, testCase := range testCases {
counter := &ordinalMarker{}
actual, err := testCase.expected.dump(counter)
failMsg := fmt.Sprintf("testCase: %d %v", i, testCase)
if (err != nil) != testCase.shouldFail {
assert.Fail(t, failMsg, err)
}
assert.EqualValues(t, testCase.args, counter.args())
assert.Equal(t, testCase.output, actual, failMsg)
}
}