mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-25 11:34:00 +00:00 
			
		
		
		
	* Add 'mark all read' option to notifications Signed-off-by: Sasha Varlamov <sasha@sashavarlamov.com> * Fix exported comment Signed-off-by: Sasha Varlamov <sasha@sashavarlamov.com> * Format method comments Signed-off-by: Sasha Varlamov <sasha@sashavarlamov.com> * Fix exported comment Signed-off-by: Sasha Varlamov <sasha@sashavarlamov.com> Format method comments Signed-off-by: Sasha Varlamov <sasha@sashavarlamov.com> Tests for reactions (#3083) * Unit tests for reactions * Fix import order Signed-off-by: Lauris Bukšis-Haberkorns <lauris@nix.lv> Fix reaction possition when there is attachments (#3099) Refactor notifications swap function * Accept change to drop beforeupdate call * Update purge notifications error message for consistency * Drop unnecessary check for mark all as read button * Remove debugging comment
		
			
				
	
	
		
			102 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			102 lines
		
	
	
		
			3.9 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, 2))
 | |
| 
 | |
| 	// 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, 2) {
 | |
| 		assert.EqualValues(t, 2, 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)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| 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})
 | |
| }
 |