You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

access_test.go 5.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. // Copyright 2017 The Gitea Authors. All rights reserved.
  2. // Use of this source code is governed by a MIT-style
  3. // license that can be found in the LICENSE file.
  4. package models
  5. import (
  6. "testing"
  7. "code.gitea.io/gitea/models/db"
  8. "code.gitea.io/gitea/models/unittest"
  9. "github.com/stretchr/testify/assert"
  10. )
  11. func TestAccessLevel(t *testing.T) {
  12. assert.NoError(t, unittest.PrepareTestDatabase())
  13. user2 := db.AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
  14. user5 := db.AssertExistsAndLoadBean(t, &User{ID: 5}).(*User)
  15. user29 := db.AssertExistsAndLoadBean(t, &User{ID: 29}).(*User)
  16. // A public repository owned by User 2
  17. repo1 := db.AssertExistsAndLoadBean(t, &Repository{ID: 1}).(*Repository)
  18. assert.False(t, repo1.IsPrivate)
  19. // A private repository owned by Org 3
  20. repo3 := db.AssertExistsAndLoadBean(t, &Repository{ID: 3}).(*Repository)
  21. assert.True(t, repo3.IsPrivate)
  22. // Another public repository
  23. repo4 := db.AssertExistsAndLoadBean(t, &Repository{ID: 4}).(*Repository)
  24. assert.False(t, repo4.IsPrivate)
  25. // org. owned private repo
  26. repo24 := db.AssertExistsAndLoadBean(t, &Repository{ID: 24}).(*Repository)
  27. level, err := AccessLevel(user2, repo1)
  28. assert.NoError(t, err)
  29. assert.Equal(t, AccessModeOwner, level)
  30. level, err = AccessLevel(user2, repo3)
  31. assert.NoError(t, err)
  32. assert.Equal(t, AccessModeOwner, level)
  33. level, err = AccessLevel(user5, repo1)
  34. assert.NoError(t, err)
  35. assert.Equal(t, AccessModeRead, level)
  36. level, err = AccessLevel(user5, repo3)
  37. assert.NoError(t, err)
  38. assert.Equal(t, AccessModeNone, level)
  39. // restricted user has no access to a public repo
  40. level, err = AccessLevel(user29, repo1)
  41. assert.NoError(t, err)
  42. assert.Equal(t, AccessModeNone, level)
  43. // ... unless he's a collaborator
  44. level, err = AccessLevel(user29, repo4)
  45. assert.NoError(t, err)
  46. assert.Equal(t, AccessModeWrite, level)
  47. // ... or a team member
  48. level, err = AccessLevel(user29, repo24)
  49. assert.NoError(t, err)
  50. assert.Equal(t, AccessModeRead, level)
  51. }
  52. func TestHasAccess(t *testing.T) {
  53. assert.NoError(t, unittest.PrepareTestDatabase())
  54. user1 := db.AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
  55. user2 := db.AssertExistsAndLoadBean(t, &User{ID: 5}).(*User)
  56. // A public repository owned by User 2
  57. repo1 := db.AssertExistsAndLoadBean(t, &Repository{ID: 1}).(*Repository)
  58. assert.False(t, repo1.IsPrivate)
  59. // A private repository owned by Org 3
  60. repo2 := db.AssertExistsAndLoadBean(t, &Repository{ID: 3}).(*Repository)
  61. assert.True(t, repo2.IsPrivate)
  62. has, err := HasAccess(user1.ID, repo1)
  63. assert.NoError(t, err)
  64. assert.True(t, has)
  65. _, err = HasAccess(user1.ID, repo2)
  66. assert.NoError(t, err)
  67. _, err = HasAccess(user2.ID, repo1)
  68. assert.NoError(t, err)
  69. _, err = HasAccess(user2.ID, repo2)
  70. assert.NoError(t, err)
  71. }
  72. func TestUser_GetRepositoryAccesses(t *testing.T) {
  73. assert.NoError(t, unittest.PrepareTestDatabase())
  74. user1 := db.AssertExistsAndLoadBean(t, &User{ID: 1}).(*User)
  75. accesses, err := user1.GetRepositoryAccesses()
  76. assert.NoError(t, err)
  77. assert.Len(t, accesses, 0)
  78. user29 := db.AssertExistsAndLoadBean(t, &User{ID: 29}).(*User)
  79. accesses, err = user29.GetRepositoryAccesses()
  80. assert.NoError(t, err)
  81. assert.Len(t, accesses, 2)
  82. }
  83. func TestUser_GetAccessibleRepositories(t *testing.T) {
  84. assert.NoError(t, unittest.PrepareTestDatabase())
  85. user1 := db.AssertExistsAndLoadBean(t, &User{ID: 1}).(*User)
  86. repos, err := user1.GetAccessibleRepositories(0)
  87. assert.NoError(t, err)
  88. assert.Len(t, repos, 0)
  89. user2 := db.AssertExistsAndLoadBean(t, &User{ID: 2}).(*User)
  90. repos, err = user2.GetAccessibleRepositories(0)
  91. assert.NoError(t, err)
  92. assert.Len(t, repos, 4)
  93. user29 := db.AssertExistsAndLoadBean(t, &User{ID: 29}).(*User)
  94. repos, err = user29.GetAccessibleRepositories(0)
  95. assert.NoError(t, err)
  96. assert.Len(t, repos, 2)
  97. }
  98. func TestRepository_RecalculateAccesses(t *testing.T) {
  99. // test with organization repo
  100. assert.NoError(t, unittest.PrepareTestDatabase())
  101. repo1 := db.AssertExistsAndLoadBean(t, &Repository{ID: 3}).(*Repository)
  102. assert.NoError(t, repo1.GetOwner())
  103. _, err := db.GetEngine(db.DefaultContext).Delete(&Collaboration{UserID: 2, RepoID: 3})
  104. assert.NoError(t, err)
  105. assert.NoError(t, repo1.RecalculateAccesses())
  106. access := &Access{UserID: 2, RepoID: 3}
  107. has, err := db.GetEngine(db.DefaultContext).Get(access)
  108. assert.NoError(t, err)
  109. assert.True(t, has)
  110. assert.Equal(t, AccessModeOwner, access.Mode)
  111. }
  112. func TestRepository_RecalculateAccesses2(t *testing.T) {
  113. // test with non-organization repo
  114. assert.NoError(t, unittest.PrepareTestDatabase())
  115. repo1 := db.AssertExistsAndLoadBean(t, &Repository{ID: 4}).(*Repository)
  116. assert.NoError(t, repo1.GetOwner())
  117. _, err := db.GetEngine(db.DefaultContext).Delete(&Collaboration{UserID: 4, RepoID: 4})
  118. assert.NoError(t, err)
  119. assert.NoError(t, repo1.RecalculateAccesses())
  120. has, err := db.GetEngine(db.DefaultContext).Get(&Access{UserID: 4, RepoID: 4})
  121. assert.NoError(t, err)
  122. assert.False(t, has)
  123. }
  124. func TestRepository_RecalculateAccesses3(t *testing.T) {
  125. assert.NoError(t, unittest.PrepareTestDatabase())
  126. team5 := db.AssertExistsAndLoadBean(t, &Team{ID: 5}).(*Team)
  127. user29 := db.AssertExistsAndLoadBean(t, &User{ID: 29}).(*User)
  128. has, err := db.GetEngine(db.DefaultContext).Get(&Access{UserID: 29, RepoID: 23})
  129. assert.NoError(t, err)
  130. assert.False(t, has)
  131. // adding user29 to team5 should add an explicit access row for repo 23
  132. // even though repo 23 is public
  133. assert.NoError(t, AddTeamMember(team5, user29.ID))
  134. has, err = db.GetEngine(db.DefaultContext).Get(&Access{UserID: 29, RepoID: 23})
  135. assert.NoError(t, err)
  136. assert.True(t, has)
  137. }