1
0
mirror of https://github.com/astaxie/beego.git synced 2025-01-15 01:47:13 +00:00
Beego/orm/models_test.go

480 lines
11 KiB
Go
Raw Normal View History

2014-08-18 16:41:43 +08:00
// Copyright 2014 beego Author. All Rights Reserved.
2014-07-03 23:40:21 +08:00
//
2014-08-18 16:41:43 +08:00
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
2014-07-03 23:40:21 +08:00
//
2014-08-18 16:41:43 +08:00
// http://www.apache.org/licenses/LICENSE-2.0
2014-07-03 23:40:21 +08:00
//
2014-08-18 16:41:43 +08:00
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
2013-08-07 19:11:44 +08:00
package orm
import (
"database/sql"
2013-11-26 21:34:40 +08:00
"encoding/json"
2013-08-07 19:11:44 +08:00
"fmt"
"os"
2013-11-26 18:32:12 +08:00
"strings"
2013-08-07 19:11:44 +08:00
"time"
_ "github.com/go-sql-driver/mysql"
_ "github.com/lib/pq"
2013-08-07 19:11:44 +08:00
_ "github.com/mattn/go-sqlite3"
// As tidb can't use go get, so disable the tidb testing now
// _ "github.com/pingcap/tidb"
2013-08-07 19:11:44 +08:00
)
2013-11-26 21:34:40 +08:00
// A slice string field.
2013-11-26 18:32:12 +08:00
type SliceStringField []string
func (e SliceStringField) Value() []string {
return []string(e)
}
func (e *SliceStringField) Set(d []string) {
*e = SliceStringField(d)
}
func (e *SliceStringField) Add(v string) {
*e = append(*e, v)
}
func (e *SliceStringField) String() string {
return strings.Join(e.Value(), ",")
}
func (e *SliceStringField) FieldType() int {
return TypeCharField
}
func (e *SliceStringField) SetRaw(value interface{}) error {
switch d := value.(type) {
case []string:
e.Set(d)
case string:
if len(d) > 0 {
parts := strings.Split(d, ",")
v := make([]string, 0, len(parts))
for _, p := range parts {
v = append(v, strings.TrimSpace(p))
}
e.Set(v)
}
default:
return fmt.Errorf("<SliceStringField.SetRaw> unknown value `%v`", value)
}
return nil
}
func (e *SliceStringField) RawValue() interface{} {
return e.String()
}
2013-11-26 21:34:40 +08:00
var _ Fielder = new(SliceStringField)
// A json field.
2015-09-12 21:46:43 +08:00
type JSONField struct {
2013-11-26 21:34:40 +08:00
Name string
Data string
}
2015-09-12 21:46:43 +08:00
func (e *JSONField) String() string {
2013-11-26 21:34:40 +08:00
data, _ := json.Marshal(e)
return string(data)
}
2015-09-12 21:46:43 +08:00
func (e *JSONField) FieldType() int {
2013-11-26 21:34:40 +08:00
return TypeTextField
}
2015-09-12 21:46:43 +08:00
func (e *JSONField) SetRaw(value interface{}) error {
2013-11-26 21:34:40 +08:00
switch d := value.(type) {
case string:
return json.Unmarshal([]byte(d), e)
default:
return fmt.Errorf("<JsonField.SetRaw> unknown value `%v`", value)
}
2013-11-26 18:32:12 +08:00
}
2015-09-12 21:46:43 +08:00
func (e *JSONField) RawValue() interface{} {
2013-11-26 21:34:40 +08:00
return e.String()
}
2015-09-12 21:46:43 +08:00
var _ Fielder = new(JSONField)
2013-11-26 21:34:40 +08:00
type Data struct {
2015-09-12 21:46:43 +08:00
ID int `orm:"column(id)"`
Boolean bool
Char string `orm:"size(50)"`
Text string `orm:"type(text)"`
Date time.Time `orm:"type(date)"`
DateTime time.Time `orm:"column(datetime)"`
Byte byte
Rune rune
Int int
Int8 int8
Int16 int16
Int32 int32
Int64 int64
Uint uint
Uint8 uint8
Uint16 uint16
Uint32 uint32
Uint64 uint64
Float32 float32
Float64 float64
Decimal float64 `orm:"digits(8);decimals(4)"`
}
type DataNull struct {
2015-09-12 21:46:43 +08:00
ID int `orm:"column(id)"`
Boolean bool `orm:"null"`
Char string `orm:"null;size(50)"`
Text string `orm:"null;type(text)"`
Date time.Time `orm:"null;type(date)"`
2014-04-11 16:08:43 +08:00
DateTime time.Time `orm:"null;column(datetime)"`
Byte byte `orm:"null"`
Rune rune `orm:"null"`
Int int `orm:"null"`
Int8 int8 `orm:"null"`
Int16 int16 `orm:"null"`
Int32 int32 `orm:"null"`
Int64 int64 `orm:"null"`
Uint uint `orm:"null"`
Uint8 uint8 `orm:"null"`
Uint16 uint16 `orm:"null"`
Uint32 uint32 `orm:"null"`
Uint64 uint64 `orm:"null"`
Float32 float32 `orm:"null"`
Float64 float64 `orm:"null"`
Decimal float64 `orm:"digits(8);decimals(4);null"`
NullString sql.NullString `orm:"null"`
NullBool sql.NullBool `orm:"null"`
NullFloat64 sql.NullFloat64 `orm:"null"`
NullInt64 sql.NullInt64 `orm:"null"`
BooleanPtr *bool `orm:"null"`
CharPtr *string `orm:"null;size(50)"`
TextPtr *string `orm:"null;type(text)"`
BytePtr *byte `orm:"null"`
RunePtr *rune `orm:"null"`
IntPtr *int `orm:"null"`
Int8Ptr *int8 `orm:"null"`
Int16Ptr *int16 `orm:"null"`
Int32Ptr *int32 `orm:"null"`
Int64Ptr *int64 `orm:"null"`
UintPtr *uint `orm:"null"`
Uint8Ptr *uint8 `orm:"null"`
Uint16Ptr *uint16 `orm:"null"`
Uint32Ptr *uint32 `orm:"null"`
Uint64Ptr *uint64 `orm:"null"`
Float32Ptr *float32 `orm:"null"`
Float64Ptr *float64 `orm:"null"`
DecimalPtr *float64 `orm:"digits(8);decimals(4);null"`
}
type String string
type Boolean bool
type Byte byte
type Rune rune
type Int int
type Int8 int8
type Int16 int16
type Int32 int32
type Int64 int64
type Uint uint
type Uint8 uint8
type Uint16 uint16
type Uint32 uint32
type Uint64 uint64
type Float32 float64
type Float64 float64
type DataCustom struct {
2015-09-12 21:46:43 +08:00
ID int `orm:"column(id)"`
Boolean Boolean
Char string `orm:"size(50)"`
Text string `orm:"type(text)"`
Byte Byte
Rune Rune
Int Int
Int8 Int8
Int16 Int16
Int32 Int32
Int64 Int64
Uint Uint
Uint8 Uint8
Uint16 Uint16
Uint32 Uint32
Uint64 Uint64
Float32 Float32
Float64 Float64
Decimal Float64 `orm:"digits(8);decimals(4)"`
}
// only for mysql
type UserBig struct {
2015-09-12 21:46:43 +08:00
ID uint64 `orm:"column(id)"`
2013-08-30 12:32:05 +08:00
Name string
}
2013-08-07 19:11:44 +08:00
type User struct {
2015-09-12 21:46:43 +08:00
ID int `orm:"column(id)"`
UserName string `orm:"size(30);unique"`
Email string `orm:"size(100)"`
Password string `orm:"size(100)"`
Status int16 `orm:"column(Status)"`
IsStaff bool
2016-01-15 14:02:08 +08:00
IsActive bool `orm:"default(true)"`
2015-09-12 21:46:43 +08:00
Created time.Time `orm:"auto_now_add;type(date)"`
Updated time.Time `orm:"auto_now"`
Profile *Profile `orm:"null;rel(one);on_delete(set_null)"`
Posts []*Post `orm:"reverse(many)" json:"-"`
ShouldSkip string `orm:"-"`
Nums int
Langs SliceStringField `orm:"size(100)"`
Extra JSONField `orm:"type(text)"`
unexport bool `orm:"-"`
unexportBool bool
2013-08-07 19:11:44 +08:00
}
func (u *User) TableIndex() [][]string {
return [][]string{
2015-03-19 22:29:01 -07:00
{"Id", "UserName"},
{"Id", "Created"},
}
}
func (u *User) TableUnique() [][]string {
return [][]string{
2015-03-19 22:29:01 -07:00
{"UserName", "Email"},
}
}
2013-08-07 19:11:44 +08:00
func NewUser() *User {
obj := new(User)
return obj
}
type Profile struct {
2015-09-12 21:46:43 +08:00
ID int `orm:"column(id)"`
Age int16
Money float64
User *User `orm:"reverse(one)" json:"-"`
BestPost *Post `orm:"rel(one);null"`
2013-08-07 19:11:44 +08:00
}
func (u *Profile) TableName() string {
return "user_profile"
}
func NewProfile() *Profile {
obj := new(Profile)
return obj
}
type Post struct {
2015-09-12 21:46:43 +08:00
ID int `orm:"column(id)"`
User *User `orm:"rel(fk)"`
2013-08-07 19:11:44 +08:00
Title string `orm:"size(60)"`
Content string `orm:"type(text)"`
2013-08-07 19:11:44 +08:00
Created time.Time `orm:"auto_now_add"`
Updated time.Time `orm:"auto_now"`
2013-11-24 19:29:48 +08:00
Tags []*Tag `orm:"rel(m2m);rel_through(github.com/astaxie/beego/orm.PostTags)"`
2013-08-07 19:11:44 +08:00
}
2013-08-25 13:50:50 +08:00
func (u *Post) TableIndex() [][]string {
return [][]string{
2015-03-19 22:29:01 -07:00
{"Id", "Created"},
2013-08-25 13:50:50 +08:00
}
}
2013-08-07 19:11:44 +08:00
func NewPost() *Post {
obj := new(Post)
return obj
}
type Tag struct {
2015-09-12 21:46:43 +08:00
ID int `orm:"column(id)"`
Name string `orm:"size(30)"`
BestPost *Post `orm:"rel(one);null"`
Posts []*Post `orm:"reverse(many)" json:"-"`
2013-08-07 19:11:44 +08:00
}
func NewTag() *Tag {
obj := new(Tag)
return obj
}
2013-11-24 19:29:48 +08:00
type PostTags struct {
2015-09-12 21:46:43 +08:00
ID int `orm:"column(id)"`
2013-11-24 19:29:48 +08:00
Post *Post `orm:"rel(fk)"`
Tag *Tag `orm:"rel(fk)"`
}
func (m *PostTags) TableName() string {
return "prefix_post_tags"
}
2013-08-07 19:11:44 +08:00
type Comment struct {
2015-09-12 21:46:43 +08:00
ID int `orm:"column(id)"`
2013-11-06 22:05:10 +08:00
Post *Post `orm:"rel(fk);column(post)"`
Content string `orm:"type(text)"`
2013-08-07 19:11:44 +08:00
Parent *Comment `orm:"null;rel(fk)"`
Created time.Time `orm:"auto_now_add"`
}
func NewComment() *Comment {
obj := new(Comment)
return obj
}
type Group struct {
2016-01-15 14:36:45 +08:00
ID int `orm:"column(gid);size(32)"`
Name string
Permissions []*Permission `orm:"reverse(many)" json:"-"`
}
type Permission struct {
ID int `orm:"column(id)"`
Name string
Groups []*Group `orm:"rel(m2m);rel_through(github.com/astaxie/beego/orm.GroupPermissions)"`
}
type GroupPermissions struct {
ID int `orm:"column(id)"`
Group *Group `orm:"rel(fk)"`
Permission *Permission `orm:"rel(fk)"`
}
2016-03-08 22:24:38 +08:00
type ModelID struct {
2016-03-10 21:47:50 +08:00
ID int64
2016-03-08 22:24:38 +08:00
}
type ModelBase struct {
ModelID
Created time.Time `orm:"auto_now_add;type(datetime)"`
Updated time.Time `orm:"auto_now;type(datetime)"`
}
type InLine struct {
// Common Fields
ModelBase
// Other Fields
Name string `orm:"unique"`
Email string
}
func NewInLine() *InLine {
return new(InLine)
}
2016-03-13 21:01:56 +08:00
type InLineOneToOne struct {
// Common Fields
ModelBase
Note string
InLine *InLine `orm:"rel(fk);column(inline)"`
}
func NewInLineOneToOne() *InLineOneToOne {
return new(InLineOneToOne)
}
2016-03-18 21:58:11 +08:00
type IntegerPk struct {
Id int64 `orm:"pk"`
Value string
}
type UintPk struct {
Id uint32 `orm:"pk"`
Name string
}
2013-08-07 19:11:44 +08:00
var DBARGS = struct {
Driver string
Source string
2013-08-09 13:20:19 +08:00
Debug string
2013-08-07 19:11:44 +08:00
}{
os.Getenv("ORM_DRIVER"),
os.Getenv("ORM_SOURCE"),
2013-08-09 13:20:19 +08:00
os.Getenv("ORM_DEBUG"),
2013-08-07 19:11:44 +08:00
}
var (
IsMysql = DBARGS.Driver == "mysql"
IsSqlite = DBARGS.Driver == "sqlite3"
IsPostgres = DBARGS.Driver == "postgres"
2015-09-10 16:31:53 +08:00
IsTidb = DBARGS.Driver == "tidb"
)
var (
dORM Ormer
dDbBaser dbBaser
)
2013-08-07 19:11:44 +08:00
func init() {
2013-08-09 13:20:19 +08:00
Debug, _ = StrTo(DBARGS.Debug).Bool()
2013-08-07 19:11:44 +08:00
if DBARGS.Driver == "" || DBARGS.Source == "" {
fmt.Println(`need driver and source!
Default DB Drivers.
driver: url
mysql: https://github.com/go-sql-driver/mysql
sqlite3: https://github.com/mattn/go-sqlite3
postgres: https://github.com/lib/pq
2015-09-10 16:31:53 +08:00
tidb: https://github.com/pingcap/tidb
2013-08-07 19:11:44 +08:00
2013-08-19 22:37:39 +08:00
usage:
2013-08-07 19:11:44 +08:00
2013-08-19 22:37:39 +08:00
go get -u github.com/astaxie/beego/orm
go get -u github.com/go-sql-driver/mysql
go get -u github.com/mattn/go-sqlite3
go get -u github.com/lib/pq
2015-09-10 16:31:53 +08:00
go get -u github.com/pingcap/tidb
2013-08-07 19:11:44 +08:00
2013-08-19 22:37:39 +08:00
#### MySQL
mysql -u root -e 'create database orm_test;'
export ORM_DRIVER=mysql
export ORM_SOURCE="root:@/orm_test?charset=utf8"
go test -v github.com/astaxie/beego/orm
2013-08-07 19:11:44 +08:00
2013-08-19 22:37:39 +08:00
#### Sqlite3
export ORM_DRIVER=sqlite3
export ORM_SOURCE='file:memory_test?mode=memory'
2013-08-19 22:37:39 +08:00
go test -v github.com/astaxie/beego/orm
2013-08-19 22:37:39 +08:00
#### PostgreSQL
psql -c 'create database orm_test;' -U postgres
export ORM_DRIVER=postgres
export ORM_SOURCE="user=postgres dbname=orm_test sslmode=disable"
go test -v github.com/astaxie/beego/orm
2015-09-10 16:31:53 +08:00
#### TiDB
export ORM_DRIVER=tidb
2015-09-11 11:24:58 +08:00
export ORM_SOURCE='memory://test/test'
2015-09-10 16:31:53 +08:00
go test -v github.com/astaxie/beego/orm
2013-08-19 22:37:39 +08:00
`)
os.Exit(2)
2013-08-07 19:11:44 +08:00
}
2013-08-19 22:37:39 +08:00
RegisterDataBase("default", DBARGS.Driver, DBARGS.Source, 20)
alias := getDbAlias("default")
2015-09-12 21:46:43 +08:00
if alias.Driver == DRMySQL {
alias.Engine = "INNODB"
}
2013-08-07 19:11:44 +08:00
}