xorm/session_exist_test.go

81 lines
1.9 KiB
Go
Raw Normal View History

2017-07-14 01:20:13 +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 (
"testing"
"github.com/stretchr/testify/assert"
)
func TestExistStruct(t *testing.T) {
assert.NoError(t, prepareEngine())
type RecordExist struct {
Id int64
Name string
}
assertSync(t, new(RecordExist))
has, err := testEngine.Exist(new(RecordExist))
assert.NoError(t, err)
assert.False(t, has)
cnt, err := testEngine.Insert(&RecordExist{
Name: "test1",
})
assert.NoError(t, err)
assert.EqualValues(t, 1, cnt)
has, err = testEngine.Exist(new(RecordExist))
assert.NoError(t, err)
assert.True(t, has)
has, err = testEngine.Exist(&RecordExist{
Name: "test1",
})
assert.NoError(t, err)
assert.True(t, has)
has, err = testEngine.Exist(&RecordExist{
Name: "test2",
})
assert.NoError(t, err)
assert.False(t, has)
2019-03-14 05:06:13 +00:00
nameName := "`" + mapper.Obj2Table("Name") + "`"
2019-03-14 01:08:07 +00:00
has, err = testEngine.Where(nameName+" = ?", "test1").Exist(&RecordExist{})
2017-07-14 01:20:13 +00:00
assert.NoError(t, err)
assert.True(t, has)
2019-03-14 01:08:07 +00:00
has, err = testEngine.Where(nameName+" = ?", "test2").Exist(&RecordExist{})
2017-07-14 01:20:13 +00:00
assert.NoError(t, err)
assert.False(t, has)
2019-03-14 14:33:48 +00:00
tableName := "`" + mapper.Obj2Table("RecordExist") + "`"
2019-03-13 12:37:15 +00:00
2019-03-14 01:08:07 +00:00
has, err = testEngine.SQL("select * from "+testEngine.TableName(tableName, true)+" where "+nameName+" = ?", "test1").Exist()
2017-07-14 01:20:13 +00:00
assert.NoError(t, err)
assert.True(t, has)
2019-03-14 01:08:07 +00:00
has, err = testEngine.SQL("select * from "+testEngine.TableName(tableName, true)+" where "+nameName+" = ?", "test2").Exist()
2017-07-14 01:20:13 +00:00
assert.NoError(t, err)
assert.False(t, has)
2019-03-13 12:37:15 +00:00
has, err = testEngine.Table(tableName).Exist()
2017-07-14 01:20:13 +00:00
assert.NoError(t, err)
assert.True(t, has)
2019-03-14 01:08:07 +00:00
has, err = testEngine.Table(tableName).Where(nameName+" = ?", "test1").Exist()
2017-07-14 01:20:13 +00:00
assert.NoError(t, err)
assert.True(t, has)
2019-03-14 01:08:07 +00:00
has, err = testEngine.Table(tableName).Where(nameName+" = ?", "test2").Exist()
2017-07-14 01:20:13 +00:00
assert.NoError(t, err)
assert.False(t, has)
}