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.4KB

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