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_org_test.go 4.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. // Copyright 2018 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. "net/http"
  7. "net/url"
  8. "strings"
  9. "testing"
  10. "code.gitea.io/gitea/models/unittest"
  11. user_model "code.gitea.io/gitea/models/user"
  12. "code.gitea.io/gitea/modules/setting"
  13. api "code.gitea.io/gitea/modules/structs"
  14. "github.com/stretchr/testify/assert"
  15. )
  16. func TestAPIOrgCreate(t *testing.T) {
  17. onGiteaRun(t, func(*testing.T, *url.URL) {
  18. session := loginUser(t, "user1")
  19. token := getTokenForLoggedInUser(t, session)
  20. var org = api.CreateOrgOption{
  21. UserName: "user1_org",
  22. FullName: "User1's organization",
  23. Description: "This organization created by user1",
  24. Website: "https://try.gitea.io",
  25. Location: "Shanghai",
  26. Visibility: "limited",
  27. }
  28. req := NewRequestWithJSON(t, "POST", "/api/v1/orgs?token="+token, &org)
  29. resp := session.MakeRequest(t, req, http.StatusCreated)
  30. var apiOrg api.Organization
  31. DecodeJSON(t, resp, &apiOrg)
  32. assert.Equal(t, org.UserName, apiOrg.UserName)
  33. assert.Equal(t, org.FullName, apiOrg.FullName)
  34. assert.Equal(t, org.Description, apiOrg.Description)
  35. assert.Equal(t, org.Website, apiOrg.Website)
  36. assert.Equal(t, org.Location, apiOrg.Location)
  37. assert.Equal(t, org.Visibility, apiOrg.Visibility)
  38. unittest.AssertExistsAndLoadBean(t, &user_model.User{
  39. Name: org.UserName,
  40. LowerName: strings.ToLower(org.UserName),
  41. FullName: org.FullName,
  42. })
  43. req = NewRequestf(t, "GET", "/api/v1/orgs/%s", org.UserName)
  44. resp = session.MakeRequest(t, req, http.StatusOK)
  45. DecodeJSON(t, resp, &apiOrg)
  46. assert.EqualValues(t, org.UserName, apiOrg.UserName)
  47. req = NewRequestf(t, "GET", "/api/v1/orgs/%s/repos", org.UserName)
  48. resp = session.MakeRequest(t, req, http.StatusOK)
  49. var repos []*api.Repository
  50. DecodeJSON(t, resp, &repos)
  51. for _, repo := range repos {
  52. assert.False(t, repo.Private)
  53. }
  54. req = NewRequestf(t, "GET", "/api/v1/orgs/%s/members", org.UserName)
  55. resp = session.MakeRequest(t, req, http.StatusOK)
  56. // user1 on this org is public
  57. var users []*api.User
  58. DecodeJSON(t, resp, &users)
  59. assert.Len(t, users, 1)
  60. assert.EqualValues(t, "user1", users[0].UserName)
  61. })
  62. }
  63. func TestAPIOrgEdit(t *testing.T) {
  64. onGiteaRun(t, func(*testing.T, *url.URL) {
  65. session := loginUser(t, "user1")
  66. token := getTokenForLoggedInUser(t, session)
  67. var org = api.EditOrgOption{
  68. FullName: "User3 organization new full name",
  69. Description: "A new description",
  70. Website: "https://try.gitea.io/new",
  71. Location: "Beijing",
  72. Visibility: "private",
  73. }
  74. req := NewRequestWithJSON(t, "PATCH", "/api/v1/orgs/user3?token="+token, &org)
  75. resp := session.MakeRequest(t, req, http.StatusOK)
  76. var apiOrg api.Organization
  77. DecodeJSON(t, resp, &apiOrg)
  78. assert.Equal(t, "user3", apiOrg.UserName)
  79. assert.Equal(t, org.FullName, apiOrg.FullName)
  80. assert.Equal(t, org.Description, apiOrg.Description)
  81. assert.Equal(t, org.Website, apiOrg.Website)
  82. assert.Equal(t, org.Location, apiOrg.Location)
  83. assert.Equal(t, org.Visibility, apiOrg.Visibility)
  84. })
  85. }
  86. func TestAPIOrgEditBadVisibility(t *testing.T) {
  87. onGiteaRun(t, func(*testing.T, *url.URL) {
  88. session := loginUser(t, "user1")
  89. token := getTokenForLoggedInUser(t, session)
  90. var org = api.EditOrgOption{
  91. FullName: "User3 organization new full name",
  92. Description: "A new description",
  93. Website: "https://try.gitea.io/new",
  94. Location: "Beijing",
  95. Visibility: "badvisibility",
  96. }
  97. req := NewRequestWithJSON(t, "PATCH", "/api/v1/orgs/user3?token="+token, &org)
  98. session.MakeRequest(t, req, http.StatusUnprocessableEntity)
  99. })
  100. }
  101. func TestAPIOrgDeny(t *testing.T) {
  102. onGiteaRun(t, func(*testing.T, *url.URL) {
  103. setting.Service.RequireSignInView = true
  104. defer func() {
  105. setting.Service.RequireSignInView = false
  106. }()
  107. var orgName = "user1_org"
  108. req := NewRequestf(t, "GET", "/api/v1/orgs/%s", orgName)
  109. MakeRequest(t, req, http.StatusNotFound)
  110. req = NewRequestf(t, "GET", "/api/v1/orgs/%s/repos", orgName)
  111. MakeRequest(t, req, http.StatusNotFound)
  112. req = NewRequestf(t, "GET", "/api/v1/orgs/%s/members", orgName)
  113. MakeRequest(t, req, http.StatusNotFound)
  114. })
  115. }
  116. func TestAPIGetAll(t *testing.T) {
  117. defer prepareTestEnv(t)()
  118. req := NewRequestf(t, "GET", "/api/v1/orgs")
  119. resp := MakeRequest(t, req, http.StatusOK)
  120. var apiOrgList []*api.Organization
  121. DecodeJSON(t, resp, &apiOrgList)
  122. assert.Len(t, apiOrgList, 7)
  123. assert.Equal(t, "org25", apiOrgList[0].FullName)
  124. assert.Equal(t, "public", apiOrgList[0].Visibility)
  125. }