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.

api_repo_teams_test.go 3.0KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. // Copyright 2021 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package integration
  4. import (
  5. "fmt"
  6. "net/http"
  7. "testing"
  8. auth_model "code.gitea.io/gitea/models/auth"
  9. repo_model "code.gitea.io/gitea/models/repo"
  10. "code.gitea.io/gitea/models/unit"
  11. "code.gitea.io/gitea/models/unittest"
  12. user_model "code.gitea.io/gitea/models/user"
  13. api "code.gitea.io/gitea/modules/structs"
  14. "code.gitea.io/gitea/modules/util"
  15. "code.gitea.io/gitea/tests"
  16. "github.com/stretchr/testify/assert"
  17. )
  18. func TestAPIRepoTeams(t *testing.T) {
  19. defer tests.PrepareTestEnv(t)()
  20. // publicOrgRepo = org3/repo21
  21. publicOrgRepo := unittest.AssertExistsAndLoadBean(t, &repo_model.Repository{ID: 32})
  22. // user4
  23. user := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 4})
  24. session := loginUser(t, user.Name)
  25. token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeWriteRepository)
  26. // ListTeams
  27. req := NewRequest(t, "GET", fmt.Sprintf("/api/v1/repos/%s/teams", publicOrgRepo.FullName())).
  28. AddTokenAuth(token)
  29. res := MakeRequest(t, req, http.StatusOK)
  30. var teams []*api.Team
  31. DecodeJSON(t, res, &teams)
  32. if assert.Len(t, teams, 2) {
  33. assert.EqualValues(t, "Owners", teams[0].Name)
  34. assert.True(t, teams[0].CanCreateOrgRepo)
  35. assert.True(t, util.SliceSortedEqual(unit.AllUnitKeyNames(), teams[0].Units), fmt.Sprintf("%v == %v", unit.AllUnitKeyNames(), teams[0].Units))
  36. assert.EqualValues(t, "owner", teams[0].Permission)
  37. assert.EqualValues(t, "test_team", teams[1].Name)
  38. assert.False(t, teams[1].CanCreateOrgRepo)
  39. assert.EqualValues(t, []string{"repo.issues"}, teams[1].Units)
  40. assert.EqualValues(t, "write", teams[1].Permission)
  41. }
  42. // IsTeam
  43. req = NewRequest(t, "GET", fmt.Sprintf("/api/v1/repos/%s/teams/%s", publicOrgRepo.FullName(), "Test_Team")).
  44. AddTokenAuth(token)
  45. res = MakeRequest(t, req, http.StatusOK)
  46. var team *api.Team
  47. DecodeJSON(t, res, &team)
  48. assert.EqualValues(t, teams[1], team)
  49. req = NewRequest(t, "GET", fmt.Sprintf("/api/v1/repos/%s/teams/%s", publicOrgRepo.FullName(), "NonExistingTeam")).
  50. AddTokenAuth(token)
  51. MakeRequest(t, req, http.StatusNotFound)
  52. // AddTeam with user4
  53. req = NewRequest(t, "PUT", fmt.Sprintf("/api/v1/repos/%s/teams/%s", publicOrgRepo.FullName(), "team1")).
  54. AddTokenAuth(token)
  55. MakeRequest(t, req, http.StatusForbidden)
  56. // AddTeam with user2
  57. user = unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2})
  58. session = loginUser(t, user.Name)
  59. token = getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeWriteRepository)
  60. req = NewRequest(t, "PUT", fmt.Sprintf("/api/v1/repos/%s/teams/%s", publicOrgRepo.FullName(), "team1")).
  61. AddTokenAuth(token)
  62. MakeRequest(t, req, http.StatusNoContent)
  63. MakeRequest(t, req, http.StatusUnprocessableEntity) // test duplicate request
  64. // DeleteTeam
  65. req = NewRequest(t, "DELETE", fmt.Sprintf("/api/v1/repos/%s/teams/%s", publicOrgRepo.FullName(), "team1")).
  66. AddTokenAuth(token)
  67. MakeRequest(t, req, http.StatusNoContent)
  68. MakeRequest(t, req, http.StatusUnprocessableEntity) // test duplicate request
  69. }