refactor
This commit is contained in:
parent
0a4112d83f
commit
a15b53bf74
1 changed files with 149 additions and 125 deletions
|
|
@ -264,8 +264,60 @@ func TestGetMerchLabelsSuccess(t *testing.T) {
|
||||||
|
|
||||||
// Merch
|
// Merch
|
||||||
func TestCreateMerchSuccess(t *testing.T) {
|
func TestCreateMerchSuccess(t *testing.T) {
|
||||||
|
type testCases struct {
|
||||||
|
name string
|
||||||
|
inputDTO newMerchDTO
|
||||||
|
expectOrigins bool
|
||||||
|
expectedCode int
|
||||||
|
}
|
||||||
|
|
||||||
|
cases := []testCases{
|
||||||
|
{
|
||||||
|
name: "Success - with origins",
|
||||||
|
inputDTO: newMerchDTO{
|
||||||
|
Name: "Test name1",
|
||||||
|
Links: []originLink{
|
||||||
|
{Origin: "origin 1", Link: "link1"},
|
||||||
|
{Origin: "origin 2", Link: "link2"},
|
||||||
|
{Origin: "origin 3", Link: "link3"},
|
||||||
|
{Origin: "origin 4", Link: "link4"},
|
||||||
|
{Origin: "origin 5", Link: "link5"},
|
||||||
|
{Origin: "origin 6", Link: "link6"},
|
||||||
|
{Origin: "origin 7", Link: "link7"},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
expectOrigins: true,
|
||||||
|
expectedCode: 201,
|
||||||
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
name: "Success - without origins",
|
||||||
|
inputDTO: newMerchDTO{
|
||||||
|
Name: "Test name2",
|
||||||
|
},
|
||||||
|
expectOrigins: false,
|
||||||
|
expectedCode: 201,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, tt := range cases {
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
mockRepo := new(MockRepository)
|
mockRepo := new(MockRepository)
|
||||||
|
|
||||||
|
if tt.expectOrigins {
|
||||||
|
mockRepo.
|
||||||
|
On("getOrigins", mock.Anything).
|
||||||
|
Return([]Origin{
|
||||||
|
{Id: 1, Name: "origin 1"},
|
||||||
|
{Id: 2, Name: "origin 2"},
|
||||||
|
{Id: 3, Name: "origin 3"},
|
||||||
|
{Id: 4, Name: "origin 4"},
|
||||||
|
{Id: 5, Name: "origin 5"},
|
||||||
|
{Id: 6, Name: "origin 6"},
|
||||||
|
{Id: 7, Name: "origin 7"},
|
||||||
|
}, nil)
|
||||||
|
}
|
||||||
|
|
||||||
merchExpected := mock.MatchedBy(func(arg any) bool {
|
merchExpected := mock.MatchedBy(func(arg any) bool {
|
||||||
model, ok := arg.(*Merch)
|
model, ok := arg.(*Merch)
|
||||||
if !ok {
|
if !ok {
|
||||||
|
|
@ -308,46 +360,17 @@ func TestCreateMerchSuccess(t *testing.T) {
|
||||||
if !ok {
|
if !ok {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
return true
|
return true
|
||||||
})
|
})
|
||||||
|
|
||||||
mockRepo.
|
|
||||||
On("getOrigins", mock.Anything).
|
|
||||||
Return([]Origin{
|
|
||||||
{Id: 1, Name: "origin 1"},
|
|
||||||
{Id: 2, Name: "origin 2"},
|
|
||||||
{Id: 3, Name: "origin 3"},
|
|
||||||
{Id: 4, Name: "origin 4"},
|
|
||||||
{Id: 5, Name: "origin 5"},
|
|
||||||
{Id: 6, Name: "origin 6"},
|
|
||||||
{Id: 7, Name: "origin 7"},
|
|
||||||
}, nil)
|
|
||||||
|
|
||||||
mockRepo.
|
mockRepo.
|
||||||
On("createMerch", mock.Anything, merchExpected, extraExpected).
|
On("createMerch", mock.Anything, merchExpected, extraExpected).
|
||||||
Return(nil)
|
Return(nil)
|
||||||
|
|
||||||
router := setupTestRouter(mockRepo)
|
router := setupTestRouter(mockRepo)
|
||||||
|
|
||||||
data1 := newMerchDTO{
|
payload, err := json.Marshal(&tt.inputDTO)
|
||||||
Name: "Test name1",
|
|
||||||
Links: []originLink{
|
|
||||||
{Origin: "origin 1", Link: "link1"},
|
|
||||||
{Origin: "origin 2", Link: "link2"},
|
|
||||||
{Origin: "origin 3", Link: "link3"},
|
|
||||||
{Origin: "origin 4", Link: "link4"},
|
|
||||||
{Origin: "origin 5", Link: "link5"},
|
|
||||||
{Origin: "origin 6", Link: "link6"},
|
|
||||||
{Origin: "origin 7", Link: "link7"},
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
data2 := newMerchDTO{
|
|
||||||
Name: "Test name2",
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, tt := range []newMerchDTO{data1, data2} {
|
|
||||||
payload, err := json.Marshal(&tt)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatal(err)
|
t.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|
@ -359,15 +382,16 @@ func TestCreateMerchSuccess(t *testing.T) {
|
||||||
|
|
||||||
router.ServeHTTP(w, req)
|
router.ServeHTTP(w, req)
|
||||||
|
|
||||||
assert.Equal(t, 201, w.Code)
|
assert.Equal(t, tt.expectedCode, w.Code)
|
||||||
}
|
|
||||||
|
|
||||||
mockRepo.AssertExpectations(t)
|
mockRepo.AssertExpectations(t)
|
||||||
|
|
||||||
|
})
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestGetManySuccess(t *testing.T) {
|
func TestGetManySuccess(t *testing.T) {
|
||||||
type testCase struct {
|
type testCase struct {
|
||||||
caseName string
|
name string
|
||||||
getManyReturn []getMerchInternal
|
getManyReturn []getMerchInternal
|
||||||
expectLabels bool
|
expectLabels bool
|
||||||
labelsReceive []int64
|
labelsReceive []int64
|
||||||
|
|
@ -378,7 +402,7 @@ func TestGetManySuccess(t *testing.T) {
|
||||||
|
|
||||||
cases := []testCase{
|
cases := []testCase{
|
||||||
{
|
{
|
||||||
caseName: "Success with merch",
|
name: "Success with merch",
|
||||||
getManyReturn: []getMerchInternal{
|
getManyReturn: []getMerchInternal{
|
||||||
{Id: 1, MerchUuid: validUuid, Name: "merch1"},
|
{Id: 1, MerchUuid: validUuid, Name: "merch1"},
|
||||||
{Id: 2, MerchUuid: validUuid, Name: "merch2"},
|
{Id: 2, MerchUuid: validUuid, Name: "merch2"},
|
||||||
|
|
@ -396,14 +420,14 @@ func TestGetManySuccess(t *testing.T) {
|
||||||
},
|
},
|
||||||
|
|
||||||
{
|
{
|
||||||
caseName: "Success no merch - empty merch",
|
name: "Success no merch - empty merch",
|
||||||
getManyReturn: []getMerchInternal{},
|
getManyReturn: []getMerchInternal{},
|
||||||
expectLabels: false,
|
expectLabels: false,
|
||||||
expectedCode: 204,
|
expectedCode: 204,
|
||||||
},
|
},
|
||||||
|
|
||||||
{
|
{
|
||||||
caseName: "Success no merch - nil merch",
|
name: "Success no merch - nil merch",
|
||||||
getManyReturn: nil,
|
getManyReturn: nil,
|
||||||
expectLabels: false,
|
expectLabels: false,
|
||||||
expectedCode: 204,
|
expectedCode: 204,
|
||||||
|
|
@ -411,8 +435,7 @@ func TestGetManySuccess(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, tt := range cases {
|
for _, tt := range cases {
|
||||||
t.Log(tt.caseName)
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
|
||||||
mockRepo := new(MockRepository)
|
mockRepo := new(MockRepository)
|
||||||
|
|
||||||
mockRepo.
|
mockRepo.
|
||||||
|
|
@ -445,5 +468,6 @@ func TestGetManySuccess(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
mockRepo.AssertExpectations(t)
|
mockRepo.AssertExpectations(t)
|
||||||
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue