gitea源码

api_repo_branch_test.go 5.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. // Copyright 2021 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package integration
  4. import (
  5. "fmt"
  6. "io"
  7. "net/http"
  8. "net/url"
  9. "strings"
  10. "testing"
  11. auth_model "code.gitea.io/gitea/models/auth"
  12. repo_model "code.gitea.io/gitea/models/repo"
  13. "code.gitea.io/gitea/models/unittest"
  14. user_model "code.gitea.io/gitea/models/user"
  15. "code.gitea.io/gitea/modules/json"
  16. "code.gitea.io/gitea/modules/setting"
  17. api "code.gitea.io/gitea/modules/structs"
  18. "code.gitea.io/gitea/tests"
  19. "github.com/stretchr/testify/assert"
  20. )
  21. func TestAPIRepoBranchesPlain(t *testing.T) {
  22. onGiteaRun(t, func(*testing.T, *url.URL) {
  23. repo3 := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 3})
  24. user1 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 1})
  25. session := loginUser(t, user1.LowerName)
  26. // public only token should be forbidden
  27. publicOnlyToken := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopePublicOnly, auth_model.AccessTokenScopeWriteRepository)
  28. link, _ := url.Parse(fmt.Sprintf("/api/v1/repos/org3/%s/branches", repo3.Name)) // a plain repo
  29. MakeRequest(t, NewRequest(t, "GET", link.String()).AddTokenAuth(publicOnlyToken), http.StatusForbidden)
  30. token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeWriteRepository)
  31. resp := MakeRequest(t, NewRequest(t, "GET", link.String()).AddTokenAuth(token), http.StatusOK)
  32. bs, err := io.ReadAll(resp.Body)
  33. assert.NoError(t, err)
  34. var branches []*api.Branch
  35. assert.NoError(t, json.Unmarshal(bs, &branches))
  36. assert.Len(t, branches, 2)
  37. assert.Equal(t, "test_branch", branches[0].Name)
  38. assert.Equal(t, "master", branches[1].Name)
  39. link2, _ := url.Parse(fmt.Sprintf("/api/v1/repos/org3/%s/branches/test_branch", repo3.Name))
  40. MakeRequest(t, NewRequest(t, "GET", link2.String()).AddTokenAuth(publicOnlyToken), http.StatusForbidden)
  41. resp = MakeRequest(t, NewRequest(t, "GET", link2.String()).AddTokenAuth(token), http.StatusOK)
  42. bs, err = io.ReadAll(resp.Body)
  43. assert.NoError(t, err)
  44. var branch api.Branch
  45. assert.NoError(t, json.Unmarshal(bs, &branch))
  46. assert.Equal(t, "test_branch", branch.Name)
  47. MakeRequest(t, NewRequest(t, "POST", link.String()).AddTokenAuth(publicOnlyToken), http.StatusForbidden)
  48. req := NewRequest(t, "POST", link.String()).AddTokenAuth(token)
  49. req.Header.Add("Content-Type", "application/json")
  50. req.Body = io.NopCloser(strings.NewReader(`{"new_branch_name":"test_branch2", "old_branch_name": "test_branch", "old_ref_name":"refs/heads/test_branch"}`))
  51. resp = MakeRequest(t, req, http.StatusCreated)
  52. bs, err = io.ReadAll(resp.Body)
  53. assert.NoError(t, err)
  54. var branch2 api.Branch
  55. assert.NoError(t, json.Unmarshal(bs, &branch2))
  56. assert.Equal(t, "test_branch2", branch2.Name)
  57. assert.Equal(t, branch.Commit.ID, branch2.Commit.ID)
  58. resp = MakeRequest(t, NewRequest(t, "GET", link.String()).AddTokenAuth(token), http.StatusOK)
  59. bs, err = io.ReadAll(resp.Body)
  60. assert.NoError(t, err)
  61. branches = []*api.Branch{}
  62. assert.NoError(t, json.Unmarshal(bs, &branches))
  63. assert.Len(t, branches, 3)
  64. assert.Equal(t, "test_branch", branches[0].Name)
  65. assert.Equal(t, "test_branch2", branches[1].Name)
  66. assert.Equal(t, "master", branches[2].Name)
  67. link3, _ := url.Parse(fmt.Sprintf("/api/v1/repos/org3/%s/branches/test_branch2", repo3.Name))
  68. MakeRequest(t, NewRequest(t, "DELETE", link3.String()), http.StatusNotFound)
  69. MakeRequest(t, NewRequest(t, "DELETE", link3.String()).AddTokenAuth(publicOnlyToken), http.StatusForbidden)
  70. MakeRequest(t, NewRequest(t, "DELETE", link3.String()).AddTokenAuth(token), http.StatusNoContent)
  71. assert.NoError(t, err)
  72. })
  73. }
  74. func TestAPIRepoBranchesMirror(t *testing.T) {
  75. defer tests.PrepareTestEnv(t)()
  76. repo5 := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 5})
  77. user1 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 1})
  78. session := loginUser(t, user1.LowerName)
  79. token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeWriteRepository)
  80. link, _ := url.Parse(fmt.Sprintf("/api/v1/repos/org3/%s/branches", repo5.Name)) // a mirror repo
  81. resp := MakeRequest(t, NewRequest(t, "GET", link.String()).AddTokenAuth(token), http.StatusOK)
  82. bs, err := io.ReadAll(resp.Body)
  83. assert.NoError(t, err)
  84. var branches []*api.Branch
  85. assert.NoError(t, json.Unmarshal(bs, &branches))
  86. assert.Len(t, branches, 2)
  87. assert.Equal(t, "test_branch", branches[0].Name)
  88. assert.Equal(t, "master", branches[1].Name)
  89. link2, _ := url.Parse(fmt.Sprintf("/api/v1/repos/org3/%s/branches/test_branch", repo5.Name))
  90. resp = MakeRequest(t, NewRequest(t, "GET", link2.String()).AddTokenAuth(token), http.StatusOK)
  91. bs, err = io.ReadAll(resp.Body)
  92. assert.NoError(t, err)
  93. var branch api.Branch
  94. assert.NoError(t, json.Unmarshal(bs, &branch))
  95. assert.Equal(t, "test_branch", branch.Name)
  96. req := NewRequest(t, "POST", link.String()).AddTokenAuth(token)
  97. req.Header.Add("Content-Type", "application/json")
  98. req.Body = io.NopCloser(strings.NewReader(`{"new_branch_name":"test_branch2", "old_branch_name": "test_branch", "old_ref_name":"refs/heads/test_branch"}`))
  99. resp = MakeRequest(t, req, http.StatusForbidden)
  100. bs, err = io.ReadAll(resp.Body)
  101. assert.NoError(t, err)
  102. assert.Equal(t, "{\"message\":\"Git Repository is a mirror.\",\"url\":\""+setting.AppURL+"api/swagger\"}\n", string(bs))
  103. resp = MakeRequest(t, NewRequest(t, "DELETE", link2.String()).AddTokenAuth(token), http.StatusForbidden)
  104. bs, err = io.ReadAll(resp.Body)
  105. assert.NoError(t, err)
  106. assert.Equal(t, "{\"message\":\"Git Repository is a mirror.\",\"url\":\""+setting.AppURL+"api/swagger\"}\n", string(bs))
  107. }