Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

api_repo_git_commits_test.go 9.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233
  1. // Copyright 2019 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package integration
  4. import (
  5. "net/http"
  6. "testing"
  7. auth_model "code.gitea.io/gitea/models/auth"
  8. "code.gitea.io/gitea/models/unittest"
  9. user_model "code.gitea.io/gitea/models/user"
  10. api "code.gitea.io/gitea/modules/structs"
  11. "code.gitea.io/gitea/tests"
  12. "github.com/stretchr/testify/assert"
  13. )
  14. func compareCommitFiles(t *testing.T, expect []string, files []*api.CommitAffectedFiles) {
  15. var actual []string
  16. for i := range files {
  17. actual = append(actual, files[i].Filename)
  18. }
  19. assert.ElementsMatch(t, expect, actual)
  20. }
  21. func TestAPIReposGitCommits(t *testing.T) {
  22. defer tests.PrepareTestEnv(t)()
  23. user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
  24. // Login as User2.
  25. session := loginUser(t, user.Name)
  26. token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeReadRepository)
  27. // check invalid requests
  28. req := NewRequestf(t, "GET", "/api/v1/repos/%s/repo1/git/commits/12345", user.Name).
  29. AddTokenAuth(token)
  30. MakeRequest(t, req, http.StatusNotFound)
  31. req = NewRequestf(t, "GET", "/api/v1/repos/%s/repo1/git/commits/..", user.Name).
  32. AddTokenAuth(token)
  33. MakeRequest(t, req, http.StatusUnprocessableEntity)
  34. req = NewRequestf(t, "GET", "/api/v1/repos/%s/repo1/git/commits/branch-not-exist", user.Name).
  35. AddTokenAuth(token)
  36. MakeRequest(t, req, http.StatusNotFound)
  37. for _, ref := range [...]string{
  38. "master", // Branch
  39. "v1.1", // Tag
  40. "65f1", // short sha
  41. "65f1bf27bc3bf70f64657658635e66094edbcb4d", // full sha
  42. } {
  43. req := NewRequestf(t, "GET", "/api/v1/repos/%s/repo1/git/commits/%s", user.Name, ref).
  44. AddTokenAuth(token)
  45. MakeRequest(t, req, http.StatusOK)
  46. }
  47. }
  48. func TestAPIReposGitCommitList(t *testing.T) {
  49. defer tests.PrepareTestEnv(t)()
  50. user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
  51. // Login as User2.
  52. session := loginUser(t, user.Name)
  53. token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeReadRepository)
  54. // Test getting commits (Page 1)
  55. req := NewRequestf(t, "GET", "/api/v1/repos/%s/repo20/commits?not=master&sha=remove-files-a", user.Name).
  56. AddTokenAuth(token)
  57. resp := MakeRequest(t, req, http.StatusOK)
  58. var apiData []api.Commit
  59. DecodeJSON(t, resp, &apiData)
  60. assert.Len(t, apiData, 2)
  61. assert.EqualValues(t, "cfe3b3c1fd36fba04f9183287b106497e1afe986", apiData[0].CommitMeta.SHA)
  62. compareCommitFiles(t, []string{"link_hi", "test.csv"}, apiData[0].Files)
  63. assert.EqualValues(t, "c8e31bc7688741a5287fcde4fbb8fc129ca07027", apiData[1].CommitMeta.SHA)
  64. compareCommitFiles(t, []string{"test.csv"}, apiData[1].Files)
  65. assert.EqualValues(t, resp.Header().Get("X-Total"), "2")
  66. }
  67. func TestAPIReposGitCommitListNotMaster(t *testing.T) {
  68. defer tests.PrepareTestEnv(t)()
  69. user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
  70. // Login as User2.
  71. session := loginUser(t, user.Name)
  72. token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeReadRepository)
  73. // Test getting commits (Page 1)
  74. req := NewRequestf(t, "GET", "/api/v1/repos/%s/repo16/commits", user.Name).
  75. AddTokenAuth(token)
  76. resp := MakeRequest(t, req, http.StatusOK)
  77. var apiData []api.Commit
  78. DecodeJSON(t, resp, &apiData)
  79. assert.Len(t, apiData, 3)
  80. assert.EqualValues(t, "69554a64c1e6030f051e5c3f94bfbd773cd6a324", apiData[0].CommitMeta.SHA)
  81. compareCommitFiles(t, []string{"readme.md"}, apiData[0].Files)
  82. assert.EqualValues(t, "27566bd5738fc8b4e3fef3c5e72cce608537bd95", apiData[1].CommitMeta.SHA)
  83. compareCommitFiles(t, []string{"readme.md"}, apiData[1].Files)
  84. assert.EqualValues(t, "5099b81332712fe655e34e8dd63574f503f61811", apiData[2].CommitMeta.SHA)
  85. compareCommitFiles(t, []string{"readme.md"}, apiData[2].Files)
  86. assert.EqualValues(t, resp.Header().Get("X-Total"), "3")
  87. }
  88. func TestAPIReposGitCommitListPage2Empty(t *testing.T) {
  89. defer tests.PrepareTestEnv(t)()
  90. user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
  91. // Login as User2.
  92. session := loginUser(t, user.Name)
  93. token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeReadRepository)
  94. // Test getting commits (Page=2)
  95. req := NewRequestf(t, "GET", "/api/v1/repos/%s/repo16/commits?page=2", user.Name).
  96. AddTokenAuth(token)
  97. resp := MakeRequest(t, req, http.StatusOK)
  98. var apiData []api.Commit
  99. DecodeJSON(t, resp, &apiData)
  100. assert.Len(t, apiData, 0)
  101. }
  102. func TestAPIReposGitCommitListDifferentBranch(t *testing.T) {
  103. defer tests.PrepareTestEnv(t)()
  104. user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
  105. // Login as User2.
  106. session := loginUser(t, user.Name)
  107. token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeReadRepository)
  108. // Test getting commits (Page=1, Branch=good-sign)
  109. req := NewRequestf(t, "GET", "/api/v1/repos/%s/repo16/commits?sha=good-sign", user.Name).
  110. AddTokenAuth(token)
  111. resp := MakeRequest(t, req, http.StatusOK)
  112. var apiData []api.Commit
  113. DecodeJSON(t, resp, &apiData)
  114. assert.Len(t, apiData, 1)
  115. assert.Equal(t, "f27c2b2b03dcab38beaf89b0ab4ff61f6de63441", apiData[0].CommitMeta.SHA)
  116. compareCommitFiles(t, []string{"readme.md"}, apiData[0].Files)
  117. }
  118. func TestAPIReposGitCommitListWithoutSelectFields(t *testing.T) {
  119. defer tests.PrepareTestEnv(t)()
  120. user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
  121. // Login as User2.
  122. session := loginUser(t, user.Name)
  123. token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeReadRepository)
  124. // Test getting commits without files, verification, and stats
  125. req := NewRequestf(t, "GET", "/api/v1/repos/%s/repo16/commits?sha=good-sign&stat=false&files=false&verification=false", user.Name).
  126. AddTokenAuth(token)
  127. resp := MakeRequest(t, req, http.StatusOK)
  128. var apiData []api.Commit
  129. DecodeJSON(t, resp, &apiData)
  130. assert.Len(t, apiData, 1)
  131. assert.Equal(t, "f27c2b2b03dcab38beaf89b0ab4ff61f6de63441", apiData[0].CommitMeta.SHA)
  132. assert.Equal(t, (*api.CommitStats)(nil), apiData[0].Stats)
  133. assert.Equal(t, (*api.PayloadCommitVerification)(nil), apiData[0].RepoCommit.Verification)
  134. assert.Equal(t, ([]*api.CommitAffectedFiles)(nil), apiData[0].Files)
  135. }
  136. func TestDownloadCommitDiffOrPatch(t *testing.T) {
  137. defer tests.PrepareTestEnv(t)()
  138. user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
  139. // Login as User2.
  140. session := loginUser(t, user.Name)
  141. token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeReadRepository)
  142. // Test getting diff
  143. reqDiff := NewRequestf(t, "GET", "/api/v1/repos/%s/repo16/git/commits/f27c2b2b03dcab38beaf89b0ab4ff61f6de63441.diff", user.Name).
  144. AddTokenAuth(token)
  145. resp := MakeRequest(t, reqDiff, http.StatusOK)
  146. assert.EqualValues(t,
  147. "commit f27c2b2b03dcab38beaf89b0ab4ff61f6de63441\nAuthor: User2 <user2@example.com>\nDate: Sun Aug 6 19:55:01 2017 +0200\n\n good signed commit\n\ndiff --git a/readme.md b/readme.md\nnew file mode 100644\nindex 0000000..458121c\n--- /dev/null\n+++ b/readme.md\n@@ -0,0 +1 @@\n+good sign\n",
  148. resp.Body.String())
  149. // Test getting patch
  150. reqPatch := NewRequestf(t, "GET", "/api/v1/repos/%s/repo16/git/commits/f27c2b2b03dcab38beaf89b0ab4ff61f6de63441.patch", user.Name).
  151. AddTokenAuth(token)
  152. resp = MakeRequest(t, reqPatch, http.StatusOK)
  153. assert.EqualValues(t,
  154. "From f27c2b2b03dcab38beaf89b0ab4ff61f6de63441 Mon Sep 17 00:00:00 2001\nFrom: User2 <user2@example.com>\nDate: Sun, 6 Aug 2017 19:55:01 +0200\nSubject: [PATCH] good signed commit\n\n---\n readme.md | 1 +\n 1 file changed, 1 insertion(+)\n create mode 100644 readme.md\n\ndiff --git a/readme.md b/readme.md\nnew file mode 100644\nindex 0000000..458121c\n--- /dev/null\n+++ b/readme.md\n@@ -0,0 +1 @@\n+good sign\n",
  155. resp.Body.String())
  156. }
  157. func TestGetFileHistory(t *testing.T) {
  158. defer tests.PrepareTestEnv(t)()
  159. user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
  160. // Login as User2.
  161. session := loginUser(t, user.Name)
  162. token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeReadRepository)
  163. req := NewRequestf(t, "GET", "/api/v1/repos/%s/repo16/commits?path=readme.md&sha=good-sign", user.Name).
  164. AddTokenAuth(token)
  165. resp := MakeRequest(t, req, http.StatusOK)
  166. var apiData []api.Commit
  167. DecodeJSON(t, resp, &apiData)
  168. assert.Len(t, apiData, 1)
  169. assert.Equal(t, "f27c2b2b03dcab38beaf89b0ab4ff61f6de63441", apiData[0].CommitMeta.SHA)
  170. compareCommitFiles(t, []string{"readme.md"}, apiData[0].Files)
  171. assert.EqualValues(t, resp.Header().Get("X-Total"), "1")
  172. }
  173. func TestGetFileHistoryNotOnMaster(t *testing.T) {
  174. defer tests.PrepareTestEnv(t)()
  175. user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
  176. // Login as User2.
  177. session := loginUser(t, user.Name)
  178. token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeReadRepository)
  179. req := NewRequestf(t, "GET", "/api/v1/repos/%s/repo20/commits?path=test.csv&sha=add-csv&not=master", user.Name).
  180. AddTokenAuth(token)
  181. resp := MakeRequest(t, req, http.StatusOK)
  182. var apiData []api.Commit
  183. DecodeJSON(t, resp, &apiData)
  184. assert.Len(t, apiData, 1)
  185. assert.Equal(t, "c8e31bc7688741a5287fcde4fbb8fc129ca07027", apiData[0].CommitMeta.SHA)
  186. compareCommitFiles(t, []string{"test.csv"}, apiData[0].Files)
  187. assert.EqualValues(t, resp.Header().Get("X-Total"), "1")
  188. }