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 4.8KB

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