Skip to content
This repository has been archived by the owner on Dec 10, 2024. It is now read-only.

Commit

Permalink
Merge pull request #1846 from eranor/feat/add-group-milestone-delete-…
Browse files Browse the repository at this point in the history
…method

Add delete group milestone functionality and tests
  • Loading branch information
svanharmelen authored Dec 9, 2023
2 parents d3e39bd + 0db60c8 commit d97e905
Show file tree
Hide file tree
Showing 2 changed files with 42 additions and 0 deletions.
18 changes: 18 additions & 0 deletions group_milestones.go
Original file line number Diff line number Diff line change
Expand Up @@ -188,6 +188,24 @@ func (s *GroupMilestonesService) UpdateGroupMilestone(gid interface{}, milestone
return m, resp, nil
}

// DeleteGroupMilestone deletes a specified group milestone.
//
// GitLab API docs:
// https://docs.gitlab.com/ee/api/group_milestones.html#delete-group-milestone
func (s *GroupMilestonesService) DeleteGroupMilestone(pid interface{}, milestone int, options ...RequestOptionFunc) (*Response, error) {
project, err := parseID(pid)
if err != nil {
return nil, err
}
u := fmt.Sprintf("groups/%s/milestones/%d", PathEscape(project), milestone)

req, err := s.client.NewRequest(http.MethodDelete, u, nil, options)
if err != nil {
return nil, err
}
return s.client.Do(req, nil)
}

// GetGroupMilestoneIssuesOptions represents the available GetGroupMilestoneIssues() options.
//
// GitLab API docs:
Expand Down
24 changes: 24 additions & 0 deletions group_milestones_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -210,6 +210,30 @@ func TestGroupMilestonesService_UpdateGroupMilestone(t *testing.T) {
require.Equal(t, http.StatusNotFound, resp.StatusCode)
}

func TestGroupMilestonesService_DeleteGroupMilestone(t *testing.T) {
mux, client := setup(t)

mux.HandleFunc("/api/v4/groups/5/milestones/12", func(w http.ResponseWriter, r *http.Request) {
testMethod(t, r, http.MethodDelete)
})

resp, err := client.GroupMilestones.DeleteGroupMilestone(5, 12, nil)
require.NoError(t, err)
require.NotNil(t, resp)

resp, err = client.GroupMilestones.DeleteGroupMilestone(5.01, 12, nil)
require.EqualError(t, err, "invalid ID type 5.01, the ID must be an int or a string")
require.Nil(t, resp)

resp, err = client.GroupMilestones.DeleteGroupMilestone(5, 12, nil, errorOption)
require.EqualError(t, err, "RequestOptionFunc returns an error")
require.Nil(t, resp)

resp, err = client.GroupMilestones.DeleteGroupMilestone(3, 12, nil)
require.Error(t, err)
require.Equal(t, http.StatusNotFound, resp.StatusCode)
}

func TestGroupMilestonesService_GetGroupMilestoneIssues(t *testing.T) {
mux, client := setup(t)

Expand Down

0 comments on commit d97e905

Please sign in to comment.