Rainbond/db/mysql/dao/application_config_group_test.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
}
})
}
}