mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-26 20:11:02 +00:00 
			
		
		
		
	* 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})
 | |
| }
 |