-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdelete_test.go
80 lines (67 loc) · 2.17 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
68
69
70
71
72
73
74
75
76
77
78
79
80
package pgxjrep_test
import (
"github.com/divilla/pgxjrep"
"github.com/stretchr/testify/assert"
"github.com/tidwall/gjson"
"testing"
)
type deleteBuild struct {
str *pgxjrep.DeleteStatement
stm string
args []interface{}
ret int
err error
}
func TestDeleteBuild(t *testing.T) {
Init(t)
buildResults := []deleteBuild{
{str: builder.Delete("test1"), stm: "DELETE FROM test1", args: nil},
{str: builder.Delete("test1").Where(pk1),
stm: "DELETE FROM test1 WHERE id = $1",
args: append(args, 11)},
{str: builder.Delete("test1").Where(insert1),
stm: "DELETE FROM test1 WHERE a_a LIKE $1 AND \"b_B\" = $2 AND cc_cc IS NULL",
args: append(args, "a", 1)},
{str: builder.Delete("test.Test2").Where(pk1),
stm: "DELETE FROM test.\"Test2\" WHERE \"Id\" = $1",
args: append(args, 11)},
}
for _, v := range buildResults {
stm, argsOut := v.str.Build()
assert.Equal(t, v.stm, stm)
assert.Equal(t, v.args, argsOut)
}
}
func TestDeleteExec(t *testing.T) {
Init(t)
ResetTables(t, conn, "test1", "test.\"Test2\"")
//test 1
json, err := builder.Insert("test1").Values(insert1).Exec(conn, ctx)
assert.Equal(t, int64(1), gjson.Get(json, "rowsAffected").Int())
assert.Equal(t, nil, err)
json, err = builder.Delete("test1").Exec(conn, ctx)
assert.Equal(t, int64(1), gjson.Get(json, "rowsAffected").Int())
assert.Equal(t, nil, err)
json, err = builder.Query("test1").All(conn, ctx)
assert.Equal(t, "[]", json)
assert.Equal(t, nil, err)
//test 2
json, err = builder.Insert("test1").Values(insert1).Exec(conn, ctx)
assert.Equal(t, int64(1), gjson.Get(json, "rowsAffected").Int())
assert.Equal(t, nil, err)
json, err = builder.Insert("test1").Values(insert1).Exec(conn, ctx)
assert.Equal(t, int64(1), gjson.Get(json, "rowsAffected").Int())
assert.Equal(t, nil, err)
pk2 := map[string]interface{}{
"id": 2,
}
json, err = builder.Delete("test1").Where(pk2).Returning("id").One(conn, ctx)
assert.Equal(t, "{\"id\" : 2}", json)
assert.Equal(t, nil, err)
pk3 := map[string]interface{}{
"id": 3,
}
json, err = builder.Query("test1").Where(pk3).One(conn, ctx)
assert.Equal(t, "{\"id\":3,\"aA\":\"a\",\"bB\":1,\"ccCc\":true}", json)
assert.Equal(t, nil, err)
}