|
|
|
package parser
|
|
|
|
|
|
|
|
import (
|
|
|
|
_ "embed"
|
|
|
|
"io/ioutil"
|
|
|
|
"path/filepath"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
|
|
|
|
"github.com/zeromicro/go-zero/tools/goctl/model/sql/model"
|
|
|
|
"github.com/zeromicro/go-zero/tools/goctl/model/sql/util"
|
|
|
|
"github.com/zeromicro/go-zero/tools/goctl/util/pathx"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestParsePlainText(t *testing.T) {
|
|
|
|
sqlFile := filepath.Join(pathx.MustTempDir(), "tmp.sql")
|
|
|
|
err := ioutil.WriteFile(sqlFile, []byte("plain text"), 0o777)
|
|
|
|
assert.Nil(t, err)
|
|
|
|
|
|
|
|
_, err = Parse(sqlFile, "go_zero", false)
|
|
|
|
assert.NotNil(t, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestParseSelect(t *testing.T) {
|
|
|
|
sqlFile := filepath.Join(pathx.MustTempDir(), "tmp.sql")
|
|
|
|
err := ioutil.WriteFile(sqlFile, []byte("select * from user"), 0o777)
|
|
|
|
assert.Nil(t, err)
|
|
|
|
|
|
|
|
tables, err := Parse(sqlFile, "go_zero", false)
|
|
|
|
assert.Nil(t, err)
|
|
|
|
assert.Equal(t, 0, len(tables))
|
|
|
|
}
|
|
|
|
|
|
|
|
//go:embed testdata/user.sql
|
|
|
|
var user string
|
|
|
|
|
|
|
|
func TestParseCreateTable(t *testing.T) {
|
|
|
|
sqlFile := filepath.Join(pathx.MustTempDir(), "tmp.sql")
|
|
|
|
err := ioutil.WriteFile(sqlFile, []byte(user), 0o777)
|
|
|
|
assert.Nil(t, err)
|
|
|
|
|
|
|
|
tables, err := Parse(sqlFile, "go_zero", false)
|
|
|
|
assert.Equal(t, 1, len(tables))
|
|
|
|
table := tables[0]
|
|
|
|
assert.Nil(t, err)
|
|
|
|
assert.Equal(t, "test_user", table.Name.Source())
|
|
|
|
assert.Equal(t, "id", table.PrimaryKey.Name.Source())
|
|
|
|
assert.Equal(t, true, table.ContainsTime())
|
|
|
|
assert.Equal(t, 2, len(table.UniqueIndex))
|
|
|
|
assert.True(t, func() bool {
|
|
|
|
for _, e := range table.Fields {
|
|
|
|
if e.Comment != util.TrimNewLine(e.Comment) {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return true
|
|
|
|
}())
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestConvertColumn(t *testing.T) {
|
|
|
|
t.Run("missingPrimaryKey", func(t *testing.T) {
|
|
|
|
columnData := model.ColumnData{
|
|
|
|
Db: "user",
|
|
|
|
Table: "user",
|
|
|
|
Columns: []*model.Column{
|
|
|
|
{
|
|
|
|
DbColumn: &model.DbColumn{
|
|
|
|
Name: "id",
|
|
|
|
DataType: "bigint",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
_, err := columnData.Convert()
|
|
|
|
assert.NotNil(t, err)
|
|
|
|
assert.Contains(t, err.Error(), "missing primary key")
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("jointPrimaryKey", func(t *testing.T) {
|
|
|
|
columnData := model.ColumnData{
|
|
|
|
Db: "user",
|
|
|
|
Table: "user",
|
|
|
|
Columns: []*model.Column{
|
|
|
|
{
|
|
|
|
DbColumn: &model.DbColumn{
|
|
|
|
Name: "id",
|
|
|
|
DataType: "bigint",
|
|
|
|
},
|
|
|
|
Index: &model.DbIndex{
|
|
|
|
IndexName: "PRIMARY",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
DbColumn: &model.DbColumn{
|
|
|
|
Name: "mobile",
|
|
|
|
DataType: "varchar",
|
|
|
|
Comment: "手机号",
|
|
|
|
},
|
|
|
|
Index: &model.DbIndex{
|
|
|
|
IndexName: "PRIMARY",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
_, err := columnData.Convert()
|
|
|
|
assert.NotNil(t, err)
|
|
|
|
assert.Contains(t, err.Error(), "joint primary key is not supported")
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("normal", func(t *testing.T) {
|
|
|
|
columnData := model.ColumnData{
|
|
|
|
Db: "user",
|
|
|
|
Table: "user",
|
|
|
|
Columns: []*model.Column{
|
|
|
|
{
|
|
|
|
DbColumn: &model.DbColumn{
|
|
|
|
Name: "id",
|
|
|
|
DataType: "bigint",
|
|
|
|
Extra: "auto_increment",
|
|
|
|
},
|
|
|
|
Index: &model.DbIndex{
|
|
|
|
IndexName: "PRIMARY",
|
|
|
|
SeqInIndex: 1,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
DbColumn: &model.DbColumn{
|
|
|
|
Name: "mobile",
|
|
|
|
DataType: "varchar",
|
|
|
|
Comment: "手机号",
|
|
|
|
},
|
|
|
|
Index: &model.DbIndex{
|
|
|
|
IndexName: "mobile_unique",
|
|
|
|
SeqInIndex: 1,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
table, err := columnData.Convert()
|
|
|
|
assert.Nil(t, err)
|
|
|
|
assert.True(t, table.PrimaryKey.Index.IndexName == "PRIMARY" && table.PrimaryKey.Name == "id")
|
|
|
|
for _, item := range table.Columns {
|
|
|
|
if item.Name == "mobile" {
|
|
|
|
assert.True(t, item.Index.NonUnique == 0)
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|