mirror of https://github.com/go-gitea/gitea.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
171 lines
5.9 KiB
171 lines
5.9 KiB
// Copyright 2019 The Gitea Authors. All rights reserved. |
|
// SPDX-License-Identifier: MIT |
|
|
|
package integration |
|
|
|
import ( |
|
"fmt" |
|
"net/http" |
|
"testing" |
|
"time" |
|
|
|
auth_model "code.gitea.io/gitea/models/auth" |
|
issues_model "code.gitea.io/gitea/models/issues" |
|
repo_model "code.gitea.io/gitea/models/repo" |
|
"code.gitea.io/gitea/models/unittest" |
|
user_model "code.gitea.io/gitea/models/user" |
|
api "code.gitea.io/gitea/modules/structs" |
|
"code.gitea.io/gitea/services/convert" |
|
"code.gitea.io/gitea/tests" |
|
|
|
"github.com/stretchr/testify/assert" |
|
) |
|
|
|
func TestAPIIssuesReactions(t *testing.T) { |
|
defer tests.PrepareTestEnv(t)() |
|
|
|
issue := unittest.AssertExistsAndLoadBean(t, &issues_model.Issue{ID: 1}) |
|
_ = issue.LoadRepo(t.Context()) |
|
owner := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: issue.Repo.OwnerID}) |
|
|
|
session := loginUser(t, owner.Name) |
|
token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeWriteIssue) |
|
|
|
user2 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2}) |
|
urlStr := fmt.Sprintf("/api/v1/repos/%s/%s/issues/%d/reactions", owner.Name, issue.Repo.Name, issue.Index) |
|
|
|
// Try to add not allowed reaction |
|
req := NewRequestWithJSON(t, "POST", urlStr, &api.EditReactionOption{ |
|
Reaction: "wrong", |
|
}).AddTokenAuth(token) |
|
MakeRequest(t, req, http.StatusForbidden) |
|
|
|
// Delete not allowed reaction |
|
req = NewRequestWithJSON(t, "DELETE", urlStr, &api.EditReactionOption{ |
|
Reaction: "zzz", |
|
}).AddTokenAuth(token) |
|
MakeRequest(t, req, http.StatusOK) |
|
|
|
// Add allowed reaction |
|
req = NewRequestWithJSON(t, "POST", urlStr, &api.EditReactionOption{ |
|
Reaction: "rocket", |
|
}).AddTokenAuth(token) |
|
resp := MakeRequest(t, req, http.StatusCreated) |
|
var apiNewReaction api.Reaction |
|
DecodeJSON(t, resp, &apiNewReaction) |
|
|
|
// Add existing reaction |
|
MakeRequest(t, req, http.StatusForbidden) |
|
|
|
// Blocked user can't react to comment |
|
user34 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 34}) |
|
req = NewRequestWithJSON(t, "POST", urlStr, &api.EditReactionOption{ |
|
Reaction: "rocket", |
|
}).AddTokenAuth(getUserToken(t, user34.Name, auth_model.AccessTokenScopeWriteIssue)) |
|
MakeRequest(t, req, http.StatusForbidden) |
|
|
|
// Get end result of reaction list of issue #1 |
|
req = NewRequest(t, "GET", urlStr). |
|
AddTokenAuth(token) |
|
resp = MakeRequest(t, req, http.StatusOK) |
|
var apiReactions []*api.Reaction |
|
DecodeJSON(t, resp, &apiReactions) |
|
expectResponse := make(map[int]api.Reaction) |
|
expectResponse[0] = api.Reaction{ |
|
User: convert.ToUser(t.Context(), user2, user2), |
|
Reaction: "eyes", |
|
Created: time.Unix(1573248003, 0), |
|
} |
|
expectResponse[1] = apiNewReaction |
|
assert.Len(t, apiReactions, 2) |
|
for i, r := range apiReactions { |
|
assert.Equal(t, expectResponse[i].Reaction, r.Reaction) |
|
assert.Equal(t, expectResponse[i].Created.Unix(), r.Created.Unix()) |
|
assert.Equal(t, expectResponse[i].User.ID, r.User.ID) |
|
} |
|
} |
|
|
|
func TestAPICommentReactions(t *testing.T) { |
|
defer tests.PrepareTestEnv(t)() |
|
|
|
comment := unittest.AssertExistsAndLoadBean(t, &issues_model.Comment{ID: 2}) |
|
_ = comment.LoadIssue(t.Context()) |
|
issue := comment.Issue |
|
_ = issue.LoadRepo(t.Context()) |
|
owner := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: issue.Repo.OwnerID}) |
|
|
|
session := loginUser(t, owner.Name) |
|
token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeWriteIssue) |
|
|
|
user1 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 1}) |
|
user2 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2}) |
|
urlStr := fmt.Sprintf("/api/v1/repos/%s/%s/issues/comments/%d/reactions", owner.Name, issue.Repo.Name, comment.ID) |
|
|
|
// Try to add not allowed reaction |
|
req := NewRequestWithJSON(t, "POST", urlStr, &api.EditReactionOption{ |
|
Reaction: "wrong", |
|
}).AddTokenAuth(token) |
|
MakeRequest(t, req, http.StatusForbidden) |
|
|
|
// Delete none existing reaction |
|
req = NewRequestWithJSON(t, "DELETE", urlStr, &api.EditReactionOption{ |
|
Reaction: "eyes", |
|
}).AddTokenAuth(token) |
|
MakeRequest(t, req, http.StatusOK) |
|
|
|
t.Run("UnrelatedCommentID", func(t *testing.T) { |
|
// Using the ID of a comment that does not belong to the repository must fail |
|
repo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 4}) |
|
repoOwner := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: repo.OwnerID}) |
|
token := getUserToken(t, repoOwner.Name, auth_model.AccessTokenScopeWriteIssue) |
|
urlStr := fmt.Sprintf("/api/v1/repos/%s/%s/issues/comments/%d/reactions", repoOwner.Name, repo.Name, comment.ID) |
|
req = NewRequestWithJSON(t, "POST", urlStr, &api.EditReactionOption{ |
|
Reaction: "+1", |
|
}).AddTokenAuth(token) |
|
MakeRequest(t, req, http.StatusNotFound) |
|
req = NewRequestWithJSON(t, "DELETE", urlStr, &api.EditReactionOption{ |
|
Reaction: "+1", |
|
}).AddTokenAuth(token) |
|
MakeRequest(t, req, http.StatusNotFound) |
|
|
|
req = NewRequest(t, "GET", urlStr). |
|
AddTokenAuth(token) |
|
MakeRequest(t, req, http.StatusNotFound) |
|
}) |
|
|
|
// Add allowed reaction |
|
req = NewRequestWithJSON(t, "POST", urlStr, &api.EditReactionOption{ |
|
Reaction: "+1", |
|
}).AddTokenAuth(token) |
|
resp := MakeRequest(t, req, http.StatusCreated) |
|
var apiNewReaction api.Reaction |
|
DecodeJSON(t, resp, &apiNewReaction) |
|
|
|
// Add existing reaction |
|
MakeRequest(t, req, http.StatusForbidden) |
|
|
|
// Get end result of reaction list of issue #1 |
|
req = NewRequest(t, "GET", urlStr). |
|
AddTokenAuth(token) |
|
resp = MakeRequest(t, req, http.StatusOK) |
|
var apiReactions []*api.Reaction |
|
DecodeJSON(t, resp, &apiReactions) |
|
expectResponse := make(map[int]api.Reaction) |
|
expectResponse[0] = api.Reaction{ |
|
User: convert.ToUser(t.Context(), user2, user2), |
|
Reaction: "laugh", |
|
Created: time.Unix(1573248004, 0), |
|
} |
|
expectResponse[1] = api.Reaction{ |
|
User: convert.ToUser(t.Context(), user1, user1), |
|
Reaction: "laugh", |
|
Created: time.Unix(1573248005, 0), |
|
} |
|
expectResponse[2] = apiNewReaction |
|
assert.Len(t, apiReactions, 3) |
|
for i, r := range apiReactions { |
|
assert.Equal(t, expectResponse[i].Reaction, r.Reaction) |
|
assert.Equal(t, expectResponse[i].Created.Unix(), r.Created.Unix()) |
|
assert.Equal(t, expectResponse[i].User.ID, r.User.ID) |
|
} |
|
}
|
|
|