fix: model

This commit is contained in:
rogeecn
2025-03-22 19:27:42 +08:00
parent 501af58e66
commit 34c05d52a2
3 changed files with 77 additions and 3 deletions

View File

@@ -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 中的文件名(不带扩展名)加入

View File

@@ -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
} }

View 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())
})
}