This MR represents a major refactor of the Go codebase, as well as introducing tests for the handlers. The MR also introduces an endpoint to shutdown or restart the Go server, which may be useful for clients who want to refresh the state of the plugin after checking out branches. Finally, this MR adds a contributing document for users who want to make feature changes.
59 lines
2.7 KiB
Go
59 lines
2.7 KiB
Go
package main
|
|
|
|
import (
|
|
"errors"
|
|
"net/http"
|
|
"testing"
|
|
|
|
"github.com/xanzy/go-gitlab"
|
|
)
|
|
|
|
func updateAssignees(pid interface{}, mergeRequest int, opt *gitlab.UpdateMergeRequestOptions, options ...gitlab.RequestOptionFunc) (*gitlab.MergeRequest, *gitlab.Response, error) {
|
|
return &gitlab.MergeRequest{}, makeResponse(http.StatusOK), nil
|
|
}
|
|
|
|
func updateAssigneesNon200(pid interface{}, mergeRequest int, opt *gitlab.UpdateMergeRequestOptions, options ...gitlab.RequestOptionFunc) (*gitlab.MergeRequest, *gitlab.Response, error) {
|
|
return nil, makeResponse(http.StatusSeeOther), nil
|
|
}
|
|
|
|
func updateAssigneesErr(pid interface{}, mergeRequest int, opt *gitlab.UpdateMergeRequestOptions, options ...gitlab.RequestOptionFunc) (*gitlab.MergeRequest, *gitlab.Response, error) {
|
|
return nil, nil, errors.New("Some error from Gitlab")
|
|
}
|
|
|
|
func TestAssigneeHandler(t *testing.T) {
|
|
t.Run("Updates assignees", func(t *testing.T) {
|
|
request := makeRequest(t, http.MethodPut, "/mr/assignee", AssigneeUpdateRequest{Ids: []int{1, 2}})
|
|
server, _ := createRouterAndApi(fakeClient{updateMergeRequestFn: updateAssignees})
|
|
data := serveRequest(t, server, request, AssigneeUpdateResponse{})
|
|
assert(t, data.SuccessResponse.Message, "Assignees updated")
|
|
assert(t, data.SuccessResponse.Status, http.StatusOK)
|
|
})
|
|
|
|
t.Run("Disallows non-PUT method", func(t *testing.T) {
|
|
request := makeRequest(t, http.MethodPost, "/mr/assignee", nil)
|
|
server, _ := createRouterAndApi(fakeClient{updateMergeRequestFn: updateAssignees})
|
|
data := serveRequest(t, server, request, ErrorResponse{})
|
|
assert(t, data.Status, http.StatusMethodNotAllowed)
|
|
assert(t, data.Details, "Invalid request type")
|
|
assert(t, data.Message, "Expected PUT")
|
|
})
|
|
|
|
t.Run("Handles errors from Gitlab client", func(t *testing.T) {
|
|
request := makeRequest(t, http.MethodPut, "/mr/assignee", AssigneeUpdateRequest{Ids: []int{1, 2}})
|
|
server, _ := createRouterAndApi(fakeClient{updateMergeRequestFn: updateAssigneesErr})
|
|
data := serveRequest(t, server, request, ErrorResponse{})
|
|
assert(t, data.Status, http.StatusInternalServerError)
|
|
assert(t, data.Message, "Could not modify merge request assignees")
|
|
assert(t, data.Details, "Some error from Gitlab")
|
|
})
|
|
|
|
t.Run("Handles non-200s from Gitlab client", func(t *testing.T) {
|
|
request := makeRequest(t, http.MethodPut, "/mr/assignee", AssigneeUpdateRequest{Ids: []int{1, 2}})
|
|
server, _ := createRouterAndApi(fakeClient{updateMergeRequestFn: updateAssigneesNon200})
|
|
data := serveRequest(t, server, request, ErrorResponse{})
|
|
assert(t, data.Status, http.StatusSeeOther)
|
|
assert(t, data.Message, "Could not modify merge request assignees")
|
|
assert(t, data.Details, "An error occurred on the /mr/assignee endpoint")
|
|
})
|
|
}
|