forked from stellar/go
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsession_test.go
91 lines (77 loc) · 2.34 KB
/
session_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
81
82
83
84
85
86
87
88
89
90
91
package db
import (
"testing"
"github.com/stellar/go/support/db/dbtest"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)
func TestSession(t *testing.T) {
db := dbtest.Postgres(t).Load(testSchema)
defer db.Close()
assert := assert.New(t)
require := require.New(t)
sess := &Session{DB: db.Open()}
defer sess.DB.Close()
assert.Equal("postgres", sess.Dialect())
var count int
err := sess.GetRaw(&count, "SELECT COUNT(*) FROM people")
assert.NoError(err)
assert.Equal(3, count)
var names []string
err = sess.SelectRaw(&names, "SELECT name FROM people")
assert.NoError(err)
assert.Len(names, 3)
ret, err := sess.ExecRaw("DELETE FROM people")
assert.NoError(err)
deleted, err := ret.RowsAffected()
assert.NoError(err)
assert.Equal(int64(3), deleted)
// Test args (NOTE: there is a simple escaped arg to ensure no error is raised
// during execution)
db.Load(testSchema)
var name string
err = sess.GetRaw(
&name,
"SELECT name FROM people WHERE hunger_level = ? AND name != '??'",
1000000,
)
assert.NoError(err)
assert.Equal("scott", name)
// Test NoRows
err = sess.GetRaw(
&name,
"SELECT name FROM people WHERE hunger_level = ?",
1234,
)
assert.True(sess.NoRows(err))
// Test transactions
db.Load(testSchema)
require.NoError(sess.Begin(), "begin failed")
err = sess.GetRaw(&count, "SELECT COUNT(*) FROM people")
assert.NoError(err)
assert.Equal(3, count)
_, err = sess.ExecRaw("DELETE FROM people")
assert.NoError(err)
err = sess.GetRaw(&count, "SELECT COUNT(*) FROM people")
assert.NoError(err)
assert.Equal(0, count, "people did not appear deleted inside transaction")
assert.NoError(sess.Rollback(), "rollback failed")
// Ensure commit works
require.NoError(sess.Begin(), "begin failed")
sess.ExecRaw("DELETE FROM people")
assert.NoError(sess.Commit(), "commit failed")
err = sess.GetRaw(&count, "SELECT COUNT(*) FROM people")
assert.NoError(err)
assert.Equal(0, count)
// ensure that selecting into a populated slice clears the slice first
db.Load(testSchema)
require.Len(names, 3, "ids slice was not preloaded with data")
err = sess.SelectRaw(&names, "SELECT name FROM people limit 2")
assert.NoError(err)
assert.Len(names, 2)
// Test ReplacePlaceholders
out, err := sess.ReplacePlaceholders("? = ? = ? = ??")
if assert.NoError(err) {
assert.Equal("$1 = $2 = $3 = ?", out)
}
}