mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2024-12-25 08:54:17 -05:00
ef89e75d0e
* add request review feature in pull request add a way to notify specific reviewers to review like github , by add or delet a special type review . The acton is is similar to Assign , so many code reuse the function and items of Assignee, but the meaning and result is different. The Permission style is is similar to github, that only writer can add a review request from Reviewers, but the poster can recall and remove a review request after a reviwer has revied even if he don't have Write Premission. only manager , the poster and reviewer of a request review can remove it. The reviewers can be requested to review contain all readers for private repo , for public, contain all writers and watchers. The offical Review Request will block merge if Reject can block it. an other change: add ui otify for Assignees. Co-authored-by: guillep2k <18600385+guillep2k@users.noreply.github.com> Co-authored-by: Lauris BH <lauris@nix.lv> Signed-off-by: a1012112796 <1012112796@qq.com> * new change * add placeholder string * do some changes follow #10238 to add review requests num on lists also change icon for review requests to eye Co-authored-by: Lauris BH <lauris@nix.lv>
103 lines
4 KiB
Go
103 lines
4 KiB
Go
// Copyright 2017 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.
|
|
|
|
package models
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestCreateOrUpdateIssueNotifications(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
issue := AssertExistsAndLoadBean(t, &Issue{ID: 1}).(*Issue)
|
|
|
|
assert.NoError(t, CreateOrUpdateIssueNotifications(issue.ID, 0, 2, 0))
|
|
|
|
// User 9 is inactive, thus notifications for user 1 and 4 are created
|
|
notf := AssertExistsAndLoadBean(t, &Notification{UserID: 1, IssueID: issue.ID}).(*Notification)
|
|
assert.Equal(t, NotificationStatusUnread, notf.Status)
|
|
CheckConsistencyFor(t, &Issue{ID: issue.ID})
|
|
|
|
notf = AssertExistsAndLoadBean(t, &Notification{UserID: 4, IssueID: issue.ID}).(*Notification)
|
|
assert.Equal(t, NotificationStatusUnread, notf.Status)
|
|
}
|
|
|
|
func TestNotificationsForUser(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
user := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
|
|
statuses := []NotificationStatus{NotificationStatusRead, NotificationStatusUnread}
|
|
notfs, err := NotificationsForUser(user, statuses, 1, 10)
|
|
assert.NoError(t, err)
|
|
if assert.Len(t, notfs, 3) {
|
|
assert.EqualValues(t, 5, notfs[0].ID)
|
|
assert.EqualValues(t, user.ID, notfs[0].UserID)
|
|
assert.EqualValues(t, 4, notfs[1].ID)
|
|
assert.EqualValues(t, user.ID, notfs[1].UserID)
|
|
assert.EqualValues(t, 2, notfs[2].ID)
|
|
assert.EqualValues(t, user.ID, notfs[2].UserID)
|
|
}
|
|
}
|
|
|
|
func TestNotification_GetRepo(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
notf := AssertExistsAndLoadBean(t, &Notification{RepoID: 1}).(*Notification)
|
|
repo, err := notf.GetRepo()
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, repo, notf.Repository)
|
|
assert.EqualValues(t, notf.RepoID, repo.ID)
|
|
}
|
|
|
|
func TestNotification_GetIssue(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
notf := AssertExistsAndLoadBean(t, &Notification{RepoID: 1}).(*Notification)
|
|
issue, err := notf.GetIssue()
|
|
assert.NoError(t, err)
|
|
assert.Equal(t, issue, notf.Issue)
|
|
assert.EqualValues(t, notf.IssueID, issue.ID)
|
|
}
|
|
|
|
func TestGetNotificationCount(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
user := AssertExistsAndLoadBean(t, &User{ID: 1}).(*User)
|
|
cnt, err := GetNotificationCount(user, NotificationStatusRead)
|
|
assert.NoError(t, err)
|
|
assert.EqualValues(t, 0, cnt)
|
|
|
|
cnt, err = GetNotificationCount(user, NotificationStatusUnread)
|
|
assert.NoError(t, err)
|
|
assert.EqualValues(t, 1, cnt)
|
|
}
|
|
|
|
func TestSetNotificationStatus(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
user := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
|
|
notf := AssertExistsAndLoadBean(t,
|
|
&Notification{UserID: user.ID, Status: NotificationStatusRead}).(*Notification)
|
|
assert.NoError(t, SetNotificationStatus(notf.ID, user, NotificationStatusPinned))
|
|
AssertExistsAndLoadBean(t,
|
|
&Notification{ID: notf.ID, Status: NotificationStatusPinned})
|
|
|
|
assert.Error(t, SetNotificationStatus(1, user, NotificationStatusRead))
|
|
assert.Error(t, SetNotificationStatus(NonexistentID, user, NotificationStatusRead))
|
|
}
|
|
|
|
func TestUpdateNotificationStatuses(t *testing.T) {
|
|
assert.NoError(t, PrepareTestDatabase())
|
|
user := AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
|
|
notfUnread := AssertExistsAndLoadBean(t,
|
|
&Notification{UserID: user.ID, Status: NotificationStatusUnread}).(*Notification)
|
|
notfRead := AssertExistsAndLoadBean(t,
|
|
&Notification{UserID: user.ID, Status: NotificationStatusRead}).(*Notification)
|
|
notfPinned := AssertExistsAndLoadBean(t,
|
|
&Notification{UserID: user.ID, Status: NotificationStatusPinned}).(*Notification)
|
|
assert.NoError(t, UpdateNotificationStatuses(user, NotificationStatusUnread, NotificationStatusRead))
|
|
AssertExistsAndLoadBean(t,
|
|
&Notification{ID: notfUnread.ID, Status: NotificationStatusRead})
|
|
AssertExistsAndLoadBean(t,
|
|
&Notification{ID: notfRead.ID, Status: NotificationStatusRead})
|
|
AssertExistsAndLoadBean(t,
|
|
&Notification{ID: notfPinned.ID, Status: NotificationStatusPinned})
|
|
}
|