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_user_watch_test.go 2.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. // Copyright 2022 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. "code.gitea.io/gitea/models/unittest"
  10. user_model "code.gitea.io/gitea/models/user"
  11. api "code.gitea.io/gitea/modules/structs"
  12. "code.gitea.io/gitea/tests"
  13. "github.com/stretchr/testify/assert"
  14. )
  15. func TestAPIWatch(t *testing.T) {
  16. defer tests.PrepareTestEnv(t)()
  17. user := "user1"
  18. repo := "user2/repo1"
  19. session := loginUser(t, user)
  20. token := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeReadUser)
  21. tokenWithRepoScope := getTokenForLoggedInUser(t, session, auth_model.AccessTokenScopeWriteRepository, auth_model.AccessTokenScopeReadUser)
  22. t.Run("Watch", func(t *testing.T) {
  23. defer tests.PrintCurrentTest(t)()
  24. req := NewRequest(t, "PUT", fmt.Sprintf("/api/v1/repos/%s/subscription", repo)).
  25. AddTokenAuth(tokenWithRepoScope)
  26. MakeRequest(t, req, http.StatusOK)
  27. // blocked user can't watch a repo
  28. user34 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 34})
  29. req = NewRequest(t, "PUT", fmt.Sprintf("/api/v1/repos/%s/subscription", repo)).
  30. AddTokenAuth(getUserToken(t, user34.Name, auth_model.AccessTokenScopeWriteRepository))
  31. MakeRequest(t, req, http.StatusForbidden)
  32. })
  33. t.Run("GetWatchedRepos", func(t *testing.T) {
  34. defer tests.PrintCurrentTest(t)()
  35. req := NewRequest(t, "GET", fmt.Sprintf("/api/v1/users/%s/subscriptions", user)).
  36. AddTokenAuth(token)
  37. resp := MakeRequest(t, req, http.StatusOK)
  38. assert.Equal(t, "1", resp.Header().Get("X-Total-Count"))
  39. var repos []api.Repository
  40. DecodeJSON(t, resp, &repos)
  41. assert.Len(t, repos, 1)
  42. assert.Equal(t, repo, repos[0].FullName)
  43. })
  44. t.Run("GetMyWatchedRepos", func(t *testing.T) {
  45. defer tests.PrintCurrentTest(t)()
  46. req := NewRequest(t, "GET", "/api/v1/user/subscriptions").
  47. AddTokenAuth(tokenWithRepoScope)
  48. resp := MakeRequest(t, req, http.StatusOK)
  49. assert.Equal(t, "1", resp.Header().Get("X-Total-Count"))
  50. var repos []api.Repository
  51. DecodeJSON(t, resp, &repos)
  52. assert.Len(t, repos, 1)
  53. assert.Equal(t, repo, repos[0].FullName)
  54. })
  55. t.Run("IsWatching", func(t *testing.T) {
  56. defer tests.PrintCurrentTest(t)()
  57. req := NewRequest(t, "GET", fmt.Sprintf("/api/v1/repos/%s/subscription", repo))
  58. MakeRequest(t, req, http.StatusUnauthorized)
  59. req = NewRequest(t, "GET", fmt.Sprintf("/api/v1/repos/%s/subscription", repo)).
  60. AddTokenAuth(tokenWithRepoScope)
  61. MakeRequest(t, req, http.StatusOK)
  62. req = NewRequest(t, "GET", fmt.Sprintf("/api/v1/repos/%s/subscription", repo+"notexisting")).
  63. AddTokenAuth(tokenWithRepoScope)
  64. MakeRequest(t, req, http.StatusNotFound)
  65. })
  66. t.Run("Unwatch", func(t *testing.T) {
  67. defer tests.PrintCurrentTest(t)()
  68. req := NewRequest(t, "DELETE", fmt.Sprintf("/api/v1/repos/%s/subscription", repo)).
  69. AddTokenAuth(tokenWithRepoScope)
  70. MakeRequest(t, req, http.StatusNoContent)
  71. })
  72. }