fix: date fixes; go middleware refactors; regex fixes; etc (#368)
fix: format of date when MR was closed or merged (#367) refactor: Add Payload Validators + Middleware In Go Code (#366) fix: Add better checks for leaving comments (#369) fix: regex support for http credentials embedded in remote url (#372) fix: Comment on single line selects two lines (#371) This is a #PATCH release.
This commit is contained in:
committed by
GitHub
parent
f1faf603b0
commit
22bfd0c83e
84
cmd/app/resolve_discussion_test.go
Normal file
84
cmd/app/resolve_discussion_test.go
Normal file
@@ -0,0 +1,84 @@
|
||||
package app
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
"testing"
|
||||
|
||||
"github.com/xanzy/go-gitlab"
|
||||
)
|
||||
|
||||
type fakeDiscussionResolver struct {
|
||||
testBase
|
||||
}
|
||||
|
||||
func (f fakeDiscussionResolver) ResolveMergeRequestDiscussion(pid interface{}, mergeRequest int, discussion string, opt *gitlab.ResolveMergeRequestDiscussionOptions, options ...gitlab.RequestOptionFunc) (*gitlab.Discussion, *gitlab.Response, error) {
|
||||
resp, err := f.handleGitlabError()
|
||||
if err != nil {
|
||||
return nil, nil, err
|
||||
}
|
||||
|
||||
return &gitlab.Discussion{}, resp, err
|
||||
}
|
||||
|
||||
func TestResolveDiscussion(t *testing.T) {
|
||||
var testResolveMergeRequestPayload = DiscussionResolveRequest{
|
||||
DiscussionID: "abc123",
|
||||
Resolved: true,
|
||||
}
|
||||
|
||||
t.Run("Resolves a discussion", func(t *testing.T) {
|
||||
svc := middleware(
|
||||
discussionsResolutionService{testProjectData, fakeDiscussionResolver{}},
|
||||
withMr(testProjectData, fakeMergeRequestLister{}),
|
||||
withPayloadValidation(methodToPayload{http.MethodPut: &DiscussionResolveRequest{}}),
|
||||
withMethodCheck(http.MethodPut),
|
||||
)
|
||||
request := makeRequest(t, http.MethodPut, "/mr/discussions/resolve", testResolveMergeRequestPayload)
|
||||
data := getSuccessData(t, svc, request)
|
||||
assert(t, data.Message, "Discussion resolved")
|
||||
})
|
||||
|
||||
t.Run("Unresolves a discussion", func(t *testing.T) {
|
||||
payload := testResolveMergeRequestPayload
|
||||
payload.Resolved = false
|
||||
svc := middleware(
|
||||
discussionsResolutionService{testProjectData, fakeDiscussionResolver{}},
|
||||
withMr(testProjectData, fakeMergeRequestLister{}),
|
||||
withPayloadValidation(methodToPayload{http.MethodPut: &DiscussionResolveRequest{}}),
|
||||
withMethodCheck(http.MethodPut),
|
||||
)
|
||||
request := makeRequest(t, http.MethodPut, "/mr/discussions/resolve", payload)
|
||||
data := getSuccessData(t, svc, request)
|
||||
assert(t, data.Message, "Discussion unresolved")
|
||||
})
|
||||
|
||||
t.Run("Requires a discussion ID", func(t *testing.T) {
|
||||
payload := testResolveMergeRequestPayload
|
||||
payload.DiscussionID = ""
|
||||
svc := middleware(
|
||||
discussionsResolutionService{testProjectData, fakeDiscussionResolver{}},
|
||||
withMr(testProjectData, fakeMergeRequestLister{}),
|
||||
withPayloadValidation(methodToPayload{http.MethodPut: &DiscussionResolveRequest{}}),
|
||||
withMethodCheck(http.MethodPut),
|
||||
)
|
||||
request := makeRequest(t, http.MethodPut, "/mr/discussions/resolve", payload)
|
||||
data, status := getFailData(t, svc, request)
|
||||
assert(t, data.Message, "Invalid payload")
|
||||
assert(t, data.Details, "DiscussionID is required")
|
||||
assert(t, status, http.StatusBadRequest)
|
||||
})
|
||||
|
||||
t.Run("Handles error from Gitlab", func(t *testing.T) {
|
||||
svc := middleware(
|
||||
discussionsResolutionService{testProjectData, fakeDiscussionResolver{testBase: testBase{errFromGitlab: true}}},
|
||||
withMr(testProjectData, fakeMergeRequestLister{}),
|
||||
withPayloadValidation(methodToPayload{http.MethodPut: &DiscussionResolveRequest{}}),
|
||||
withMethodCheck(http.MethodPut),
|
||||
)
|
||||
request := makeRequest(t, http.MethodPut, "/mr/discussions/resolve", testResolveMergeRequestPayload)
|
||||
data, status := getFailData(t, svc, request)
|
||||
assert(t, data.Message, "Could not resolve discussion")
|
||||
assert(t, data.Details, "Some error from Gitlab")
|
||||
assert(t, status, http.StatusInternalServerError)
|
||||
})
|
||||
}
|
||||
Reference in New Issue
Block a user