mirror of
https://gitee.com/rainbond/Rainbond.git
synced 2024-12-05 13:17:42 +08:00
502 lines
14 KiB
Go
502 lines
14 KiB
Go
package dao
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/DATA-DOG/go-sqlmock"
|
|
"github.com/goodrain/rainbond/db/model"
|
|
"github.com/jinzhu/gorm"
|
|
"github.com/pkg/errors"
|
|
)
|
|
|
|
// Test AppConfigGroup Dao
|
|
func TestAppConfigGroupDaoAddModel(t *testing.T) {
|
|
req := &model.ApplicationConfigGroup{
|
|
AppID: "appID",
|
|
ConfigGroupName: "configname",
|
|
}
|
|
tests := []struct {
|
|
name string
|
|
request *model.ApplicationConfigGroup
|
|
mockFunc func(mock sqlmock.Sqlmock)
|
|
wanterr bool
|
|
}{
|
|
{
|
|
name: "config group exists,return err",
|
|
request: req,
|
|
mockFunc: func(mock sqlmock.Sqlmock) {
|
|
rows := sqlmock.
|
|
NewRows([]string{"app_id", "config_group_name"}).
|
|
AddRow("ID1", "Name1")
|
|
mock.ExpectQuery("SELECT").WithArgs(sqlmock.AnyArg(), sqlmock.AnyArg()).WillReturnRows(rows).WillReturnError(nil)
|
|
},
|
|
wanterr: true,
|
|
},
|
|
{
|
|
name: "config group not found,create success",
|
|
request: req,
|
|
mockFunc: func(mock sqlmock.Sqlmock) {
|
|
mock.ExpectQuery("SELECT").WithArgs(sqlmock.AnyArg(), sqlmock.AnyArg()).WillReturnError(gorm.ErrRecordNotFound)
|
|
mock.ExpectBegin()
|
|
mock.ExpectExec("INSERT").WillReturnResult(sqlmock.NewResult(1, 1)).WillReturnError(nil)
|
|
mock.ExpectCommit()
|
|
},
|
|
wanterr: false,
|
|
},
|
|
{
|
|
name: "database error",
|
|
request: req,
|
|
mockFunc: func(mock sqlmock.Sqlmock) {
|
|
mock.ExpectQuery("SELECT").WithArgs(sqlmock.AnyArg(), sqlmock.AnyArg()).WillReturnError(gorm.ErrRecordNotFound)
|
|
mock.ExpectBegin()
|
|
mock.ExpectExec("INSERT").WillReturnError(errors.New("database error"))
|
|
mock.ExpectRollback()
|
|
},
|
|
wanterr: true,
|
|
},
|
|
}
|
|
|
|
for i := range tests {
|
|
tc := tests[i]
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
db, mock, err := sqlmock.New()
|
|
if err != nil {
|
|
t.Fatalf("an error '%s' was not expected when opening a stub database connection", err)
|
|
}
|
|
defer db.Close()
|
|
|
|
gdb, _ := gorm.Open("mysql", db)
|
|
appConfigDaoImpl := &AppConfigGroupDaoImpl{
|
|
DB: gdb,
|
|
}
|
|
tc.mockFunc(mock)
|
|
|
|
req := &model.ApplicationConfigGroup{
|
|
AppID: "appID",
|
|
ConfigGroupName: "configname",
|
|
}
|
|
err = appConfigDaoImpl.AddModel(req)
|
|
if (err != nil) != tc.wanterr {
|
|
t.Errorf("Unexpected error = %v, wantErr %v", err, tc.wanterr)
|
|
return
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestAppGetConfigGroupByID(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
appID string
|
|
mockFunc func(mock sqlmock.Sqlmock)
|
|
wanterr bool
|
|
}{
|
|
{
|
|
name: "get config success",
|
|
appID: "ID1",
|
|
mockFunc: func(mock sqlmock.Sqlmock) {
|
|
rows := sqlmock.
|
|
NewRows([]string{"app_id", "config_group_name"}).
|
|
AddRow("ID1", "Name1")
|
|
mock.ExpectQuery("SELECT").WithArgs(sqlmock.AnyArg(), sqlmock.AnyArg()).WillReturnRows(rows).WillReturnError(nil)
|
|
},
|
|
wanterr: false,
|
|
},
|
|
{
|
|
name: "get config failed",
|
|
mockFunc: func(mock sqlmock.Sqlmock) {
|
|
mock.ExpectQuery("SELECT").WithArgs(sqlmock.AnyArg(), sqlmock.AnyArg()).WillReturnError(errors.New("query failed"))
|
|
},
|
|
wanterr: true,
|
|
},
|
|
}
|
|
|
|
for i := range tests {
|
|
tc := tests[i]
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
db, mock, err := sqlmock.New()
|
|
if err != nil {
|
|
t.Fatalf("an error '%s' was not expected when opening a stub database connection", err)
|
|
}
|
|
defer db.Close()
|
|
|
|
gdb, _ := gorm.Open("mysql", db)
|
|
appConfigDaoImpl := &AppConfigGroupDaoImpl{
|
|
DB: gdb,
|
|
}
|
|
tc.mockFunc(mock)
|
|
|
|
resp, err := appConfigDaoImpl.GetConfigGroupByID("appID", "name")
|
|
if (err != nil) != tc.wanterr {
|
|
t.Errorf("Unexpected error = %v, wantErr %v", err, tc.wanterr)
|
|
return
|
|
}
|
|
if resp != nil && resp.AppID != tc.appID {
|
|
t.Errorf("reponse app_id should equal %v, but got %v", resp.AppID, tc.appID)
|
|
return
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestDeleteConfigGroup(t *testing.T) {
|
|
tests := []struct {
|
|
name, appID, configGroupName string
|
|
request *model.ConfigGroupItem
|
|
mockFunc func(mock sqlmock.Sqlmock)
|
|
wanterr bool
|
|
}{
|
|
{
|
|
name: "delete success",
|
|
mockFunc: func(mock sqlmock.Sqlmock) {
|
|
mock.ExpectBegin()
|
|
mock.ExpectExec("DELETE").WithArgs(sqlmock.AnyArg(), sqlmock.AnyArg()).WillReturnResult(sqlmock.NewResult(1, 1)).WillReturnError(nil)
|
|
mock.ExpectCommit()
|
|
},
|
|
wanterr: false,
|
|
},
|
|
{
|
|
name: "delete failed",
|
|
mockFunc: func(mock sqlmock.Sqlmock) {
|
|
mock.ExpectBegin()
|
|
mock.ExpectExec("DELETE").WithArgs(sqlmock.AnyArg(), sqlmock.AnyArg()).WillReturnError(errors.New("delete failed"))
|
|
mock.ExpectCommit()
|
|
},
|
|
wanterr: true,
|
|
},
|
|
}
|
|
for i := range tests {
|
|
tc := tests[i]
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
db, mock, err := sqlmock.New()
|
|
if err != nil {
|
|
t.Fatalf("an error '%s' was not expected when opening a stub database connection", err)
|
|
}
|
|
defer db.Close()
|
|
|
|
gdb, _ := gorm.Open("mysql", db)
|
|
appConfigGroupDaoImpl := &AppConfigGroupDaoImpl{
|
|
DB: gdb,
|
|
}
|
|
tc.mockFunc(mock)
|
|
|
|
err = appConfigGroupDaoImpl.DeleteConfigGroup(tc.appID, tc.configGroupName)
|
|
if (err != nil) != tc.wanterr {
|
|
t.Errorf("Unexpected error = %v, wantErr %v", err, tc.wanterr)
|
|
return
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
// Test AppConfigGroup Service Dao
|
|
func TestAppConfigGroupServiceDaoAddModel(t *testing.T) {
|
|
req := &model.ConfigGroupService{
|
|
AppID: "appID",
|
|
ConfigGroupName: "configname",
|
|
}
|
|
tests := []struct {
|
|
name string
|
|
request *model.ConfigGroupService
|
|
mockFunc func(mock sqlmock.Sqlmock)
|
|
wanterr bool
|
|
}{
|
|
{
|
|
name: "service config group exists,return err",
|
|
request: req,
|
|
mockFunc: func(mock sqlmock.Sqlmock) {
|
|
rows := sqlmock.
|
|
NewRows([]string{"app_id", "config_group_name", "service_id"}).
|
|
AddRow("ID1", "Name1", "serviceID1")
|
|
mock.ExpectQuery("SELECT").WithArgs(sqlmock.AnyArg(), sqlmock.AnyArg(), sqlmock.AnyArg()).WillReturnRows(rows).WillReturnError(nil)
|
|
},
|
|
wanterr: true,
|
|
},
|
|
{
|
|
name: "service config group not found,create success",
|
|
request: req,
|
|
mockFunc: func(mock sqlmock.Sqlmock) {
|
|
mock.ExpectQuery("SELECT").WithArgs(sqlmock.AnyArg(), sqlmock.AnyArg(), sqlmock.AnyArg()).WillReturnError(gorm.ErrRecordNotFound)
|
|
mock.ExpectBegin()
|
|
mock.ExpectExec("INSERT").WillReturnResult(sqlmock.NewResult(1, 1)).WillReturnError(nil)
|
|
mock.ExpectCommit()
|
|
},
|
|
wanterr: false,
|
|
},
|
|
{
|
|
name: "database error",
|
|
request: req,
|
|
mockFunc: func(mock sqlmock.Sqlmock) {
|
|
mock.ExpectBegin()
|
|
mock.ExpectQuery("SELECT").WithArgs(sqlmock.AnyArg(), sqlmock.AnyArg()).WillReturnError(gorm.ErrRecordNotFound)
|
|
mock.ExpectExec("INSERT").WillReturnError(errors.New("database error"))
|
|
mock.ExpectRollback()
|
|
},
|
|
wanterr: true,
|
|
},
|
|
}
|
|
|
|
for i := range tests {
|
|
tc := tests[i]
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
db, mock, err := sqlmock.New()
|
|
if err != nil {
|
|
t.Fatalf("an error '%s' was not expected when opening a stub database connection", err)
|
|
}
|
|
defer db.Close()
|
|
|
|
gdb, _ := gorm.Open("mysql", db)
|
|
serviceConfigGroupDao := &AppConfigGroupServiceDaoImpl{
|
|
DB: gdb,
|
|
}
|
|
tc.mockFunc(mock)
|
|
|
|
req := &model.ConfigGroupService{
|
|
AppID: "appID",
|
|
ConfigGroupName: "configname",
|
|
ServiceID: "serviceID",
|
|
}
|
|
err = serviceConfigGroupDao.AddModel(req)
|
|
if (err != nil) != tc.wanterr {
|
|
t.Errorf("Unexpected error = %v, wantErr %v", err, tc.wanterr)
|
|
return
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestDeleteConfigGroupService(t *testing.T) {
|
|
tests := []struct {
|
|
name, appID, configGroupName string
|
|
request *model.ConfigGroupItem
|
|
mockFunc func(mock sqlmock.Sqlmock)
|
|
wanterr bool
|
|
}{
|
|
{
|
|
name: "delete success",
|
|
mockFunc: func(mock sqlmock.Sqlmock) {
|
|
mock.ExpectBegin()
|
|
mock.ExpectExec("DELETE").WithArgs(sqlmock.AnyArg(), sqlmock.AnyArg()).WillReturnResult(sqlmock.NewResult(1, 1)).WillReturnError(nil)
|
|
mock.ExpectCommit()
|
|
},
|
|
wanterr: false,
|
|
},
|
|
{
|
|
name: "delete failed",
|
|
mockFunc: func(mock sqlmock.Sqlmock) {
|
|
mock.ExpectBegin()
|
|
mock.ExpectExec("DELETE").WithArgs(sqlmock.AnyArg(), sqlmock.AnyArg()).WillReturnError(errors.New("delete failed"))
|
|
mock.ExpectCommit()
|
|
},
|
|
wanterr: true,
|
|
},
|
|
}
|
|
for i := range tests {
|
|
tc := tests[i]
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
db, mock, err := sqlmock.New()
|
|
if err != nil {
|
|
t.Fatalf("an error '%s' was not expected when opening a stub database connection", err)
|
|
}
|
|
defer db.Close()
|
|
|
|
gdb, _ := gorm.Open("mysql", db)
|
|
appConfigGroupServiceDaoImpl := &AppConfigGroupServiceDaoImpl{
|
|
DB: gdb,
|
|
}
|
|
tc.mockFunc(mock)
|
|
|
|
err = appConfigGroupServiceDaoImpl.DeleteConfigGroupService(tc.appID, tc.configGroupName)
|
|
if (err != nil) != tc.wanterr {
|
|
t.Errorf("Unexpected error = %v, wantErr %v", err, tc.wanterr)
|
|
return
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
// Test AppConfigGroup Item Dao
|
|
func TestAppConfigGroupItemDaoAddModel(t *testing.T) {
|
|
req := &model.ConfigGroupItem{
|
|
AppID: "appID",
|
|
ConfigGroupName: "configname",
|
|
ItemKey: "key1",
|
|
}
|
|
tests := []struct {
|
|
name string
|
|
request *model.ConfigGroupItem
|
|
mockFunc func(mock sqlmock.Sqlmock)
|
|
wanterr bool
|
|
}{
|
|
{
|
|
name: "config item exists,return err",
|
|
request: req,
|
|
mockFunc: func(mock sqlmock.Sqlmock) {
|
|
rows := sqlmock.
|
|
NewRows([]string{"app_id", "config_group_name", "item_key"}).
|
|
AddRow("ID1", "Name1", "key1")
|
|
mock.ExpectQuery("SELECT").WithArgs(sqlmock.AnyArg(), sqlmock.AnyArg(), sqlmock.AnyArg()).WillReturnRows(rows).WillReturnError(nil)
|
|
},
|
|
wanterr: true,
|
|
},
|
|
{
|
|
name: "config item not found,create success",
|
|
request: req,
|
|
mockFunc: func(mock sqlmock.Sqlmock) {
|
|
mock.ExpectQuery("SELECT").WithArgs(sqlmock.AnyArg(), sqlmock.AnyArg(), sqlmock.AnyArg()).WillReturnError(gorm.ErrRecordNotFound)
|
|
mock.ExpectBegin()
|
|
mock.ExpectExec("INSERT").WillReturnResult(sqlmock.NewResult(1, 1)).WillReturnError(nil)
|
|
mock.ExpectCommit()
|
|
},
|
|
wanterr: false,
|
|
},
|
|
{
|
|
name: "database error",
|
|
request: req,
|
|
mockFunc: func(mock sqlmock.Sqlmock) {
|
|
mock.ExpectBegin()
|
|
mock.ExpectQuery("SELECT").WithArgs(sqlmock.AnyArg(), sqlmock.AnyArg(), sqlmock.AnyArg()).WillReturnError(errors.New("database error"))
|
|
mock.ExpectExec("INSERT").WillReturnError(errors.New("database error"))
|
|
mock.ExpectRollback()
|
|
},
|
|
wanterr: true,
|
|
},
|
|
}
|
|
|
|
for i := range tests {
|
|
tc := tests[i]
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
db, mock, err := sqlmock.New()
|
|
if err != nil {
|
|
t.Fatalf("an error '%s' was not expected when opening a stub database connection", err)
|
|
}
|
|
defer db.Close()
|
|
|
|
gdb, _ := gorm.Open("mysql", db)
|
|
configItemDaoImpl := &AppConfigGroupItemDaoImpl{
|
|
DB: gdb,
|
|
}
|
|
tc.mockFunc(mock)
|
|
|
|
req := &model.ConfigGroupItem{
|
|
AppID: "appID",
|
|
ConfigGroupName: "configname",
|
|
ItemKey: "key1",
|
|
}
|
|
err = configItemDaoImpl.AddModel(req)
|
|
if (err != nil) != tc.wanterr {
|
|
t.Errorf("Unexpected error = %v, wantErr %v", err, tc.wanterr)
|
|
return
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestAppConfigGroupItemDaoUpdateModel(t *testing.T) {
|
|
req := &model.ConfigGroupItem{
|
|
AppID: "appID",
|
|
ConfigGroupName: "configname",
|
|
ItemKey: "key1",
|
|
ItemValue: "value1",
|
|
}
|
|
tests := []struct {
|
|
name string
|
|
request *model.ConfigGroupItem
|
|
mockFunc func(mock sqlmock.Sqlmock)
|
|
wanterr bool
|
|
}{
|
|
{
|
|
name: "update config item success",
|
|
request: req,
|
|
mockFunc: func(mock sqlmock.Sqlmock) {
|
|
mock.ExpectBegin()
|
|
mock.ExpectExec("UPDATE").WithArgs(sqlmock.AnyArg(), sqlmock.AnyArg(), sqlmock.AnyArg(), sqlmock.AnyArg()).WillReturnResult(sqlmock.NewResult(1, 1)).WillReturnError(nil)
|
|
mock.ExpectCommit()
|
|
},
|
|
wanterr: false,
|
|
},
|
|
{
|
|
name: "update config item failed",
|
|
request: req,
|
|
mockFunc: func(mock sqlmock.Sqlmock) {
|
|
mock.ExpectBegin()
|
|
mock.ExpectExec("UPDATE").WithArgs(sqlmock.AnyArg(), sqlmock.AnyArg(), sqlmock.AnyArg(), sqlmock.AnyArg()).WillReturnError(errors.New("database error"))
|
|
mock.ExpectCommit()
|
|
},
|
|
wanterr: true,
|
|
},
|
|
}
|
|
for i := range tests {
|
|
tc := tests[i]
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
db, mock, err := sqlmock.New()
|
|
if err != nil {
|
|
t.Fatalf("an error '%s' was not expected when opening a stub database connection", err)
|
|
}
|
|
defer db.Close()
|
|
|
|
gdb, _ := gorm.Open("mysql", db)
|
|
configItemDaoImpl := &AppConfigGroupItemDaoImpl{
|
|
DB: gdb,
|
|
}
|
|
tc.mockFunc(mock)
|
|
|
|
err = configItemDaoImpl.UpdateModel(req)
|
|
if (err != nil) != tc.wanterr {
|
|
t.Errorf("Unexpected error = %v, wantErr %v", err, tc.wanterr)
|
|
return
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestDeleteConfigGroupItem(t *testing.T) {
|
|
tests := []struct {
|
|
name, appID, configGroupName string
|
|
request *model.ConfigGroupItem
|
|
mockFunc func(mock sqlmock.Sqlmock)
|
|
wanterr bool
|
|
}{
|
|
{
|
|
name: "delete success",
|
|
mockFunc: func(mock sqlmock.Sqlmock) {
|
|
mock.ExpectBegin()
|
|
mock.ExpectExec("DELETE").WithArgs(sqlmock.AnyArg(), sqlmock.AnyArg()).WillReturnResult(sqlmock.NewResult(1, 1)).WillReturnError(nil)
|
|
mock.ExpectCommit()
|
|
},
|
|
wanterr: false,
|
|
},
|
|
{
|
|
name: "delete failed",
|
|
mockFunc: func(mock sqlmock.Sqlmock) {
|
|
mock.ExpectBegin()
|
|
mock.ExpectExec("DELETE").WithArgs(sqlmock.AnyArg(), sqlmock.AnyArg()).WillReturnError(errors.New("delete failed"))
|
|
mock.ExpectCommit()
|
|
},
|
|
wanterr: true,
|
|
},
|
|
}
|
|
for i := range tests {
|
|
tc := tests[i]
|
|
t.Run(tc.name, func(t *testing.T) {
|
|
db, mock, err := sqlmock.New()
|
|
if err != nil {
|
|
t.Fatalf("an error '%s' was not expected when opening a stub database connection", err)
|
|
}
|
|
defer db.Close()
|
|
|
|
gdb, _ := gorm.Open("mysql", db)
|
|
appConfigGroupItemDaoImpl := &AppConfigGroupItemDaoImpl{
|
|
DB: gdb,
|
|
}
|
|
tc.mockFunc(mock)
|
|
|
|
err = appConfigGroupItemDaoImpl.DeleteConfigGroupItem(tc.appID, tc.configGroupName)
|
|
if (err != nil) != tc.wanterr {
|
|
t.Errorf("Unexpected error = %v, wantErr %v", err, tc.wanterr)
|
|
return
|
|
}
|
|
})
|
|
}
|
|
}
|