2017-04-01 02:35:27 +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.
|
|
|
|
|
|
|
|
package xorm
|
|
|
|
|
|
|
|
import (
|
2017-05-27 12:34:57 +00:00
|
|
|
"strconv"
|
2017-04-01 02:35:27 +00:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
2017-11-15 03:34:59 +00:00
|
|
|
func TestExecAndQuery(t *testing.T) {
|
2017-05-27 12:34:57 +00:00
|
|
|
assert.NoError(t, prepareEngine())
|
|
|
|
|
|
|
|
type UserinfoQuery struct {
|
|
|
|
Uid int
|
|
|
|
Name string
|
|
|
|
}
|
|
|
|
|
2017-10-16 07:28:13 +00:00
|
|
|
assert.NoError(t, testEngine.Sync2(new(UserinfoQuery)))
|
2017-05-27 12:34:57 +00:00
|
|
|
|
2019-03-13 12:37:15 +00:00
|
|
|
tableName := tableMapper.Obj2Table("UserinfoQuery")
|
|
|
|
uidName := colMapper.Obj2Table("Uid")
|
|
|
|
nameName := colMapper.Obj2Table("Name")
|
|
|
|
|
2019-03-14 14:33:48 +00:00
|
|
|
res, err := testEngine.Exec("INSERT INTO `"+testEngine.TableName(tableName, true)+"` (`"+uidName+"`, `"+nameName+"`) VALUES (?, ?)", 1, "user")
|
2017-05-27 12:34:57 +00:00
|
|
|
assert.NoError(t, err)
|
|
|
|
cnt, err := res.RowsAffected()
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.EqualValues(t, 1, cnt)
|
|
|
|
|
2019-03-14 14:33:48 +00:00
|
|
|
results, err := testEngine.Query("select * from `" + testEngine.TableName(tableName, true) + "`")
|
2017-05-27 12:34:57 +00:00
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.EqualValues(t, 1, len(results))
|
2019-03-13 12:37:15 +00:00
|
|
|
id, err := strconv.Atoi(string(results[0][uidName]))
|
2017-05-27 12:34:57 +00:00
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.EqualValues(t, 1, id)
|
2019-03-13 12:37:15 +00:00
|
|
|
assert.Equal(t, "user", string(results[0][nameName]))
|
2017-05-27 12:34:57 +00:00
|
|
|
}
|