fix: model
This commit is contained in:
@@ -10,15 +10,20 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/samber/lo"
|
"github.com/samber/lo"
|
||||||
|
"go.ipao.vip/atomctl/pkg/utils/gomod"
|
||||||
)
|
)
|
||||||
|
|
||||||
//go:embed table.go.tpl
|
//go:embed table.go.tpl
|
||||||
var tableTpl string
|
var tableTpl string
|
||||||
|
|
||||||
|
//go:embed table_test.go.tpl
|
||||||
|
var tableTestTpl string
|
||||||
|
|
||||||
//go:embed models.gen.go.tpl
|
//go:embed models.gen.go.tpl
|
||||||
var modelTpl string
|
var modelTpl string
|
||||||
|
|
||||||
type TableModelParam struct {
|
type TableModelParam struct {
|
||||||
|
PkgName string
|
||||||
CamelTable string // user
|
CamelTable string // user
|
||||||
PascalTable string // User
|
PascalTable string // User
|
||||||
}
|
}
|
||||||
@@ -27,6 +32,7 @@ func Generate(tables []string, transformer Transformer) error {
|
|||||||
baseDir := "app/models"
|
baseDir := "app/models"
|
||||||
|
|
||||||
tableTpl := template.Must(template.New("model").Parse(string(tableTpl)))
|
tableTpl := template.Must(template.New("model").Parse(string(tableTpl)))
|
||||||
|
tableTestTpl := template.Must(template.New("model").Parse(string(tableTestTpl)))
|
||||||
modelTpl := template.Must(template.New("modelGen").Parse(string(modelTpl)))
|
modelTpl := template.Must(template.New("modelGen").Parse(string(modelTpl)))
|
||||||
|
|
||||||
items := []TableModelParam{}
|
items := []TableModelParam{}
|
||||||
@@ -36,10 +42,12 @@ func Generate(tables []string, transformer Transformer) error {
|
|||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
items = append(items, TableModelParam{
|
tableInfo := TableModelParam{
|
||||||
CamelTable: lo.CamelCase(table),
|
CamelTable: lo.CamelCase(table),
|
||||||
PascalTable: lo.PascalCase(table),
|
PascalTable: lo.PascalCase(table),
|
||||||
})
|
PkgName: gomod.GetModuleName(),
|
||||||
|
}
|
||||||
|
items = append(items, tableInfo)
|
||||||
|
|
||||||
modelFile := fmt.Sprintf("%s/%s.go", baseDir, table)
|
modelFile := fmt.Sprintf("%s/%s.go", baseDir, table)
|
||||||
// 如果 modelFile 已存在,则跳过
|
// 如果 modelFile 已存在,则跳过
|
||||||
@@ -55,9 +63,27 @@ func Generate(tables []string, transformer Transformer) error {
|
|||||||
}
|
}
|
||||||
defer fd.Close()
|
defer fd.Close()
|
||||||
|
|
||||||
if err := tableTpl.Execute(fd, map[string]string{"CamelTable": lo.CamelCase(table)}); err != nil {
|
if err := tableTpl.Execute(fd, tableInfo); err != nil {
|
||||||
return fmt.Errorf("failed to render model template: %w", err)
|
return fmt.Errorf("failed to render model template: %w", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
modelTestFile := fmt.Sprintf("%s/%s_test.go", baseDir, table)
|
||||||
|
// 如果 modelTestFile 已存在,则跳过
|
||||||
|
if _, err := os.Stat(modelTestFile); err == nil {
|
||||||
|
fmt.Printf("Model test file %s already exists. Skipping...\n", modelTestFile)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
// 如果 modelTestFile 不存在,则创建
|
||||||
|
fd, err = os.Create(modelTestFile)
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf("failed to create model test file %s: %w", modelTestFile, err)
|
||||||
|
}
|
||||||
|
defer fd.Close()
|
||||||
|
|
||||||
|
if err := tableTestTpl.Execute(fd, tableInfo); err != nil {
|
||||||
|
return fmt.Errorf("failed to render model test template: %w", err)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 遍历 baseDir 下的所有文件,将不在 tables 中的文件名(不带扩展名)加入
|
// 遍历 baseDir 下的所有文件,将不在 tables 中的文件名(不带扩展名)加入
|
||||||
|
|||||||
@@ -1,9 +1,14 @@
|
|||||||
package models
|
package models
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/sirupsen/logrus"
|
||||||
|
)
|
||||||
// @provider
|
// @provider
|
||||||
type {{.CamelTable}}Model struct {
|
type {{.CamelTable}}Model struct {
|
||||||
|
log *logrus.Entry `inject:"false"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *{{.CamelTable}}Model) Prepare() error {
|
func (m *{{.CamelTable}}Model) Prepare() error {
|
||||||
|
m.log = logrus.WithField("model", "{{.CamelTable}}Model")
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
43
pkg/ast/model/table_test.go.tpl
Normal file
43
pkg/ast/model/table_test.go.tpl
Normal file
@@ -0,0 +1,43 @@
|
|||||||
|
package models
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"{{ .PkgName }}/app/service/testx"
|
||||||
|
"{{ .PkgName }}/database"
|
||||||
|
"{{ .PkgName }}/database/schemas/public/table"
|
||||||
|
|
||||||
|
. "github.com/smartystreets/goconvey/convey"
|
||||||
|
"go.ipao.vip/atom/contracts"
|
||||||
|
|
||||||
|
// . "github.com/go-jet/jet/v2/postgres"
|
||||||
|
"github.com/stretchr/testify/suite"
|
||||||
|
"go.uber.org/dig"
|
||||||
|
)
|
||||||
|
|
||||||
|
type {{ .PascalTable }}InjectParams struct {
|
||||||
|
dig.In
|
||||||
|
Initials []contracts.Initial `group:"initials"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type {{ .PascalTable }}TestSuite struct {
|
||||||
|
suite.Suite
|
||||||
|
|
||||||
|
{{ .PascalTable }}InjectParams
|
||||||
|
}
|
||||||
|
|
||||||
|
func Test_{{ .PascalTable }}(t *testing.T) {
|
||||||
|
providers := testx.Default().With(Provide)
|
||||||
|
testx.Serve(providers, t, func(params {{ .PascalTable }}InjectParams) {
|
||||||
|
suite.Run(t, &{{ .PascalTable }}TestSuite{
|
||||||
|
{{ .PascalTable }}InjectParams: params,
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
func (s *{{ .PascalTable }}TestSuite) Test_Demo() {
|
||||||
|
Convey("Test_Demo", s.T(), func() {
|
||||||
|
database.Truncate(context.Background(), db, table.{{ .PascalTable }}.TableName())
|
||||||
|
})
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user