2017-05-27 09:31:39 +00:00
|
|
|
// Copyright 2017 The Xorm Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
2020-03-27 07:13:04 +00:00
|
|
|
package integrations
|
2017-05-27 09:31:39 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestRows(t *testing.T) {
|
2020-03-27 07:13:04 +00:00
|
|
|
assert.NoError(t, PrepareEngine())
|
2017-05-27 09:31:39 +00:00
|
|
|
|
|
|
|
type UserRows struct {
|
|
|
|
Id int64
|
|
|
|
IsMan bool
|
|
|
|
}
|
|
|
|
|
|
|
|
assert.NoError(t, testEngine.Sync2(new(UserRows)))
|
|
|
|
|
|
|
|
cnt, err := testEngine.Insert(&UserRows{
|
|
|
|
IsMan: true,
|
|
|
|
})
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.EqualValues(t, 1, cnt)
|
|
|
|
|
|
|
|
rows, err := testEngine.Rows(new(UserRows))
|
|
|
|
assert.NoError(t, err)
|
|
|
|
defer rows.Close()
|
|
|
|
|
|
|
|
cnt = 0
|
|
|
|
user := new(UserRows)
|
|
|
|
for rows.Next() {
|
|
|
|
err = rows.Scan(user)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
cnt++
|
|
|
|
}
|
|
|
|
assert.EqualValues(t, 1, cnt)
|
2019-06-20 15:12:08 +00:00
|
|
|
assert.False(t, rows.Next())
|
|
|
|
assert.NoError(t, rows.Close())
|
|
|
|
|
|
|
|
rows0, err := testEngine.Where("1>1").Rows(new(UserRows))
|
|
|
|
assert.NoError(t, err)
|
|
|
|
defer rows0.Close()
|
|
|
|
|
|
|
|
cnt = 0
|
|
|
|
user0 := new(UserRows)
|
|
|
|
for rows0.Next() {
|
|
|
|
err = rows0.Scan(user0)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
cnt++
|
|
|
|
}
|
|
|
|
assert.EqualValues(t, 0, cnt)
|
|
|
|
assert.NoError(t, rows0.Close())
|
2017-07-27 06:38:39 +00:00
|
|
|
|
|
|
|
sess := testEngine.NewSession()
|
|
|
|
defer sess.Close()
|
|
|
|
|
|
|
|
rows1, err := sess.Prepare().Rows(new(UserRows))
|
|
|
|
assert.NoError(t, err)
|
|
|
|
defer rows1.Close()
|
|
|
|
|
|
|
|
cnt = 0
|
|
|
|
for rows1.Next() {
|
|
|
|
err = rows1.Scan(user)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
cnt++
|
|
|
|
}
|
|
|
|
assert.EqualValues(t, 1, cnt)
|
|
|
|
|
2018-04-10 01:50:29 +00:00
|
|
|
var tbName = testEngine.Quote(testEngine.TableName(user, true))
|
|
|
|
rows2, err := testEngine.SQL("SELECT * FROM " + tbName).Rows(new(UserRows))
|
2017-07-27 06:38:39 +00:00
|
|
|
assert.NoError(t, err)
|
|
|
|
defer rows2.Close()
|
|
|
|
|
|
|
|
cnt = 0
|
|
|
|
for rows2.Next() {
|
|
|
|
err = rows2.Scan(user)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
cnt++
|
|
|
|
}
|
|
|
|
assert.EqualValues(t, 1, cnt)
|
2017-05-27 09:31:39 +00:00
|
|
|
}
|
2019-01-20 13:49:23 +00:00
|
|
|
|
|
|
|
func TestRowsMyTableName(t *testing.T) {
|
2020-03-27 07:13:04 +00:00
|
|
|
assert.NoError(t, PrepareEngine())
|
2019-01-20 13:49:23 +00:00
|
|
|
|
|
|
|
type UserRowsMyTable struct {
|
|
|
|
Id int64
|
|
|
|
IsMan bool
|
|
|
|
}
|
|
|
|
|
|
|
|
var tableName = "user_rows_my_table_name"
|
|
|
|
|
|
|
|
assert.NoError(t, testEngine.Table(tableName).Sync2(new(UserRowsMyTable)))
|
|
|
|
|
|
|
|
cnt, err := testEngine.Table(tableName).Insert(&UserRowsMyTable{
|
|
|
|
IsMan: true,
|
|
|
|
})
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.EqualValues(t, 1, cnt)
|
|
|
|
|
|
|
|
rows, err := testEngine.Table(tableName).Rows(new(UserRowsMyTable))
|
|
|
|
assert.NoError(t, err)
|
|
|
|
|
|
|
|
cnt = 0
|
|
|
|
user := new(UserRowsMyTable)
|
|
|
|
for rows.Next() {
|
|
|
|
err = rows.Scan(user)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
cnt++
|
|
|
|
}
|
|
|
|
assert.EqualValues(t, 1, cnt)
|
2020-03-06 12:08:32 +00:00
|
|
|
|
|
|
|
rows.Close()
|
|
|
|
|
|
|
|
rows, err = testEngine.Table(tableName).Rows(&UserRowsMyTable{
|
|
|
|
Id: 2,
|
|
|
|
})
|
|
|
|
assert.NoError(t, err)
|
|
|
|
cnt = 0
|
|
|
|
user = new(UserRowsMyTable)
|
|
|
|
for rows.Next() {
|
|
|
|
err = rows.Scan(user)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
cnt++
|
|
|
|
}
|
|
|
|
assert.EqualValues(t, 0, cnt)
|
2019-01-20 13:49:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
type UserRowsSpecTable struct {
|
|
|
|
Id int64
|
|
|
|
IsMan bool
|
|
|
|
}
|
|
|
|
|
|
|
|
func (UserRowsSpecTable) TableName() string {
|
|
|
|
return "user_rows_my_table_name"
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestRowsSpecTableName(t *testing.T) {
|
2020-03-27 07:13:04 +00:00
|
|
|
assert.NoError(t, PrepareEngine())
|
2019-01-20 13:49:23 +00:00
|
|
|
assert.NoError(t, testEngine.Sync2(new(UserRowsSpecTable)))
|
|
|
|
|
|
|
|
cnt, err := testEngine.Insert(&UserRowsSpecTable{
|
|
|
|
IsMan: true,
|
|
|
|
})
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.EqualValues(t, 1, cnt)
|
|
|
|
|
|
|
|
rows, err := testEngine.Rows(new(UserRowsSpecTable))
|
|
|
|
assert.NoError(t, err)
|
|
|
|
defer rows.Close()
|
|
|
|
|
|
|
|
cnt = 0
|
|
|
|
user := new(UserRowsSpecTable)
|
|
|
|
for rows.Next() {
|
|
|
|
err = rows.Scan(user)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
cnt++
|
|
|
|
}
|
|
|
|
assert.EqualValues(t, 1, cnt)
|
|
|
|
}
|