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.
|
|
|
|
|
2023-07-26 10:44:41 +00:00
|
|
|
package tests
|
2017-04-01 02:35:27 +00:00
|
|
|
|
|
|
|
import (
|
2017-05-27 12:34:57 +00:00
|
|
|
"strconv"
|
2017-04-01 02:35:27 +00:00
|
|
|
"testing"
|
2021-07-14 04:20:26 +00:00
|
|
|
"time"
|
2017-04-01 02:35:27 +00:00
|
|
|
|
2023-07-26 08:14:54 +00:00
|
|
|
"xorm.io/xorm/convert"
|
2021-07-28 04:08:58 +00:00
|
|
|
|
2017-04-01 02:35:27 +00:00
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
2017-11-15 03:34:59 +00:00
|
|
|
func TestExecAndQuery(t *testing.T) {
|
2020-03-27 07:13:04 +00:00
|
|
|
assert.NoError(t, PrepareEngine())
|
2017-05-27 12:34:57 +00:00
|
|
|
|
|
|
|
type UserinfoQuery struct {
|
|
|
|
Uid int
|
|
|
|
Name string
|
|
|
|
}
|
|
|
|
|
2021-08-24 09:13:17 +00:00
|
|
|
assert.NoError(t, testEngine.Sync(new(UserinfoQuery)))
|
2017-05-27 12:34:57 +00:00
|
|
|
|
2021-08-24 05:46:08 +00:00
|
|
|
res, err := testEngine.Exec("INSERT INTO "+testEngine.TableName("`userinfo_query`", true)+" (`uid`, `name`) 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)
|
|
|
|
|
2021-08-24 05:46:08 +00:00
|
|
|
results, err := testEngine.Query("select * from " + testEngine.Quote(testEngine.TableName("userinfo_query", true)))
|
2017-05-27 12:34:57 +00:00
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.EqualValues(t, 1, len(results))
|
|
|
|
id, err := strconv.Atoi(string(results[0]["uid"]))
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.EqualValues(t, 1, id)
|
|
|
|
assert.Equal(t, "user", string(results[0]["name"]))
|
|
|
|
}
|
2021-07-14 04:20:26 +00:00
|
|
|
|
|
|
|
func TestExecTime(t *testing.T) {
|
|
|
|
assert.NoError(t, PrepareEngine())
|
|
|
|
|
|
|
|
type UserinfoExecTime struct {
|
|
|
|
Uid int
|
|
|
|
Name string
|
|
|
|
Created time.Time
|
|
|
|
}
|
|
|
|
|
2021-08-24 09:13:17 +00:00
|
|
|
assert.NoError(t, testEngine.Sync(new(UserinfoExecTime)))
|
2021-07-14 04:20:26 +00:00
|
|
|
now := time.Now()
|
2021-08-24 05:46:08 +00:00
|
|
|
res, err := testEngine.Exec("INSERT INTO "+testEngine.TableName("`userinfo_exec_time`", true)+" (`uid`, `name`, `created`) VALUES (?, ?, ?)", 1, "user", now)
|
2021-07-14 04:20:26 +00:00
|
|
|
assert.NoError(t, err)
|
|
|
|
cnt, err := res.RowsAffected()
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.EqualValues(t, 1, cnt)
|
|
|
|
|
2021-08-24 05:46:08 +00:00
|
|
|
results, err := testEngine.QueryString("SELECT * FROM " + testEngine.Quote(testEngine.TableName("userinfo_exec_time", true)))
|
2021-07-14 04:20:26 +00:00
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.EqualValues(t, 1, len(results))
|
|
|
|
assert.EqualValues(t, now.In(testEngine.GetTZLocation()).Format("2006-01-02 15:04:05"), results[0]["created"])
|
|
|
|
|
|
|
|
var uet UserinfoExecTime
|
2021-08-24 05:46:08 +00:00
|
|
|
has, err := testEngine.Where("`uid`=?", 1).Get(&uet)
|
2021-07-14 04:20:26 +00:00
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.True(t, has)
|
|
|
|
assert.EqualValues(t, now.In(testEngine.GetTZLocation()).Format("2006-01-02 15:04:05"), uet.Created.Format("2006-01-02 15:04:05"))
|
|
|
|
}
|
2021-07-06 15:17:57 +00:00
|
|
|
|
|
|
|
type ConversionData struct {
|
|
|
|
MyData string
|
|
|
|
}
|
|
|
|
|
2023-07-26 08:14:54 +00:00
|
|
|
var _ convert.Conversion = new(ConversionData)
|
2021-07-06 15:17:57 +00:00
|
|
|
|
|
|
|
func (c ConversionData) ToDB() ([]byte, error) {
|
|
|
|
return []byte(c.MyData), nil
|
|
|
|
}
|
2023-07-26 08:14:54 +00:00
|
|
|
|
2021-07-06 15:17:57 +00:00
|
|
|
func (c *ConversionData) FromDB(bs []byte) error {
|
|
|
|
if bs != nil {
|
|
|
|
c.MyData = string(bs)
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestExecCustomTypes(t *testing.T) {
|
|
|
|
assert.NoError(t, PrepareEngine())
|
|
|
|
|
|
|
|
type UserinfoExec struct {
|
|
|
|
Uid int
|
|
|
|
Name string
|
|
|
|
Data string
|
|
|
|
}
|
|
|
|
|
|
|
|
assert.NoError(t, testEngine.Sync2(new(UserinfoExec)))
|
|
|
|
|
|
|
|
res, err := testEngine.Exec("INSERT INTO "+testEngine.TableName("`userinfo_exec`", true)+" (uid, name,data) VALUES (?, ?, ?)",
|
|
|
|
1, "user", ConversionData{"data"})
|
|
|
|
assert.NoError(t, err)
|
|
|
|
cnt, err := res.RowsAffected()
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.EqualValues(t, 1, cnt)
|
|
|
|
|
|
|
|
results, err := testEngine.QueryString("select * from " + testEngine.TableName("userinfo_exec", true))
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.EqualValues(t, 1, len(results))
|
|
|
|
id, err := strconv.Atoi(results[0]["uid"])
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.EqualValues(t, 1, id)
|
|
|
|
assert.Equal(t, "user", results[0]["name"])
|
|
|
|
assert.EqualValues(t, "data", results[0]["data"])
|
|
|
|
}
|