summaryrefslogtreecommitdiffstats
path: root/models/access_test.go
diff options
context:
space:
mode:
authorEthan Koenig <etk39@cornell.edu>2017-01-07 22:10:53 -0500
committerLunny Xiao <xiaolunwen@gmail.com>2017-01-08 11:10:53 +0800
commit6072b032918006824f260e79f96372dd94fbb17f (patch)
tree16e9ee4c0f0550ec55dd2463496649d44e2dfe99 /models/access_test.go
parent8422ab542c69592b4629188d4460ca560307465b (diff)
downloadgitea-6072b032918006824f260e79f96372dd94fbb17f.tar.gz
gitea-6072b032918006824f260e79f96372dd94fbb17f.zip
Unit tests for models/access.go (#606)
Diffstat (limited to 'models/access_test.go')
-rw-r--r--models/access_test.go136
1 files changed, 136 insertions, 0 deletions
diff --git a/models/access_test.go b/models/access_test.go
new file mode 100644
index 0000000000..c9847f0069
--- /dev/null
+++ b/models/access_test.go
@@ -0,0 +1,136 @@
+// 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"
+)
+
+var accessModes = []AccessMode{
+ AccessModeRead,
+ AccessModeWrite,
+ AccessModeAdmin,
+ AccessModeOwner,
+}
+
+func TestAccessLevel(t *testing.T) {
+ assert.NoError(t, PrepareTestDatabase())
+
+ user1 := &User{ID: 2}; LoadTestFixture(t, user1)
+ user2 := &User{ID: 4}; LoadTestFixture(t, user2)
+ repo1 := &Repository{OwnerID: 2, IsPrivate: false}; LoadTestFixture(t, repo1)
+ repo2 := &Repository{OwnerID: 3, IsPrivate: true}; LoadTestFixture(t, repo2)
+
+ level, err := AccessLevel(user1, repo1)
+ assert.NoError(t, err)
+ assert.Equal(t, AccessModeOwner, level)
+
+ level, err = AccessLevel(user1, repo2)
+ assert.NoError(t, err)
+ assert.Equal(t, AccessModeWrite, level)
+
+ level, err = AccessLevel(user2, repo1)
+ assert.NoError(t, err)
+ assert.Equal(t, AccessModeRead, level)
+
+ level, err = AccessLevel(user2, repo2)
+ assert.NoError(t, err)
+ assert.Equal(t, AccessModeNone, level)
+}
+
+func TestHasAccess(t *testing.T) {
+ assert.NoError(t, PrepareTestDatabase())
+
+ user1 := &User{ID: 2}; LoadTestFixture(t, user1)
+ user2 := &User{ID: 4}; LoadTestFixture(t, user2)
+ repo1 := &Repository{OwnerID: 2, IsPrivate: false}; LoadTestFixture(t, repo1)
+ repo2 := &Repository{OwnerID: 3, IsPrivate: true}; LoadTestFixture(t, repo2)
+
+ for _, accessMode := range accessModes {
+ has, err := HasAccess(user1, repo1, accessMode)
+ assert.NoError(t, err)
+ assert.True(t, has)
+
+ has, err = HasAccess(user1, repo2, accessMode)
+ assert.NoError(t, err)
+ assert.Equal(t, accessMode <= AccessModeWrite, has)
+
+ has, err = HasAccess(user2, repo1, accessMode)
+ assert.NoError(t, err)
+ assert.Equal(t, accessMode <= AccessModeRead, has)
+
+ has, err = HasAccess(user2, repo2, accessMode)
+ assert.NoError(t, err)
+ assert.Equal(t, accessMode <= AccessModeNone, has)
+ }
+}
+
+func TestUser_GetRepositoryAccesses(t *testing.T) {
+ assert.NoError(t, PrepareTestDatabase())
+
+ user1 := &User{ID: 1}; LoadTestFixture(t, user1)
+ user2 := &User{ID: 2}; LoadTestFixture(t, user2)
+
+ accesses, err := user1.GetRepositoryAccesses()
+ assert.NoError(t, err)
+ assert.Len(t, accesses, 0)
+}
+
+func TestUser_GetAccessibleRepositories(t *testing.T) {
+ assert.NoError(t, PrepareTestDatabase())
+
+ user1 := &User{ID: 1}; LoadTestFixture(t, user1)
+ user2 := &User{ID: 2}; LoadTestFixture(t, user2)
+
+ repos, err := user1.GetAccessibleRepositories(0)
+ assert.NoError(t, err)
+ assert.Len(t, repos, 0)
+
+ repos, err = user2.GetAccessibleRepositories(0)
+ assert.NoError(t, err)
+ assert.Len(t, repos, 1)
+}
+
+
+func TestRepository_RecalculateAccesses(t *testing.T) {
+ // test with organization repo
+ assert.NoError(t, PrepareTestDatabase())
+ repo1 := &Repository{ID: 3}; LoadTestFixture(t, repo1)
+ assert.NoError(t, repo1.GetOwner())
+
+ sess := x.NewSession()
+ defer sess.Close()
+ _, err := sess.Delete(&Collaboration{UserID: 2, RepoID: 3})
+ assert.NoError(t, err)
+
+ assert.NoError(t, repo1.RecalculateAccesses())
+
+ sess = x.NewSession()
+ access := &Access{UserID: 2, RepoID: 3}
+ has, err := sess.Get(access)
+ assert.NoError(t, err)
+ assert.True(t, has)
+ assert.Equal(t, AccessModeWrite, access.Mode)
+}
+
+func TestRepository_RecalculateAccesses2(t *testing.T) {
+ // test with non-organization repo
+ assert.NoError(t, PrepareTestDatabase())
+ repo1 := &Repository{ID: 4}; LoadTestFixture(t, repo1)
+ assert.NoError(t, repo1.GetOwner())
+
+ sess := x.NewSession()
+ defer sess.Close()
+ _, err := sess.Delete(&Collaboration{UserID: 4, RepoID: 4})
+ assert.NoError(t, err)
+
+ assert.NoError(t, repo1.RecalculateAccesses())
+
+ sess = x.NewSession()
+ has, err := sess.Get(&Access{UserID: 4, RepoID: 4})
+ assert.NoError(t, err)
+ assert.False(t, has)
+}