go-sqlite3/driver/connection_go18_test.go

194 lines
4.2 KiB
Go
Raw Normal View History

2018-06-15 18:53:32 +03:00
// Copyright (C) 2018 The Go-SQLite3 Authors.
2016-11-04 09:17:21 +03:00
//
// Use of this source code is governed by an MIT-style
// license that can be found in the LICENSE file.
2016-11-06 07:16:38 +03:00
2016-11-04 09:17:21 +03:00
// +build go1.8
package sqlite3
import (
2017-08-28 12:58:02 +03:00
"context"
2016-11-04 09:17:21 +03:00
"database/sql"
2017-08-28 12:58:02 +03:00
"fmt"
"math/rand"
2016-11-04 09:17:21 +03:00
"os"
"testing"
2017-08-28 12:58:02 +03:00
"time"
2016-11-04 09:17:21 +03:00
)
func TestNamedParams(t *testing.T) {
tempFilename := TempFilename(t)
defer os.Remove(tempFilename)
db, err := sql.Open("sqlite3", tempFilename)
if err != nil {
2018-07-22 23:32:19 +03:00
t.Fatal("failed to open database:", err)
2016-11-04 09:17:21 +03:00
}
defer db.Close()
_, err = db.Exec(`
create table foo (id integer, name text, extra text);
`)
if err != nil {
2018-07-22 23:32:19 +03:00
t.Error("failed to call db.Query:", err)
2016-11-04 09:17:21 +03:00
}
2016-12-09 06:58:20 +03:00
_, err = db.Exec(`insert into foo(id, name, extra) values(:id, :name, :name)`, sql.Named("name", "foo"), sql.Named("id", 1))
2016-11-04 09:17:21 +03:00
if err != nil {
2018-07-22 23:32:19 +03:00
t.Error("failed to call db.Exec:", err)
2016-11-04 09:17:21 +03:00
}
2016-12-09 06:58:20 +03:00
row := db.QueryRow(`select id, extra from foo where id = :id and extra = :extra`, sql.Named("id", 1), sql.Named("extra", "foo"))
2016-11-04 09:17:21 +03:00
if row == nil {
2018-07-22 23:32:19 +03:00
t.Error("failed to call db.QueryRow")
2016-11-04 09:17:21 +03:00
}
var id int
var extra string
err = row.Scan(&id, &extra)
if err != nil {
2018-07-22 23:32:19 +03:00
t.Error("failed to db.Scan:", err)
2016-11-04 09:17:21 +03:00
}
if id != 1 || extra != "foo" {
2018-07-22 23:32:19 +03:00
t.Error("failed to db.QueryRow: not matched results")
2016-11-04 09:17:21 +03:00
}
}
2017-08-28 12:58:02 +03:00
var (
testTableStatements = []string{
`DROP TABLE IF EXISTS test_table`,
`
CREATE TABLE IF NOT EXISTS test_table (
key1 VARCHAR(64) PRIMARY KEY,
key_id VARCHAR(64) NOT NULL,
key2 VARCHAR(64) NOT NULL,
key3 VARCHAR(64) NOT NULL,
key4 VARCHAR(64) NOT NULL,
key5 VARCHAR(64) NOT NULL,
key6 VARCHAR(64) NOT NULL,
data BLOB NOT NULL
);`,
}
letterBytes = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"
)
func randStringBytes(n int) string {
b := make([]byte, n)
for i := range b {
b[i] = letterBytes[rand.Intn(len(letterBytes))]
}
return string(b)
}
func initDatabase(t *testing.T, db *sql.DB, rowCount int64) {
for _, query := range testTableStatements {
_, err := db.Exec(query)
if err != nil {
t.Fatal(err)
}
}
for i := int64(0); i < rowCount; i++ {
query := `INSERT INTO test_table
(key1, key_id, key2, key3, key4, key5, key6, data)
VALUES
(?, ?, ?, ?, ?, ?, ?, ?);`
args := []interface{}{
randStringBytes(50),
fmt.Sprint(i),
randStringBytes(50),
randStringBytes(50),
randStringBytes(50),
randStringBytes(50),
randStringBytes(50),
randStringBytes(50),
randStringBytes(2048),
}
_, err := db.Exec(query, args...)
if err != nil {
t.Fatal(err)
}
}
}
func TestShortTimeout(t *testing.T) {
srcTempFilename := TempFilename(t)
defer os.Remove(srcTempFilename)
db, err := sql.Open("sqlite3", srcTempFilename)
2017-08-28 12:58:02 +03:00
if err != nil {
t.Fatal(err)
}
defer db.Close()
initDatabase(t, db, 100)
2017-08-28 12:58:02 +03:00
ctx, cancel := context.WithTimeout(context.Background(), 1*time.Microsecond)
2017-08-28 12:58:02 +03:00
defer cancel()
query := `SELECT key1, key_id, key2, key3, key4, key5, key6, data
FROM test_table
ORDER BY key2 ASC`
2017-09-28 07:00:20 +03:00
_, err = db.QueryContext(ctx, query)
2017-09-28 06:45:09 +03:00
if err != nil && err != context.DeadlineExceeded {
2017-08-28 12:58:02 +03:00
t.Fatal(err)
}
2017-09-28 06:45:09 +03:00
if ctx.Err() != nil && ctx.Err() != context.DeadlineExceeded {
t.Fatal(ctx.Err())
2017-08-28 12:58:02 +03:00
}
}
func TestExecCancel(t *testing.T) {
db, err := sql.Open("sqlite3", ":memory:")
if err != nil {
t.Fatal(err)
}
defer db.Close()
if _, err = db.Exec("create table foo (id integer primary key)"); err != nil {
t.Fatal(err)
}
for n := 0; n < 100; n++ {
ctx, cancel := context.WithCancel(context.Background())
_, err = db.ExecContext(ctx, "insert into foo (id) values (?)", n)
cancel()
if err != nil {
t.Fatal(err)
}
}
}
2018-06-20 23:51:38 +03:00
func TestPinger(t *testing.T) {
driverName := "sqlite3_pinger"
var dbDriverConn []*SQLiteConn
sql.Register(driverName, &SQLiteDriver{
ConnectHook: func(conn *SQLiteConn) error {
dbDriverConn = append(dbDriverConn, conn)
return nil
},
})
db, err := sql.Open(driverName, ":memory:")
2018-06-20 23:51:38 +03:00
if err != nil {
t.Fatal(err)
}
// Ping Database
2018-06-20 23:51:38 +03:00
err = db.Ping()
if err != nil {
t.Fatal(err)
}
db.Close()
// Ping database
// response should be: database closed
2018-06-20 23:51:38 +03:00
err = db.Ping()
if err == nil {
2018-07-22 23:32:19 +03:00
t.Fatal("should be closed")
}
// Ping Database through connection
err = dbDriverConn[0].Ping(context.Background())
2018-06-20 23:51:38 +03:00
if err == nil {
2018-07-22 23:32:19 +03:00
t.Fatal("should be closed")
2018-06-20 23:51:38 +03:00
}
}