-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdbm_test.go
49 lines (44 loc) · 1.44 KB
/
dbm_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
package dbm
import (
_ "github.com/go-sql-driver/mysql"
"testing"
)
type User struct {
ID int64 `db:"id" json:"id" scheme:"int(8),comment(fsdf\"df\"),default(0),nullable"`
}
type UserDto struct {
ID int64 `json:"id" form:"id"`
}
func TestNewDBM(t *testing.T) {
NewTable("user").
Create(
Col("id").Int().AutoIncrement().Primary(),
Col("name").Int().Index(),
Col("email").Int().Unique(),
Col("address").Int(20).Comment("地址"),
Col("age").Int(3).Nullable(),
Col("sex").Int(1).Default(1),
Col("created_at").Int(10),
Col("updated_at").Decimal(10, 2),
Index(KTUnique, "email", "address"),
).
Engine("InnoDB").
Charset("utf8mb4").
Comment("测试表").
ToSql("mysql")
//Migrate("mysql", "")
//tab.ToSql("mysql")
//tab.ToStruct("mysql")
}
func TestFromSql(t *testing.T) {
FromSql("CREATE TABLE users (\n `user_id` INT AUTO_INCREMENT PRIMARY KEY,\n username VARCHAR(50),\n KEY idx_username_email (username, email)\n);").
TryToStructToSingleFile("", "mysql", Tag("json").CamelCase())
}
func TestFromDsn(t *testing.T) {
filePath := "tmp/test-struct.go"
//filePath := "tmp/tmp2"
FromDsn("mysql", "root:123456@tcp(192.168.0.41:3306)/goapi?charset=utf8mb4&parseTime=true").Table("config").SetPackageName("dao").
TryToStructToSingleFile(filePath, "mysql", Tag("json").CamelCase())
//ToStructToSingleFile(filePath, "mysql", Tag("json").CamelCase())
//ToStructToPath(filePath, "mysql", Tag("json").CamelCase())
}