gitea源码

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206
  1. // Copyright 2017 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package integration
  4. import (
  5. "fmt"
  6. "net/http"
  7. "path"
  8. "testing"
  9. "code.gitea.io/gitea/modules/setting"
  10. api "code.gitea.io/gitea/modules/structs"
  11. "code.gitea.io/gitea/modules/test"
  12. "code.gitea.io/gitea/tests"
  13. "github.com/stretchr/testify/assert"
  14. )
  15. func assertLinkPageComplete(t *testing.T, session *TestSession, link string) {
  16. req := NewRequest(t, "GET", link)
  17. resp := session.MakeRequest(t, req, http.StatusOK)
  18. assert.True(t, test.IsNormalPageCompleted(resp.Body.String()), "Page did not complete: "+link)
  19. }
  20. func TestLinks(t *testing.T) {
  21. defer tests.PrepareTestEnv(t)()
  22. t.Run("NoLogin", testLinksNoLogin)
  23. t.Run("RedirectsNoLogin", testLinksRedirectsNoLogin)
  24. t.Run("NoLoginNotExist", testLinksNoLoginNotExist)
  25. t.Run("AsUser", testLinksAsUser)
  26. t.Run("RepoCommon", testLinksRepoCommon)
  27. }
  28. func testLinksNoLogin(t *testing.T) {
  29. links := []string{
  30. "/",
  31. "/explore/repos",
  32. "/explore/repos?q=test",
  33. "/explore/users",
  34. "/explore/users?q=test",
  35. "/explore/organizations",
  36. "/explore/organizations?q=test",
  37. "/user/sign_up",
  38. "/user/login",
  39. "/user/forgot_password",
  40. "/user2/repo1",
  41. "/user2/repo1/",
  42. "/user2/repo1/projects",
  43. "/user2/repo1/projects/1",
  44. "/user2/repo1/releases/tag/delete-tag", // It's the only one existing record on release.yml which has is_tag: true
  45. "/api/swagger",
  46. }
  47. for _, link := range links {
  48. assertLinkPageComplete(t, nil, link)
  49. }
  50. MakeRequest(t, NewRequest(t, "GET", "/.well-known/security.txt"), http.StatusOK)
  51. }
  52. func testLinksRedirectsNoLogin(t *testing.T) {
  53. redirects := []struct{ from, to string }{
  54. {"/user2/repo1/commits/master", "/user2/repo1/commits/branch/master"},
  55. {"/user2/repo1/src/master", "/user2/repo1/src/branch/master"},
  56. {"/user2/repo1/src/master/a%2fb.txt", "/user2/repo1/src/branch/master/a%2fb.txt"},
  57. {"/user2/repo1/src/master/directory/file.txt?a=1", "/user2/repo1/src/branch/master/directory/file.txt?a=1"},
  58. {"/user2/repo1/src/branch/master/directory/file.txt?raw=1&other=2", "/user2/repo1/raw/branch/master/directory/file.txt"},
  59. {"/user2/repo1/tree/a%2fb?a=1", "/user2/repo1/src/a%2fb?a=1"},
  60. {"/user2/repo1/blob/123456/%20?a=1", "/user2/repo1/src/commit/123456/%20?a=1"},
  61. {"/user/avatar/GhosT/-1", "/assets/img/avatar_default.png"},
  62. {"/user/avatar/Gitea-ActionS/0", "/assets/img/avatar_default.png"},
  63. {"/api/v1/swagger", "/api/swagger"},
  64. }
  65. for _, c := range redirects {
  66. req := NewRequest(t, "GET", c.from)
  67. resp := MakeRequest(t, req, http.StatusSeeOther)
  68. assert.Equal(t, path.Join(setting.AppSubURL, c.to), test.RedirectURL(resp))
  69. }
  70. }
  71. func testLinksNoLoginNotExist(t *testing.T) {
  72. links := []string{
  73. "/user5/repo4/projects",
  74. "/user5/repo4/projects/3",
  75. }
  76. for _, link := range links {
  77. req := NewRequest(t, "GET", link)
  78. MakeRequest(t, req, http.StatusNotFound)
  79. }
  80. }
  81. func testLinksAsUser(t *testing.T) {
  82. session := loginUser(t, "user2")
  83. links := []string{
  84. "/explore/repos",
  85. "/explore/repos?q=test",
  86. "/explore/users",
  87. "/explore/users?q=test",
  88. "/explore/organizations",
  89. "/explore/organizations?q=test",
  90. "/",
  91. "/user/forgot_password",
  92. "/api/swagger",
  93. "/issues",
  94. "/issues?type=your_repositories&repos=[0]&sort=&state=open",
  95. "/issues?type=assigned&repos=[0]&sort=&state=open",
  96. "/issues?type=your_repositories&repos=[0]&sort=&state=closed",
  97. "/issues?type=assigned&repos=[]&sort=&state=closed",
  98. "/issues?type=assigned&sort=&state=open",
  99. "/issues?type=created_by&repos=[1,2]&sort=&state=closed",
  100. "/issues?type=created_by&repos=[1,2]&sort=&state=open",
  101. "/pulls",
  102. "/pulls?type=your_repositories&repos=[2]&sort=&state=open",
  103. "/pulls?type=assigned&repos=[]&sort=&state=open",
  104. "/pulls?type=created_by&repos=[0]&sort=&state=open",
  105. "/pulls?type=your_repositories&repos=[0]&sort=&state=closed",
  106. "/pulls?type=assigned&repos=[0]&sort=&state=closed",
  107. "/pulls?type=created_by&repos=[0]&sort=&state=closed",
  108. "/milestones",
  109. "/milestones?sort=mostcomplete&state=closed",
  110. "/milestones?type=your_repositories&sort=mostcomplete&state=closed",
  111. "/milestones?sort=&repos=[1]&state=closed",
  112. "/milestones?sort=&repos=[1]&state=open",
  113. "/milestones?repos=[0]&sort=mostissues&state=open",
  114. "/notifications",
  115. "/repo/create",
  116. "/repo/migrate",
  117. "/org/create",
  118. "/user2",
  119. "/user2?tab=stars",
  120. "/user2?tab=activity",
  121. "/user/settings",
  122. "/user/settings/account",
  123. "/user/settings/security",
  124. "/user/settings/security/two_factor/enroll",
  125. "/user/settings/keys",
  126. "/user/settings/organization",
  127. "/user/settings/repos",
  128. }
  129. for _, link := range links {
  130. assertLinkPageComplete(t, session, link)
  131. }
  132. reqAPI := NewRequestf(t, "GET", "/api/v1/users/user2/repos")
  133. respAPI := MakeRequest(t, reqAPI, http.StatusOK)
  134. var apiRepos []*api.Repository
  135. DecodeJSON(t, respAPI, &apiRepos)
  136. repoLinks := []string{
  137. "",
  138. "/issues",
  139. "/pulls",
  140. "/commits/branch/master",
  141. "/graph",
  142. "/settings",
  143. "/settings/collaboration",
  144. "/settings/branches",
  145. "/settings/hooks",
  146. // FIXME: below links should return 200 but 404 ??
  147. //"/settings/hooks/git",
  148. //"/settings/hooks/git/pre-receive",
  149. //"/settings/hooks/git/update",
  150. //"/settings/hooks/git/post-receive",
  151. "/settings/keys",
  152. "/releases",
  153. "/releases/new",
  154. //"/wiki/_pages",
  155. "/wiki/?action=_new",
  156. "/activity",
  157. }
  158. for _, repo := range apiRepos {
  159. for _, link := range repoLinks {
  160. link = fmt.Sprintf("/user2/%s%s", repo.Name, link)
  161. assertLinkPageComplete(t, session, link)
  162. }
  163. }
  164. }
  165. func testLinksRepoCommon(t *testing.T) {
  166. // repo1 has enabled almost features, so we can test most links
  167. repoLink := "/user2/repo1"
  168. links := []string{
  169. "/actions",
  170. "/packages",
  171. "/projects",
  172. }
  173. // anonymous user
  174. for _, link := range links {
  175. assertLinkPageComplete(t, nil, repoLink+link)
  176. }
  177. // admin/owner user
  178. session := loginUser(t, "user1")
  179. for _, link := range links {
  180. assertLinkPageComplete(t, session, repoLink+link)
  181. }
  182. // non-admin non-owner user
  183. session = loginUser(t, "user2")
  184. for _, link := range links {
  185. assertLinkPageComplete(t, session, repoLink+link)
  186. }
  187. }