aboutsummaryrefslogtreecommitdiffstats
path: root/models/user_follow_test.go
diff options
context:
space:
mode:
authorEthan Koenig <etk39@cornell.edu>2017-03-11 03:46:53 -0500
committerLunny Xiao <xiaolunwen@gmail.com>2017-03-11 16:46:53 +0800
commit3803f257fb5cfa3419f0d91ccbae1c128f0fcca1 (patch)
treef771af0252ae57f9be20ff56952a34aeb9c820ab /models/user_follow_test.go
parent1e3548b7e764c60aad2eb315a65e146264c11a7d (diff)
downloadgitea-3803f257fb5cfa3419f0d91ccbae1c128f0fcca1.tar.gz
gitea-3803f257fb5cfa3419f0d91ccbae1c128f0fcca1.zip
Move user_follow to separate file (#1210)
Also add unit tests
Diffstat (limited to 'models/user_follow_test.go')
-rw-r--r--models/user_follow_test.go45
1 files changed, 45 insertions, 0 deletions
diff --git a/models/user_follow_test.go b/models/user_follow_test.go
new file mode 100644
index 0000000000..59392dcb1d
--- /dev/null
+++ b/models/user_follow_test.go
@@ -0,0 +1,45 @@
+package models
+
+import (
+ "testing"
+
+ "github.com/stretchr/testify/assert"
+)
+
+func TestIsFollowing(t *testing.T) {
+ assert.NoError(t, PrepareTestDatabase())
+ assert.True(t, IsFollowing(4, 2))
+ assert.False(t, IsFollowing(2, 4))
+ assert.False(t, IsFollowing(5, NonexistentID))
+ assert.False(t, IsFollowing(NonexistentID, 5))
+ assert.False(t, IsFollowing(NonexistentID, NonexistentID))
+}
+
+func TestFollowUser(t *testing.T) {
+ assert.NoError(t, PrepareTestDatabase())
+
+ testSuccess := func(followerID, followedID int64) {
+ assert.NoError(t, FollowUser(followerID, followedID))
+ AssertExistsAndLoadBean(t, &Follow{UserID: followerID, FollowID: followedID})
+ }
+ testSuccess(4, 2)
+ testSuccess(5, 2)
+
+ assert.NoError(t, FollowUser(2, 2))
+
+ CheckConsistencyFor(t, &User{})
+}
+
+func TestUnfollowUser(t *testing.T) {
+ assert.NoError(t, PrepareTestDatabase())
+
+ testSuccess := func(followerID, followedID int64) {
+ assert.NoError(t, UnfollowUser(followerID, followedID))
+ AssertNotExistsBean(t, &Follow{UserID: followerID, FollowID: followedID})
+ }
+ testSuccess(4, 2)
+ testSuccess(5, 2)
+ testSuccess(2, 2)
+
+ CheckConsistencyFor(t, &User{})
+}