diff options
Diffstat (limited to 'models')
-rw-r--r-- | models/fixtures/review.yml | 40 | ||||
-rw-r--r-- | models/review.go | 33 | ||||
-rw-r--r-- | models/review_test.go | 32 |
3 files changed, 104 insertions, 1 deletions
diff --git a/models/fixtures/review.yml b/models/fixtures/review.yml index 17defd1b3a..515f0d77f8 100644 --- a/models/fixtures/review.yml +++ b/models/fixtures/review.yml @@ -30,3 +30,43 @@ content: "Pending Review" updated_unix: 946684810 created_unix: 946684810 +- + id: 5 + type: 2 + reviewer_id: 1 + issue_id: 3 + content: "New review 1" + updated_unix: 946684810 + created_unix: 946684810 +- + id: 6 + type: 0 + reviewer_id: 2 + issue_id: 3 + content: "New review 3" + updated_unix: 946684810 + created_unix: 946684810 +- + id: 7 + type: 3 + reviewer_id: 3 + issue_id: 3 + content: "New review 4" + updated_unix: 946684810 + created_unix: 946684810 +- + id: 8 + type: 1 + reviewer_id: 4 + issue_id: 3 + content: "New review 5" + updated_unix: 946684810 + created_unix: 946684810 +- + id: 9 + type: 3 + reviewer_id: 2 + issue_id: 3 + content: "New review 3 rejected" + updated_unix: 946684810 + created_unix: 946684810 diff --git a/models/review.go b/models/review.go index f58d3f90cb..7eabb93746 100644 --- a/models/review.go +++ b/models/review.go @@ -255,3 +255,36 @@ func UpdateReview(r *Review) error { } return nil } + +// PullReviewersWithType represents the type used to display a review overview +type PullReviewersWithType struct { + User `xorm:"extends"` + Type ReviewType + ReviewUpdatedUnix util.TimeStamp `xorm:"review_updated_unix"` +} + +// GetReviewersByPullID gets all reviewers for a pull request with the statuses +func GetReviewersByPullID(pullID int64) (issueReviewers []*PullReviewersWithType, err error) { + irs := []*PullReviewersWithType{} + err = x.Select("`user`.*, review.type, max(review.updated_unix) as review_updated_unix"). + Table("review"). + Join("INNER", "`user`", "review.reviewer_id = `user`.id"). + Where("review.issue_id = ? AND (review.type = ? OR review.type = ?)", pullID, ReviewTypeApprove, ReviewTypeReject). + GroupBy("`user`.id, review.type"). + OrderBy("review_updated_unix DESC"). + Find(&irs) + + // We need to group our results by user id _and_ review type, otherwise the query fails when using postgresql. + // But becaus we're doing this, we need to manually filter out multiple reviews of different types by the + // same person because we only want to show the newest review grouped by user. Thats why we're using a map here. + issueReviewers = []*PullReviewersWithType{} + usersInArray := make(map[int64]bool) + for _, ir := range irs { + if !usersInArray[ir.ID] { + issueReviewers = append(issueReviewers, ir) + usersInArray[ir.ID] = true + } + } + + return +} diff --git a/models/review_test.go b/models/review_test.go index 3c0444e7a3..f8e8086dca 100644 --- a/models/review_test.go +++ b/models/review_test.go @@ -74,7 +74,7 @@ func TestGetCurrentReview(t *testing.T) { assert.Equal(t, ReviewTypePending, review.Type) assert.Equal(t, "Pending Review", review.Content) - user2 := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User) + user2 := AssertExistsAndLoadBean(t, &User{ID: 7}).(*User) review2, err := GetCurrentReview(user2, issue) assert.Error(t, err) assert.True(t, IsErrReviewNotExist(err)) @@ -105,3 +105,33 @@ func TestUpdateReview(t *testing.T) { assert.NoError(t, UpdateReview(review)) AssertExistsAndLoadBean(t, &Review{ID: 1, Content: "Updated Review"}) } + +func TestGetReviewersByPullID(t *testing.T) { + assert.NoError(t, PrepareTestDatabase()) + + issue := AssertExistsAndLoadBean(t, &Issue{ID: 3}).(*Issue) + user2 := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User) + user3 := AssertExistsAndLoadBean(t, &User{ID: 3}).(*User) + user4 := AssertExistsAndLoadBean(t, &User{ID: 4}).(*User) + + expectedReviews := []*PullReviewersWithType{} + expectedReviews = append(expectedReviews, &PullReviewersWithType{ + User: *user2, + Type: ReviewTypeReject, + ReviewUpdatedUnix: 946684810, + }, + &PullReviewersWithType{ + User: *user3, + Type: ReviewTypeReject, + ReviewUpdatedUnix: 946684810, + }, + &PullReviewersWithType{ + User: *user4, + Type: ReviewTypeApprove, + ReviewUpdatedUnix: 946684810, + }) + + allReviews, err := GetReviewersByPullID(issue.ID) + assert.NoError(t, err) + assert.Equal(t, expectedReviews, allReviews) +} |