summaryrefslogtreecommitdiffstats
path: root/models
diff options
context:
space:
mode:
authorEthan Koenig <etk39@cornell.edu>2017-01-30 09:21:49 -0500
committerLunny Xiao <xiaolunwen@gmail.com>2017-01-30 22:21:49 +0800
commit2eb15f4a611393a4cbfcd91054f92ade302be62f (patch)
treecbc3c1b448d0fe0ec4db19bae480682559ba2272 /models
parent77ab60df83c5fb60ef8d7c4fe63ac222e3670112 (diff)
downloadgitea-2eb15f4a611393a4cbfcd91054f92ade302be62f.tar.gz
gitea-2eb15f4a611393a4cbfcd91054f92ade302be62f.zip
Unit tests and remove unused functions in models/notification (#796)
* Unit tests and remove unused functions in models/notification * Read -> Unread
Diffstat (limited to 'models')
-rw-r--r--models/fixtures/notification.yml21
-rw-r--r--models/fixtures/watch.yml9
-rw-r--r--models/notification.go10
-rw-r--r--models/notification_test.go77
4 files changed, 107 insertions, 10 deletions
diff --git a/models/fixtures/notification.yml b/models/fixtures/notification.yml
new file mode 100644
index 0000000000..d90936709e
--- /dev/null
+++ b/models/fixtures/notification.yml
@@ -0,0 +1,21 @@
+-
+ id: 1
+ user_id: 1
+ repo_id: 1
+ status: 1 # unread
+ source: 1 # issue
+ updated_by: 2
+ issue_id: 1
+ created_unix: 946684800
+ updated_unix: 946684800
+
+-
+ id: 2
+ user_id: 2
+ repo_id: 1
+ status: 2 # read
+ source: 1 # issue
+ updated_by: 1
+ issue_id: 2
+ created_unix: 946684800
+ updated_unix: 946684800
diff --git a/models/fixtures/watch.yml b/models/fixtures/watch.yml
new file mode 100644
index 0000000000..cd6efb102e
--- /dev/null
+++ b/models/fixtures/watch.yml
@@ -0,0 +1,9 @@
+-
+ id: 1
+ user_id: 1
+ repo_id: 1
+
+-
+ id: 2
+ user_id: 4
+ repo_id: 1
diff --git a/models/notification.go b/models/notification.go
index 6e1a2fbf6c..7ef8f058ce 100644
--- a/models/notification.go
+++ b/models/notification.go
@@ -227,16 +227,6 @@ func (n *Notification) GetIssue() (*Issue, error) {
return n.Issue, err
}
-// GetNotificationReadCount returns the notification read count for user
-func GetNotificationReadCount(user *User) (int64, error) {
- return GetNotificationCount(user, NotificationStatusRead)
-}
-
-// GetNotificationUnreadCount returns the notification unread count for user
-func GetNotificationUnreadCount(user *User) (int64, error) {
- return GetNotificationCount(user, NotificationStatusUnread)
-}
-
// GetNotificationCount returns the notification count for user
func GetNotificationCount(user *User, status NotificationStatus) (int64, error) {
return getNotificationCount(x, user, status)
diff --git a/models/notification_test.go b/models/notification_test.go
new file mode 100644
index 0000000000..dccb478f27
--- /dev/null
+++ b/models/notification_test.go
@@ -0,0 +1,77 @@
+// 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))
+
+ notf := AssertExistsAndLoadBean(t, &Notification{UserID: 1, IssueID: issue.ID}).(*Notification)
+ assert.Equal(t, NotificationStatusUnread, notf.Status)
+ 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)
+ assert.Len(t, notfs, 1)
+ assert.EqualValues(t, 2, notfs[0].ID)
+ assert.EqualValues(t, user.ID, notfs[0].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: 2}).(*User)
+ cnt, err := GetNotificationCount(user, NotificationStatusUnread)
+ assert.NoError(t, err)
+ assert.EqualValues(t, 0, cnt)
+
+ cnt, err = GetNotificationCount(user, NotificationStatusRead)
+ 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))
+}