mirror of
https://github.com/golang/go.git
synced 2025-12-08 06:10:04 +00:00
database/sql: allow Stmt Query and Exec methods to open a new conn
Query and Exec functions on DB first attempt to get a cached connection before requesting the connection pool to ignore the cache and get a new connection. This change aligns Stmt to that behavior as well. Fixes #20433 Change-Id: Idda5f61927289d7ad0882effa3a50ffc9efd88e6 Reviewed-on: https://go-review.googlesource.com/43790 Run-TryBot: Daniel Theophanes <kardianos@gmail.com> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
This commit is contained in:
parent
d79ec64fe1
commit
1865a56e8d
2 changed files with 54 additions and 7 deletions
|
|
@ -2334,9 +2334,13 @@ func TestStmtCloseOrder(t *testing.T) {
|
|||
// Test cases where there's more than maxBadConnRetries bad connections in the
|
||||
// pool (issue 8834)
|
||||
func TestManyErrBadConn(t *testing.T) {
|
||||
manyErrBadConnSetup := func() *DB {
|
||||
manyErrBadConnSetup := func(first ...func(db *DB)) *DB {
|
||||
db := newTestDB(t, "people")
|
||||
|
||||
for _, f := range first {
|
||||
f(db)
|
||||
}
|
||||
|
||||
nconn := maxBadConnRetries + 1
|
||||
db.SetMaxIdleConns(nconn)
|
||||
db.SetMaxOpenConns(nconn)
|
||||
|
|
@ -2405,6 +2409,41 @@ func TestManyErrBadConn(t *testing.T) {
|
|||
t.Fatal(err)
|
||||
}
|
||||
|
||||
// Stmt.Exec
|
||||
db = manyErrBadConnSetup(func(db *DB) {
|
||||
stmt, err = db.Prepare("INSERT|people|name=Julia,age=19")
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
})
|
||||
defer closeDB(t, db)
|
||||
_, err = stmt.Exec()
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
if err = stmt.Close(); err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
|
||||
// Stmt.Query
|
||||
db = manyErrBadConnSetup(func(db *DB) {
|
||||
stmt, err = db.Prepare("SELECT|people|age,name|")
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
})
|
||||
defer closeDB(t, db)
|
||||
rows, err = stmt.Query()
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
if err = rows.Close(); err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
if err = stmt.Close(); err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
|
||||
// Conn
|
||||
db = manyErrBadConnSetup()
|
||||
defer closeDB(t, db)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue