gen_test.go 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. package gen
  2. import (
  3. "database/sql"
  4. "os"
  5. "path/filepath"
  6. "strings"
  7. "testing"
  8. "time"
  9. "github.com/stretchr/testify/assert"
  10. "github.com/tal-tech/go-zero/core/logx"
  11. "github.com/tal-tech/go-zero/core/stringx"
  12. "github.com/tal-tech/go-zero/tools/goctl/config"
  13. "github.com/tal-tech/go-zero/tools/goctl/model/sql/builderx"
  14. )
  15. var (
  16. source = "CREATE TABLE `test_user` (\n `id` bigint NOT NULL AUTO_INCREMENT,\n `mobile` varchar(255) COLLATE utf8mb4_bin NOT NULL,\n `class` bigint NOT NULL,\n `name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_bin NOT NULL,\n `create_time` timestamp NULL DEFAULT CURRENT_TIMESTAMP,\n `update_time` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,\n PRIMARY KEY (`id`),\n UNIQUE KEY `mobile_unique` (`mobile`),\n UNIQUE KEY `class_name_unique` (`class`,`name`),\n KEY `create_index` (`create_time`),\n KEY `name_index` (`name`)\n) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin;"
  17. )
  18. func TestCacheModel(t *testing.T) {
  19. logx.Disable()
  20. _ = Clean()
  21. dir := filepath.Join(t.TempDir(), "./testmodel")
  22. cacheDir := filepath.Join(dir, "cache")
  23. noCacheDir := filepath.Join(dir, "nocache")
  24. g, err := NewDefaultGenerator(cacheDir, &config.Config{
  25. NamingFormat: "GoZero",
  26. })
  27. assert.Nil(t, err)
  28. err = g.StartFromDDL(source, true)
  29. assert.Nil(t, err)
  30. assert.True(t, func() bool {
  31. _, err := os.Stat(filepath.Join(cacheDir, "TestUserModel.go"))
  32. return err == nil
  33. }())
  34. g, err = NewDefaultGenerator(noCacheDir, &config.Config{
  35. NamingFormat: "gozero",
  36. })
  37. assert.Nil(t, err)
  38. err = g.StartFromDDL(source, false)
  39. assert.Nil(t, err)
  40. assert.True(t, func() bool {
  41. _, err := os.Stat(filepath.Join(noCacheDir, "testusermodel.go"))
  42. return err == nil
  43. }())
  44. }
  45. func TestNamingModel(t *testing.T) {
  46. logx.Disable()
  47. _ = Clean()
  48. dir, _ := filepath.Abs("./testmodel")
  49. camelDir := filepath.Join(dir, "camel")
  50. snakeDir := filepath.Join(dir, "snake")
  51. defer func() {
  52. _ = os.RemoveAll(dir)
  53. }()
  54. g, err := NewDefaultGenerator(camelDir, &config.Config{
  55. NamingFormat: "GoZero",
  56. })
  57. assert.Nil(t, err)
  58. err = g.StartFromDDL(source, true)
  59. assert.Nil(t, err)
  60. assert.True(t, func() bool {
  61. _, err := os.Stat(filepath.Join(camelDir, "TestUserModel.go"))
  62. return err == nil
  63. }())
  64. g, err = NewDefaultGenerator(snakeDir, &config.Config{
  65. NamingFormat: "go_zero",
  66. })
  67. assert.Nil(t, err)
  68. err = g.StartFromDDL(source, true)
  69. assert.Nil(t, err)
  70. assert.True(t, func() bool {
  71. _, err := os.Stat(filepath.Join(snakeDir, "test_user_model.go"))
  72. return err == nil
  73. }())
  74. }
  75. func TestWrapWithRawString(t *testing.T) {
  76. assert.Equal(t, "``", wrapWithRawString(""))
  77. assert.Equal(t, "``", wrapWithRawString("``"))
  78. assert.Equal(t, "`a`", wrapWithRawString("a"))
  79. assert.Equal(t, "` `", wrapWithRawString(" "))
  80. }
  81. func TestFields(t *testing.T) {
  82. type Student struct {
  83. ID int64 `db:"id"`
  84. Name string `db:"name"`
  85. Age sql.NullInt64 `db:"age"`
  86. Score sql.NullFloat64 `db:"score"`
  87. CreateTime time.Time `db:"create_time"`
  88. UpdateTime sql.NullTime `db:"update_time"`
  89. }
  90. var (
  91. studentFieldNames = builderx.RawFieldNames(&Student{})
  92. studentRows = strings.Join(studentFieldNames, ",")
  93. studentRowsExpectAutoSet = strings.Join(stringx.Remove(studentFieldNames, "`id`", "`create_time`", "`update_time`"), ",")
  94. studentRowsWithPlaceHolder = strings.Join(stringx.Remove(studentFieldNames, "`id`", "`create_time`", "`update_time`"), "=?,") + "=?"
  95. )
  96. assert.Equal(t, []string{"`id`", "`name`", "`age`", "`score`", "`create_time`", "`update_time`"}, studentFieldNames)
  97. assert.Equal(t, "`id`,`name`,`age`,`score`,`create_time`,`update_time`", studentRows)
  98. assert.Equal(t, "`name`,`age`,`score`", studentRowsExpectAutoSet)
  99. assert.Equal(t, "`name`=?,`age`=?,`score`=?", studentRowsWithPlaceHolder)
  100. }