2020-04-05 15:20:50 +09:00
|
|
|
// Copyright 2020 The Gitea Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a MIT-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
2018-08-06 13:43:22 +09:00
|
|
|
package models
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
2021-11-12 23:36:47 +09:00
|
|
|
"code.gitea.io/gitea/models/unittest"
|
2018-08-06 13:43:22 +09:00
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestGetReviewByID(t *testing.T) {
|
2021-11-12 23:36:47 +09:00
|
|
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
2018-08-06 13:43:22 +09:00
|
|
|
review, err := GetReviewByID(1)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.Equal(t, "Demo Review", review.Content)
|
|
|
|
assert.Equal(t, ReviewTypeApprove, review.Type)
|
|
|
|
|
|
|
|
_, err = GetReviewByID(23892)
|
|
|
|
assert.Error(t, err)
|
|
|
|
assert.True(t, IsErrReviewNotExist(err), "IsErrReviewNotExist")
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestReview_LoadAttributes(t *testing.T) {
|
2021-11-12 23:36:47 +09:00
|
|
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
2021-11-16 17:53:21 +09:00
|
|
|
review := unittest.AssertExistsAndLoadBean(t, &Review{ID: 1}).(*Review)
|
2018-08-06 13:43:22 +09:00
|
|
|
assert.NoError(t, review.LoadAttributes())
|
|
|
|
assert.NotNil(t, review.Issue)
|
|
|
|
assert.NotNil(t, review.Reviewer)
|
|
|
|
|
2021-11-16 17:53:21 +09:00
|
|
|
invalidReview1 := unittest.AssertExistsAndLoadBean(t, &Review{ID: 2}).(*Review)
|
2018-08-06 13:43:22 +09:00
|
|
|
assert.Error(t, invalidReview1.LoadAttributes())
|
|
|
|
|
2021-11-16 17:53:21 +09:00
|
|
|
invalidReview2 := unittest.AssertExistsAndLoadBean(t, &Review{ID: 3}).(*Review)
|
2018-08-06 13:43:22 +09:00
|
|
|
assert.Error(t, invalidReview2.LoadAttributes())
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestReview_LoadCodeComments(t *testing.T) {
|
2021-11-12 23:36:47 +09:00
|
|
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
2018-08-06 13:43:22 +09:00
|
|
|
|
2021-11-16 17:53:21 +09:00
|
|
|
review := unittest.AssertExistsAndLoadBean(t, &Review{ID: 4}).(*Review)
|
2018-08-06 13:43:22 +09:00
|
|
|
assert.NoError(t, review.LoadAttributes())
|
|
|
|
assert.NoError(t, review.LoadCodeComments())
|
|
|
|
assert.Len(t, review.CodeComments, 1)
|
|
|
|
assert.Equal(t, int64(4), review.CodeComments["README.md"][int64(4)][0].Line)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestReviewType_Icon(t *testing.T) {
|
2020-04-03 14:12:42 +09:00
|
|
|
assert.Equal(t, "check", ReviewTypeApprove.Icon())
|
2020-07-18 00:15:12 +09:00
|
|
|
assert.Equal(t, "diff", ReviewTypeReject.Icon())
|
2018-08-06 13:43:22 +09:00
|
|
|
assert.Equal(t, "comment", ReviewTypeComment.Icon())
|
|
|
|
assert.Equal(t, "comment", ReviewTypeUnknown.Icon())
|
2020-07-18 00:15:12 +09:00
|
|
|
assert.Equal(t, "dot-fill", ReviewTypeRequest.Icon())
|
2020-04-07 01:33:34 +09:00
|
|
|
assert.Equal(t, "comment", ReviewType(6).Icon())
|
2018-08-06 13:43:22 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestFindReviews(t *testing.T) {
|
2021-11-12 23:36:47 +09:00
|
|
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
2018-08-06 13:43:22 +09:00
|
|
|
reviews, err := FindReviews(FindReviewOptions{
|
|
|
|
Type: ReviewTypeApprove,
|
|
|
|
IssueID: 2,
|
|
|
|
ReviewerID: 1,
|
|
|
|
})
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.Len(t, reviews, 1)
|
|
|
|
assert.Equal(t, "Demo Review", reviews[0].Content)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGetCurrentReview(t *testing.T) {
|
2021-11-12 23:36:47 +09:00
|
|
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
2021-11-16 17:53:21 +09:00
|
|
|
issue := unittest.AssertExistsAndLoadBean(t, &Issue{ID: 2}).(*Issue)
|
|
|
|
user := unittest.AssertExistsAndLoadBean(t, &User{ID: 1}).(*User)
|
2018-08-06 13:43:22 +09:00
|
|
|
|
|
|
|
review, err := GetCurrentReview(user, issue)
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.NotNil(t, review)
|
|
|
|
assert.Equal(t, ReviewTypePending, review.Type)
|
|
|
|
assert.Equal(t, "Pending Review", review.Content)
|
|
|
|
|
2021-11-16 17:53:21 +09:00
|
|
|
user2 := unittest.AssertExistsAndLoadBean(t, &User{ID: 7}).(*User)
|
2018-08-06 13:43:22 +09:00
|
|
|
review2, err := GetCurrentReview(user2, issue)
|
|
|
|
assert.Error(t, err)
|
|
|
|
assert.True(t, IsErrReviewNotExist(err))
|
|
|
|
assert.Nil(t, review2)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestCreateReview(t *testing.T) {
|
2021-11-12 23:36:47 +09:00
|
|
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
2018-08-06 13:43:22 +09:00
|
|
|
|
2021-11-16 17:53:21 +09:00
|
|
|
issue := unittest.AssertExistsAndLoadBean(t, &Issue{ID: 2}).(*Issue)
|
|
|
|
user := unittest.AssertExistsAndLoadBean(t, &User{ID: 1}).(*User)
|
2018-08-06 13:43:22 +09:00
|
|
|
|
|
|
|
review, err := CreateReview(CreateReviewOptions{
|
|
|
|
Content: "New Review",
|
|
|
|
Type: ReviewTypePending,
|
|
|
|
Issue: issue,
|
|
|
|
Reviewer: user,
|
|
|
|
})
|
|
|
|
assert.NoError(t, err)
|
|
|
|
assert.Equal(t, "New Review", review.Content)
|
2021-11-16 17:53:21 +09:00
|
|
|
unittest.AssertExistsAndLoadBean(t, &Review{Content: "New Review"})
|
2018-08-06 13:43:22 +09:00
|
|
|
}
|
|
|
|
|
2019-12-04 10:08:56 +09:00
|
|
|
func TestGetReviewersByIssueID(t *testing.T) {
|
2021-11-12 23:36:47 +09:00
|
|
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
2018-11-22 22:17:36 +09:00
|
|
|
|
2021-11-16 17:53:21 +09:00
|
|
|
issue := unittest.AssertExistsAndLoadBean(t, &Issue{ID: 3}).(*Issue)
|
|
|
|
user2 := unittest.AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
|
|
|
|
user3 := unittest.AssertExistsAndLoadBean(t, &User{ID: 3}).(*User)
|
|
|
|
user4 := unittest.AssertExistsAndLoadBean(t, &User{ID: 4}).(*User)
|
2018-11-22 22:17:36 +09:00
|
|
|
|
2019-12-04 10:08:56 +09:00
|
|
|
expectedReviews := []*Review{}
|
|
|
|
expectedReviews = append(expectedReviews,
|
|
|
|
&Review{
|
|
|
|
Reviewer: user3,
|
|
|
|
Type: ReviewTypeReject,
|
|
|
|
UpdatedUnix: 946684812,
|
2018-11-22 22:17:36 +09:00
|
|
|
},
|
2019-12-04 10:08:56 +09:00
|
|
|
&Review{
|
|
|
|
Reviewer: user4,
|
|
|
|
Type: ReviewTypeApprove,
|
|
|
|
UpdatedUnix: 946684813,
|
|
|
|
},
|
|
|
|
&Review{
|
|
|
|
Reviewer: user2,
|
|
|
|
Type: ReviewTypeReject,
|
|
|
|
UpdatedUnix: 946684814,
|
2018-11-22 22:17:36 +09:00
|
|
|
})
|
|
|
|
|
2019-12-04 10:08:56 +09:00
|
|
|
allReviews, err := GetReviewersByIssueID(issue.ID)
|
2020-10-13 04:55:13 +09:00
|
|
|
for _, reviewer := range allReviews {
|
|
|
|
assert.NoError(t, reviewer.LoadReviewer())
|
|
|
|
}
|
2018-11-22 22:17:36 +09:00
|
|
|
assert.NoError(t, err)
|
2020-05-02 09:20:51 +09:00
|
|
|
if assert.Len(t, allReviews, 3) {
|
|
|
|
for i, review := range allReviews {
|
|
|
|
assert.Equal(t, expectedReviews[i].Reviewer, review.Reviewer)
|
|
|
|
assert.Equal(t, expectedReviews[i].Type, review.Type)
|
|
|
|
assert.Equal(t, expectedReviews[i].UpdatedUnix, review.UpdatedUnix)
|
|
|
|
}
|
2019-12-04 10:08:56 +09:00
|
|
|
}
|
2018-11-22 22:17:36 +09:00
|
|
|
}
|
2021-02-12 02:32:25 +09:00
|
|
|
|
|
|
|
func TestDismissReview(t *testing.T) {
|
2021-11-12 23:36:47 +09:00
|
|
|
assert.NoError(t, unittest.PrepareTestDatabase())
|
2021-04-15 19:03:11 +09:00
|
|
|
|
2021-11-16 17:53:21 +09:00
|
|
|
rejectReviewExample := unittest.AssertExistsAndLoadBean(t, &Review{ID: 9}).(*Review)
|
|
|
|
requestReviewExample := unittest.AssertExistsAndLoadBean(t, &Review{ID: 11}).(*Review)
|
|
|
|
approveReviewExample := unittest.AssertExistsAndLoadBean(t, &Review{ID: 8}).(*Review)
|
2021-04-15 19:03:11 +09:00
|
|
|
assert.False(t, rejectReviewExample.Dismissed)
|
|
|
|
assert.False(t, requestReviewExample.Dismissed)
|
|
|
|
assert.False(t, approveReviewExample.Dismissed)
|
|
|
|
|
|
|
|
assert.NoError(t, DismissReview(rejectReviewExample, true))
|
2021-11-16 17:53:21 +09:00
|
|
|
rejectReviewExample = unittest.AssertExistsAndLoadBean(t, &Review{ID: 9}).(*Review)
|
|
|
|
requestReviewExample = unittest.AssertExistsAndLoadBean(t, &Review{ID: 11}).(*Review)
|
2021-04-15 19:03:11 +09:00
|
|
|
assert.True(t, rejectReviewExample.Dismissed)
|
|
|
|
assert.False(t, requestReviewExample.Dismissed)
|
|
|
|
|
|
|
|
assert.NoError(t, DismissReview(requestReviewExample, true))
|
2021-11-16 17:53:21 +09:00
|
|
|
rejectReviewExample = unittest.AssertExistsAndLoadBean(t, &Review{ID: 9}).(*Review)
|
|
|
|
requestReviewExample = unittest.AssertExistsAndLoadBean(t, &Review{ID: 11}).(*Review)
|
2021-04-15 19:03:11 +09:00
|
|
|
assert.True(t, rejectReviewExample.Dismissed)
|
|
|
|
assert.False(t, requestReviewExample.Dismissed)
|
|
|
|
assert.False(t, approveReviewExample.Dismissed)
|
|
|
|
|
|
|
|
assert.NoError(t, DismissReview(requestReviewExample, true))
|
2021-11-16 17:53:21 +09:00
|
|
|
rejectReviewExample = unittest.AssertExistsAndLoadBean(t, &Review{ID: 9}).(*Review)
|
|
|
|
requestReviewExample = unittest.AssertExistsAndLoadBean(t, &Review{ID: 11}).(*Review)
|
2021-04-15 19:03:11 +09:00
|
|
|
assert.True(t, rejectReviewExample.Dismissed)
|
|
|
|
assert.False(t, requestReviewExample.Dismissed)
|
|
|
|
assert.False(t, approveReviewExample.Dismissed)
|
|
|
|
|
|
|
|
assert.NoError(t, DismissReview(requestReviewExample, false))
|
2021-11-16 17:53:21 +09:00
|
|
|
rejectReviewExample = unittest.AssertExistsAndLoadBean(t, &Review{ID: 9}).(*Review)
|
|
|
|
requestReviewExample = unittest.AssertExistsAndLoadBean(t, &Review{ID: 11}).(*Review)
|
2021-04-15 19:03:11 +09:00
|
|
|
assert.True(t, rejectReviewExample.Dismissed)
|
|
|
|
assert.False(t, requestReviewExample.Dismissed)
|
|
|
|
assert.False(t, approveReviewExample.Dismissed)
|
|
|
|
|
|
|
|
assert.NoError(t, DismissReview(requestReviewExample, false))
|
2021-11-16 17:53:21 +09:00
|
|
|
rejectReviewExample = unittest.AssertExistsAndLoadBean(t, &Review{ID: 9}).(*Review)
|
|
|
|
requestReviewExample = unittest.AssertExistsAndLoadBean(t, &Review{ID: 11}).(*Review)
|
2021-04-15 19:03:11 +09:00
|
|
|
assert.True(t, rejectReviewExample.Dismissed)
|
|
|
|
assert.False(t, requestReviewExample.Dismissed)
|
|
|
|
assert.False(t, approveReviewExample.Dismissed)
|
|
|
|
|
|
|
|
assert.NoError(t, DismissReview(rejectReviewExample, false))
|
|
|
|
assert.False(t, rejectReviewExample.Dismissed)
|
|
|
|
assert.False(t, requestReviewExample.Dismissed)
|
|
|
|
assert.False(t, approveReviewExample.Dismissed)
|
|
|
|
|
|
|
|
assert.NoError(t, DismissReview(approveReviewExample, true))
|
|
|
|
assert.False(t, rejectReviewExample.Dismissed)
|
|
|
|
assert.False(t, requestReviewExample.Dismissed)
|
|
|
|
assert.True(t, approveReviewExample.Dismissed)
|
|
|
|
|
2021-02-12 02:32:25 +09:00
|
|
|
}
|