Improve ScanRowsTest() so its decoupled from the adapters

pull/16/head
Vinícius Garcia 2022-02-28 22:36:54 -03:00
parent 492dd478e0
commit ea4f56fadd
2 changed files with 44 additions and 46 deletions

View File

@ -2124,19 +2124,16 @@ func ScanRowsTest(
})
t.Run("should ignore extra columns from query", func(t *testing.T) {
err := createTables("sqlite3")
err := createTables(config.driver)
if err != nil {
t.Fatal("could not create test table!, reason:", err.Error())
}
dialect := supportedDialects["sqlite3"]
dialect := supportedDialects[config.driver]
ctx := context.TODO()
db, closer := connectDB(t, testConfig{
driver: "sqlite3",
adapterName: "sql",
})
db, closer := newDBAdapter(t)
defer closer.Close()
c := newTestDB(db, "sqlite3")
c := newTestDB(db, config.driver)
_ = c.Insert(ctx, UsersTable, &User{Name: "User1", Age: 22})
rows, err := db.QueryContext(ctx, "SELECT * FROM users WHERE name='User1'")
@ -2159,17 +2156,14 @@ func ScanRowsTest(
})
t.Run("should report error for closed rows", func(t *testing.T) {
err := createTables("sqlite3")
err := createTables(config.driver)
if err != nil {
t.Fatal("could not create test table!, reason:", err.Error())
}
dialect := supportedDialects["sqlite3"]
dialect := supportedDialects[config.driver]
ctx := context.TODO()
db, closer := connectDB(t, testConfig{
driver: "sqlite3",
adapterName: "sql",
})
db, closer := newDBAdapter(t)
defer closer.Close()
rows, err := db.QueryContext(ctx, "SELECT * FROM users WHERE name='User2'")
@ -2183,47 +2177,51 @@ func ScanRowsTest(
})
t.Run("should report if record is not a pointer", func(t *testing.T) {
err := createTables("sqlite3")
err := createTables(config.driver)
if err != nil {
t.Fatal("could not create test table!, reason:", err.Error())
}
dialect := supportedDialects["sqlite3"]
dialect := supportedDialects[config.driver]
ctx := context.TODO()
db, closer := connectDB(t, testConfig{
driver: "sqlite3",
adapterName: "sql",
})
defer closer.Close()
rows, err := db.QueryContext(ctx, "select * from users where name='User2'")
assert.Equal(t, nil, err)
var u User
err = scanRows(dialect, rows, u)
assert.NotEqual(t, nil, err)
})
t.Run("should report if record is not a pointer to struct", func(t *testing.T) {
err := createTables("sqlite3")
if err != nil {
t.Fatal("could not create test table!, reason:", err.Error())
}
dialect := supportedDialects["sqlite3"]
ctx := context.TODO()
db, closer := connectDB(t, testConfig{
driver: "sqlite3",
adapterName: "sql",
})
db, closer := newDBAdapter(t)
defer closer.Close()
rows, err := db.QueryContext(ctx, "SELECT * FROM users WHERE name='User2'")
assert.Equal(t, nil, err)
tt.AssertNoErr(t, err)
// Some drivers will hang forever if Next() is not called:
defer func() {
for rows.Next() {
}
}()
var u User
err = scanRows(dialect, rows, u)
tt.AssertErrContains(t, err, "ksql", "expected", "pointer to struct", "User")
})
t.Run("should report if record is not a pointer to struct", func(t *testing.T) {
err := createTables(config.driver)
if err != nil {
t.Fatal("could not create test table!, reason:", err.Error())
}
dialect := supportedDialects[config.driver]
ctx := context.TODO()
db, closer := newDBAdapter(t)
defer closer.Close()
rows, err := db.QueryContext(ctx, "SELECT * FROM users WHERE name='User2'")
tt.AssertNoErr(t, err)
// Some drivers will hang forever if Next() is not called:
defer func() {
for rows.Next() {
}
}()
var u map[string]interface{}
err = scanRows(dialect, rows, &u)
assert.NotEqual(t, nil, err)
tt.AssertErrContains(t, err, "ksql", "expected", "pointer to struct", "map[string]interface")
})
}

View File

@ -77,7 +77,7 @@ func startPostgresDB(dbName string) (databaseURL string, closer func()) {
fmt.Println("Connecting to postgres on url: ", databaseUrl)
resource.Expire(40) // Tell docker to hard kill the container in 20 seconds
resource.Expire(40) // Tell docker to hard kill the container in 40 seconds
var sqlDB *sql.DB
// exponential backoff-retry, because the application in the container might not be ready to accept connections yet
@ -133,7 +133,7 @@ func startMySQLDB(dbName string) (databaseURL string, closer func()) {
fmt.Println("Connecting to mysql on url: ", databaseUrl)
resource.Expire(40) // Tell docker to hard kill the container in 20 seconds
resource.Expire(40) // Tell docker to hard kill the container in 40 seconds
var sqlDB *sql.DB
// exponential backoff-retry, because the application in the container might not be ready to accept connections yet
@ -189,7 +189,7 @@ func startSQLServerDB(dbName string) (databaseURL string, closer func()) {
fmt.Println("Connecting to sqlserver on url: ", databaseUrl)
resource.Expire(40) // Tell docker to hard kill the container in 20 seconds
resource.Expire(40) // Tell docker to hard kill the container in 40 seconds
var sqlDB *sql.DB
// exponential backoff-retry, because the application in the container might not be ready to accept connections yet