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

api_repo_test.go 6.2 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192
  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 integrations
  5. import (
  6. "fmt"
  7. "net/http"
  8. "testing"
  9. "code.gitea.io/gitea/models"
  10. api "code.gitea.io/sdk/gitea"
  11. "github.com/stretchr/testify/assert"
  12. )
  13. func TestAPIUserReposNotLogin(t *testing.T) {
  14. prepareTestEnv(t)
  15. user := models.AssertExistsAndLoadBean(t, &models.User{ID: 2}).(*models.User)
  16. req := NewRequestf(t, "GET", "/api/v1/users/%s/repos", user.Name)
  17. resp := MakeRequest(t, req, http.StatusOK)
  18. var apiRepos []api.Repository
  19. DecodeJSON(t, resp, &apiRepos)
  20. expectedLen := models.GetCount(t, models.Repository{OwnerID: user.ID},
  21. models.Cond("is_private = ?", false))
  22. assert.Len(t, apiRepos, expectedLen)
  23. for _, repo := range apiRepos {
  24. assert.EqualValues(t, user.ID, repo.Owner.ID)
  25. assert.False(t, repo.Private)
  26. }
  27. }
  28. func TestAPISearchRepo(t *testing.T) {
  29. prepareTestEnv(t)
  30. const keyword = "test"
  31. req := NewRequestf(t, "GET", "/api/v1/repos/search?q=%s", keyword)
  32. resp := MakeRequest(t, req, http.StatusOK)
  33. var body api.SearchResults
  34. DecodeJSON(t, resp, &body)
  35. assert.NotEmpty(t, body.Data)
  36. for _, repo := range body.Data {
  37. assert.Contains(t, repo.Name, keyword)
  38. assert.False(t, repo.Private)
  39. }
  40. user := models.AssertExistsAndLoadBean(t, &models.User{ID: 15}).(*models.User)
  41. user2 := models.AssertExistsAndLoadBean(t, &models.User{ID: 16}).(*models.User)
  42. user3 := models.AssertExistsAndLoadBean(t, &models.User{ID: 18}).(*models.User)
  43. orgUser := models.AssertExistsAndLoadBean(t, &models.User{ID: 17}).(*models.User)
  44. // Map of expected results, where key is user for login
  45. type expectedResults map[*models.User]struct {
  46. count int
  47. repoOwnerID int64
  48. repoName string
  49. includesPrivate bool
  50. }
  51. testCases := []struct {
  52. name, requestURL string
  53. expectedResults
  54. }{
  55. {name: "RepositoriesMax50", requestURL: "/api/v1/repos/search?limit=50", expectedResults: expectedResults{
  56. nil: {count: 12},
  57. user: {count: 12},
  58. user2: {count: 12}},
  59. },
  60. {name: "RepositoriesMax10", requestURL: "/api/v1/repos/search?limit=10", expectedResults: expectedResults{
  61. nil: {count: 10},
  62. user: {count: 10},
  63. user2: {count: 10}},
  64. },
  65. {name: "RepositoriesDefaultMax10", requestURL: "/api/v1/repos/search", expectedResults: expectedResults{
  66. nil: {count: 10},
  67. user: {count: 10},
  68. user2: {count: 10}},
  69. },
  70. {name: "RepositoriesByName", requestURL: fmt.Sprintf("/api/v1/repos/search?q=%s", "big_test_"), expectedResults: expectedResults{
  71. nil: {count: 4, repoName: "big_test_"},
  72. user: {count: 4, repoName: "big_test_"},
  73. user2: {count: 4, repoName: "big_test_"}},
  74. },
  75. {name: "RepositoriesAccessibleAndRelatedToUser", requestURL: fmt.Sprintf("/api/v1/repos/search?uid=%d", user.ID), expectedResults: expectedResults{
  76. nil: {count: 4},
  77. user: {count: 8, includesPrivate: true},
  78. user2: {count: 4}},
  79. },
  80. {name: "RepositoriesAccessibleAndRelatedToUser2", requestURL: fmt.Sprintf("/api/v1/repos/search?uid=%d", user2.ID), expectedResults: expectedResults{
  81. nil: {count: 1},
  82. user: {count: 1},
  83. user2: {count: 2, includesPrivate: true}},
  84. },
  85. {name: "RepositoriesAccessibleAndRelatedToUser3", requestURL: fmt.Sprintf("/api/v1/repos/search?uid=%d", user3.ID), expectedResults: expectedResults{
  86. nil: {count: 1},
  87. user: {count: 1},
  88. user2: {count: 1},
  89. user3: {count: 4, includesPrivate: true}},
  90. },
  91. {name: "RepositoriesOwnedByOrganization", requestURL: fmt.Sprintf("/api/v1/repos/search?uid=%d", orgUser.ID), expectedResults: expectedResults{
  92. nil: {count: 1, repoOwnerID: orgUser.ID},
  93. user: {count: 2, repoOwnerID: orgUser.ID, includesPrivate: true},
  94. user2: {count: 1, repoOwnerID: orgUser.ID}},
  95. },
  96. }
  97. for _, testCase := range testCases {
  98. t.Run(testCase.name, func(t *testing.T) {
  99. for userToLogin, expected := range testCase.expectedResults {
  100. var session *TestSession
  101. var testName string
  102. if userToLogin != nil && userToLogin.ID > 0 {
  103. testName = fmt.Sprintf("LoggedUser%d", userToLogin.ID)
  104. session = loginUser(t, userToLogin.Name)
  105. } else {
  106. testName = "AnonymousUser"
  107. session = emptyTestSession(t)
  108. }
  109. t.Run(testName, func(t *testing.T) {
  110. request := NewRequest(t, "GET", testCase.requestURL)
  111. response := session.MakeRequest(t, request, http.StatusOK)
  112. var body api.SearchResults
  113. DecodeJSON(t, response, &body)
  114. assert.Len(t, body.Data, expected.count)
  115. for _, repo := range body.Data {
  116. assert.NotEmpty(t, repo.Name)
  117. if len(expected.repoName) > 0 {
  118. assert.Contains(t, repo.Name, expected.repoName)
  119. }
  120. if expected.repoOwnerID > 0 {
  121. assert.Equal(t, expected.repoOwnerID, repo.Owner.ID)
  122. }
  123. if !expected.includesPrivate {
  124. assert.False(t, repo.Private)
  125. }
  126. }
  127. })
  128. }
  129. })
  130. }
  131. }
  132. func TestAPIViewRepo(t *testing.T) {
  133. prepareTestEnv(t)
  134. req := NewRequest(t, "GET", "/api/v1/repos/user2/repo1")
  135. resp := MakeRequest(t, req, http.StatusOK)
  136. var repo api.Repository
  137. DecodeJSON(t, resp, &repo)
  138. assert.EqualValues(t, 1, repo.ID)
  139. assert.EqualValues(t, "repo1", repo.Name)
  140. }
  141. func TestAPIOrgRepos(t *testing.T) {
  142. prepareTestEnv(t)
  143. user := models.AssertExistsAndLoadBean(t, &models.User{ID: 2}).(*models.User)
  144. // User3 is an Org. Check their repos.
  145. sourceOrg := models.AssertExistsAndLoadBean(t, &models.User{ID: 3}).(*models.User)
  146. // Login as User2.
  147. session := loginUser(t, user.Name)
  148. req := NewRequestf(t, "GET", "/api/v1/orgs/%s/repos", sourceOrg.Name)
  149. resp := session.MakeRequest(t, req, http.StatusOK)
  150. var apiRepos []*api.Repository
  151. DecodeJSON(t, resp, &apiRepos)
  152. expectedLen := models.GetCount(t, models.Repository{OwnerID: sourceOrg.ID},
  153. models.Cond("is_private = ?", false))
  154. assert.Len(t, apiRepos, expectedLen)
  155. for _, repo := range apiRepos {
  156. assert.False(t, repo.Private)
  157. }
  158. }
  159. func TestAPIGetRepoByIDUnauthorized(t *testing.T) {
  160. prepareTestEnv(t)
  161. user := models.AssertExistsAndLoadBean(t, &models.User{ID: 4}).(*models.User)
  162. sess := loginUser(t, user.Name)
  163. req := NewRequestf(t, "GET", "/api/v1/repositories/2")
  164. sess.MakeRequest(t, req, http.StatusNotFound)
  165. }