2020-10-22 18:33:09 +08:00
|
|
|
package gen
|
|
|
|
|
|
|
|
import (
|
2020-12-21 09:43:32 +08:00
|
|
|
"database/sql"
|
2022-04-21 21:49:09 +08:00
|
|
|
_ "embed"
|
2021-07-16 22:55:39 +08:00
|
|
|
"io/ioutil"
|
2020-11-05 14:12:47 +08:00
|
|
|
"os"
|
2022-04-01 14:48:45 +08:00
|
|
|
"path"
|
2020-11-05 14:12:47 +08:00
|
|
|
"path/filepath"
|
2020-12-21 09:43:32 +08:00
|
|
|
"strings"
|
2020-10-22 18:33:09 +08:00
|
|
|
"testing"
|
2020-12-21 09:43:32 +08:00
|
|
|
"time"
|
2020-10-22 18:33:09 +08:00
|
|
|
|
2020-10-25 23:21:55 +08:00
|
|
|
"github.com/stretchr/testify/assert"
|
2022-04-01 14:48:45 +08:00
|
|
|
"github.com/stretchr/testify/require"
|
2022-01-25 23:15:07 +08:00
|
|
|
"github.com/zeromicro/go-zero/core/logx"
|
|
|
|
"github.com/zeromicro/go-zero/core/stringx"
|
|
|
|
"github.com/zeromicro/go-zero/tools/goctl/config"
|
|
|
|
"github.com/zeromicro/go-zero/tools/goctl/model/sql/builderx"
|
2022-04-01 14:48:45 +08:00
|
|
|
"github.com/zeromicro/go-zero/tools/goctl/model/sql/parser"
|
2022-01-25 23:15:07 +08:00
|
|
|
"github.com/zeromicro/go-zero/tools/goctl/util/pathx"
|
2020-10-22 18:33:09 +08:00
|
|
|
)
|
|
|
|
|
2022-04-21 21:49:09 +08:00
|
|
|
//go:embed testdata/user.sql
|
|
|
|
var source string
|
2020-10-22 18:33:09 +08:00
|
|
|
|
2020-10-25 23:21:55 +08:00
|
|
|
func TestCacheModel(t *testing.T) {
|
|
|
|
logx.Disable()
|
2020-10-22 18:33:09 +08:00
|
|
|
_ = Clean()
|
2021-07-16 22:55:39 +08:00
|
|
|
|
2022-01-03 21:32:40 +08:00
|
|
|
sqlFile := filepath.Join(pathx.MustTempDir(), "tmp.sql")
|
2021-07-17 20:51:23 +08:00
|
|
|
err := ioutil.WriteFile(sqlFile, []byte(source), 0o777)
|
2021-07-16 22:55:39 +08:00
|
|
|
assert.Nil(t, err)
|
|
|
|
|
2022-01-03 21:32:40 +08:00
|
|
|
dir := filepath.Join(pathx.MustTempDir(), "./testmodel")
|
2020-11-05 14:12:47 +08:00
|
|
|
cacheDir := filepath.Join(dir, "cache")
|
|
|
|
noCacheDir := filepath.Join(dir, "nocache")
|
2020-11-24 15:11:18 +08:00
|
|
|
g, err := NewDefaultGenerator(cacheDir, &config.Config{
|
|
|
|
NamingFormat: "GoZero",
|
|
|
|
})
|
2020-11-18 15:32:53 +08:00
|
|
|
assert.Nil(t, err)
|
|
|
|
|
2021-07-22 11:29:09 +08:00
|
|
|
err = g.StartFromDDL(sqlFile, true, "go_zero")
|
2020-10-25 23:21:55 +08:00
|
|
|
assert.Nil(t, err)
|
2020-11-05 14:12:47 +08:00
|
|
|
assert.True(t, func() bool {
|
2021-03-01 17:29:07 +08:00
|
|
|
_, err := os.Stat(filepath.Join(cacheDir, "TestUserModel.go"))
|
2020-11-05 14:12:47 +08:00
|
|
|
return err == nil
|
|
|
|
}())
|
2020-11-24 15:11:18 +08:00
|
|
|
g, err = NewDefaultGenerator(noCacheDir, &config.Config{
|
|
|
|
NamingFormat: "gozero",
|
|
|
|
})
|
2020-11-18 15:32:53 +08:00
|
|
|
assert.Nil(t, err)
|
|
|
|
|
2021-07-22 11:29:09 +08:00
|
|
|
err = g.StartFromDDL(sqlFile, false, "go_zero")
|
2020-10-27 22:42:53 +08:00
|
|
|
assert.Nil(t, err)
|
2020-11-05 14:12:47 +08:00
|
|
|
assert.True(t, func() bool {
|
2021-03-01 17:29:07 +08:00
|
|
|
_, err := os.Stat(filepath.Join(noCacheDir, "testusermodel.go"))
|
2020-11-05 14:12:47 +08:00
|
|
|
return err == nil
|
|
|
|
}())
|
2020-10-27 22:42:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestNamingModel(t *testing.T) {
|
|
|
|
logx.Disable()
|
|
|
|
_ = Clean()
|
2021-07-16 22:55:39 +08:00
|
|
|
|
2022-01-03 21:32:40 +08:00
|
|
|
sqlFile := filepath.Join(pathx.MustTempDir(), "tmp.sql")
|
2021-07-17 20:51:23 +08:00
|
|
|
err := ioutil.WriteFile(sqlFile, []byte(source), 0o777)
|
2021-07-16 22:55:39 +08:00
|
|
|
assert.Nil(t, err)
|
|
|
|
|
2020-11-05 14:12:47 +08:00
|
|
|
dir, _ := filepath.Abs("./testmodel")
|
|
|
|
camelDir := filepath.Join(dir, "camel")
|
|
|
|
snakeDir := filepath.Join(dir, "snake")
|
|
|
|
defer func() {
|
|
|
|
_ = os.RemoveAll(dir)
|
|
|
|
}()
|
2020-11-24 15:11:18 +08:00
|
|
|
g, err := NewDefaultGenerator(camelDir, &config.Config{
|
|
|
|
NamingFormat: "GoZero",
|
|
|
|
})
|
2020-11-18 15:32:53 +08:00
|
|
|
assert.Nil(t, err)
|
|
|
|
|
2021-07-22 11:29:09 +08:00
|
|
|
err = g.StartFromDDL(sqlFile, true, "go_zero")
|
2020-10-27 22:42:53 +08:00
|
|
|
assert.Nil(t, err)
|
2020-11-05 14:12:47 +08:00
|
|
|
assert.True(t, func() bool {
|
2021-03-01 17:29:07 +08:00
|
|
|
_, err := os.Stat(filepath.Join(camelDir, "TestUserModel.go"))
|
2020-11-05 14:12:47 +08:00
|
|
|
return err == nil
|
|
|
|
}())
|
2020-11-24 15:11:18 +08:00
|
|
|
g, err = NewDefaultGenerator(snakeDir, &config.Config{
|
|
|
|
NamingFormat: "go_zero",
|
|
|
|
})
|
2020-11-18 15:32:53 +08:00
|
|
|
assert.Nil(t, err)
|
|
|
|
|
2021-07-22 11:29:09 +08:00
|
|
|
err = g.StartFromDDL(sqlFile, true, "go_zero")
|
2020-10-27 22:42:53 +08:00
|
|
|
assert.Nil(t, err)
|
2020-11-05 14:12:47 +08:00
|
|
|
assert.True(t, func() bool {
|
2021-03-01 17:29:07 +08:00
|
|
|
_, err := os.Stat(filepath.Join(snakeDir, "test_user_model.go"))
|
2020-11-05 14:12:47 +08:00
|
|
|
return err == nil
|
|
|
|
}())
|
2020-10-22 18:33:09 +08:00
|
|
|
}
|
2020-12-21 09:43:32 +08:00
|
|
|
|
2022-08-27 21:56:39 +08:00
|
|
|
func TestFolderName(t *testing.T) {
|
|
|
|
logx.Disable()
|
|
|
|
_ = Clean()
|
|
|
|
|
|
|
|
sqlFile := filepath.Join(pathx.MustTempDir(), "tmp.sql")
|
|
|
|
err := ioutil.WriteFile(sqlFile, []byte(source), 0o777)
|
|
|
|
assert.Nil(t, err)
|
|
|
|
|
|
|
|
dir, _ := filepath.Abs("./testmodel")
|
|
|
|
camelDir := filepath.Join(dir, "go-camel")
|
|
|
|
snakeDir := filepath.Join(dir, "go-snake")
|
|
|
|
defer func() {
|
|
|
|
_ = os.RemoveAll(dir)
|
|
|
|
}()
|
|
|
|
g, err := NewDefaultGenerator(camelDir, &config.Config{
|
|
|
|
NamingFormat: "GoZero",
|
|
|
|
})
|
|
|
|
assert.Nil(t, err)
|
|
|
|
|
|
|
|
pkg := g.pkg
|
|
|
|
|
|
|
|
err = g.StartFromDDL(sqlFile, true, "go_zero")
|
|
|
|
assert.Nil(t, err)
|
|
|
|
assert.True(t, func() bool {
|
|
|
|
_, err := os.Stat(filepath.Join(camelDir, "TestUserModel.go"))
|
|
|
|
return err == nil
|
|
|
|
}())
|
|
|
|
assert.Equal(t, pkg, g.pkg)
|
|
|
|
|
|
|
|
g, err = NewDefaultGenerator(snakeDir, &config.Config{
|
|
|
|
NamingFormat: "go_zero",
|
|
|
|
})
|
|
|
|
assert.Nil(t, err)
|
|
|
|
|
|
|
|
err = g.StartFromDDL(sqlFile, true, "go_zero")
|
|
|
|
assert.Nil(t, err)
|
|
|
|
assert.True(t, func() bool {
|
|
|
|
_, err := os.Stat(filepath.Join(snakeDir, "test_user_model.go"))
|
|
|
|
return err == nil
|
|
|
|
}())
|
|
|
|
}
|
|
|
|
|
2020-12-21 09:43:32 +08:00
|
|
|
func TestWrapWithRawString(t *testing.T) {
|
2021-07-23 11:45:15 +08:00
|
|
|
assert.Equal(t, "``", wrapWithRawString("", false))
|
|
|
|
assert.Equal(t, "``", wrapWithRawString("``", false))
|
|
|
|
assert.Equal(t, "`a`", wrapWithRawString("a", false))
|
|
|
|
assert.Equal(t, "a", wrapWithRawString("a", true))
|
|
|
|
assert.Equal(t, "` `", wrapWithRawString(" ", false))
|
2020-12-21 09:43:32 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestFields(t *testing.T) {
|
|
|
|
type Student struct {
|
2021-02-26 16:11:47 +08:00
|
|
|
ID int64 `db:"id"`
|
2020-12-21 09:43:32 +08:00
|
|
|
Name string `db:"name"`
|
|
|
|
Age sql.NullInt64 `db:"age"`
|
|
|
|
Score sql.NullFloat64 `db:"score"`
|
|
|
|
CreateTime time.Time `db:"create_time"`
|
|
|
|
UpdateTime sql.NullTime `db:"update_time"`
|
|
|
|
}
|
|
|
|
var (
|
2021-01-08 12:01:21 +08:00
|
|
|
studentFieldNames = builderx.RawFieldNames(&Student{})
|
2020-12-21 09:43:32 +08:00
|
|
|
studentRows = strings.Join(studentFieldNames, ",")
|
|
|
|
studentRowsExpectAutoSet = strings.Join(stringx.Remove(studentFieldNames, "`id`", "`create_time`", "`update_time`"), ",")
|
|
|
|
studentRowsWithPlaceHolder = strings.Join(stringx.Remove(studentFieldNames, "`id`", "`create_time`", "`update_time`"), "=?,") + "=?"
|
|
|
|
)
|
|
|
|
|
|
|
|
assert.Equal(t, []string{"`id`", "`name`", "`age`", "`score`", "`create_time`", "`update_time`"}, studentFieldNames)
|
|
|
|
assert.Equal(t, "`id`,`name`,`age`,`score`,`create_time`,`update_time`", studentRows)
|
|
|
|
assert.Equal(t, "`name`,`age`,`score`", studentRowsExpectAutoSet)
|
|
|
|
assert.Equal(t, "`name`=?,`age`=?,`score`=?", studentRowsWithPlaceHolder)
|
|
|
|
}
|
2022-04-01 14:48:45 +08:00
|
|
|
|
|
|
|
func Test_genPublicModel(t *testing.T) {
|
|
|
|
var err error
|
|
|
|
dir := pathx.MustTempDir()
|
|
|
|
modelDir := path.Join(dir, "model")
|
2022-07-10 11:05:21 +08:00
|
|
|
err = os.MkdirAll(modelDir, 0o777)
|
2022-04-01 14:48:45 +08:00
|
|
|
require.NoError(t, err)
|
|
|
|
defer os.RemoveAll(dir)
|
|
|
|
|
|
|
|
modelFilename := filepath.Join(modelDir, "foo.sql")
|
2022-07-10 11:05:21 +08:00
|
|
|
err = ioutil.WriteFile(modelFilename, []byte(source), 0o777)
|
2022-04-01 14:48:45 +08:00
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
g, err := NewDefaultGenerator(modelDir, &config.Config{
|
|
|
|
NamingFormat: config.DefaultFormat,
|
|
|
|
})
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
tables, err := parser.Parse(modelFilename, "")
|
|
|
|
require.Equal(t, 1, len(tables))
|
|
|
|
|
2022-04-02 15:36:06 +08:00
|
|
|
code, err := g.genModelCustom(*tables[0], false)
|
2022-04-01 14:48:45 +08:00
|
|
|
assert.NoError(t, err)
|
2022-04-02 15:36:06 +08:00
|
|
|
assert.True(t, strings.Contains(code, "package model"))
|
|
|
|
assert.True(t, strings.Contains(code, "TestUserModel interface {\n\t\ttestUserModel\n\t}\n"))
|
|
|
|
assert.True(t, strings.Contains(code, "customTestUserModel struct {\n\t\t*defaultTestUserModel\n\t}\n"))
|
|
|
|
assert.True(t, strings.Contains(code, "func NewTestUserModel(conn sqlx.SqlConn) TestUserModel {"))
|
2022-04-01 14:48:45 +08:00
|
|
|
}
|