gitea源码

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. // Copyright 2021 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package integration
  4. import (
  5. "bytes"
  6. "image/png"
  7. "io"
  8. "mime/multipart"
  9. "net/http"
  10. "testing"
  11. "code.gitea.io/gitea/models/unittest"
  12. user_model "code.gitea.io/gitea/models/user"
  13. "code.gitea.io/gitea/modules/avatar"
  14. "code.gitea.io/gitea/tests"
  15. "github.com/stretchr/testify/assert"
  16. )
  17. func TestUserAvatar(t *testing.T) {
  18. defer tests.PrepareTestEnv(t)()
  19. user2 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2}) // owner of the repo3, is an org
  20. seed := user2.Email
  21. if len(seed) == 0 {
  22. seed = user2.Name
  23. }
  24. img, err := avatar.RandomImage([]byte(seed))
  25. if err != nil {
  26. assert.NoError(t, err)
  27. return
  28. }
  29. session := loginUser(t, "user2")
  30. csrf := GetUserCSRFToken(t, session)
  31. imgData := &bytes.Buffer{}
  32. body := &bytes.Buffer{}
  33. // Setup multi-part
  34. writer := multipart.NewWriter(body)
  35. writer.WriteField("source", "local")
  36. part, err := writer.CreateFormFile("avatar", "avatar-for-testuseravatar.png")
  37. if err != nil {
  38. assert.NoError(t, err)
  39. return
  40. }
  41. if err := png.Encode(imgData, img); err != nil {
  42. assert.NoError(t, err)
  43. return
  44. }
  45. if _, err := io.Copy(part, imgData); err != nil {
  46. assert.NoError(t, err)
  47. return
  48. }
  49. if err := writer.Close(); err != nil {
  50. assert.NoError(t, err)
  51. return
  52. }
  53. req := NewRequestWithBody(t, "POST", "/user/settings/avatar", body)
  54. req.Header.Add("X-Csrf-Token", csrf)
  55. req.Header.Add("Content-Type", writer.FormDataContentType())
  56. session.MakeRequest(t, req, http.StatusSeeOther)
  57. user2 = unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2}) // owner of the repo3, is an org
  58. req = NewRequest(t, "GET", user2.AvatarLinkWithSize(t.Context(), 0))
  59. _ = session.MakeRequest(t, req, http.StatusOK)
  60. testGetAvatarRedirect(t, user2)
  61. // Can't test if the response matches because the image is re-generated on upload but checking that this at least doesn't give a 404 should be enough.
  62. }
  63. func testGetAvatarRedirect(t *testing.T, user *user_model.User) {
  64. t.Run("getAvatarRedirect_"+user.Name, func(t *testing.T) {
  65. req := NewRequestf(t, "GET", "/%s.png", user.Name)
  66. resp := MakeRequest(t, req, http.StatusSeeOther)
  67. assert.Equal(t, "/avatars/"+user.Avatar, resp.Header().Get("location"))
  68. })
  69. }