2021-05-05 14:06:39 +01:00
|
|
|
// Copyright 2021 The Gitea Authors. All rights reserved.
|
2022-11-27 13:20:29 -05:00
|
|
|
// SPDX-License-Identifier: MIT
|
2021-05-05 14:06:39 +01:00
|
|
|
|
2022-09-02 15:18:23 -04:00
|
|
|
package integration
|
2021-05-05 14:06:39 +01:00
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
2023-04-10 22:14:16 +02:00
|
|
|
"fmt"
|
2021-05-05 14:06:39 +01:00
|
|
|
"image/png"
|
|
|
|
"io"
|
|
|
|
"mime/multipart"
|
|
|
|
"net/http"
|
2025-04-29 13:31:07 +00:00
|
|
|
"net/url"
|
2021-05-05 14:06:39 +01:00
|
|
|
"testing"
|
|
|
|
|
2025-03-27 19:40:14 +00:00
|
|
|
"forgejo.org/models/db"
|
|
|
|
"forgejo.org/models/unittest"
|
|
|
|
user_model "forgejo.org/models/user"
|
|
|
|
"forgejo.org/modules/avatar"
|
|
|
|
"forgejo.org/tests"
|
2021-11-17 20:34:35 +08:00
|
|
|
|
2021-05-05 14:06:39 +01:00
|
|
|
"github.com/stretchr/testify/assert"
|
2024-07-30 19:41:10 +00:00
|
|
|
"github.com/stretchr/testify/require"
|
2021-05-05 14:06:39 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestUserAvatar(t *testing.T) {
|
2024-11-10 18:25:41 +01:00
|
|
|
defer tests.PrepareTestEnv(t)()
|
|
|
|
user2 := unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2}) // owner of the repo3, is an org
|
2021-05-05 14:06:39 +01:00
|
|
|
|
2024-11-10 18:25:41 +01:00
|
|
|
seed := user2.Email
|
|
|
|
if len(seed) == 0 {
|
|
|
|
seed = user2.Name
|
|
|
|
}
|
2021-05-05 14:06:39 +01:00
|
|
|
|
2024-11-10 18:25:41 +01:00
|
|
|
img, err := avatar.RandomImage([]byte(seed))
|
|
|
|
if err != nil {
|
|
|
|
require.NoError(t, err)
|
|
|
|
return
|
|
|
|
}
|
2021-05-05 14:06:39 +01:00
|
|
|
|
2024-11-10 18:25:41 +01:00
|
|
|
session := loginUser(t, "user2")
|
|
|
|
csrf := GetCSRF(t, session, "/user/settings")
|
2021-05-05 14:06:39 +01:00
|
|
|
|
2024-11-10 18:25:41 +01:00
|
|
|
imgData := &bytes.Buffer{}
|
2021-05-05 14:06:39 +01:00
|
|
|
|
2024-11-10 18:25:41 +01:00
|
|
|
body := &bytes.Buffer{}
|
2021-05-05 14:06:39 +01:00
|
|
|
|
2024-11-10 18:25:41 +01:00
|
|
|
// Setup multi-part
|
|
|
|
writer := multipart.NewWriter(body)
|
|
|
|
writer.WriteField("source", "local")
|
|
|
|
part, err := writer.CreateFormFile("avatar", "avatar-for-testuseravatar.png")
|
|
|
|
if err != nil {
|
|
|
|
require.NoError(t, err)
|
|
|
|
return
|
|
|
|
}
|
2021-05-05 14:06:39 +01:00
|
|
|
|
2024-11-10 18:25:41 +01:00
|
|
|
if err := png.Encode(imgData, img); err != nil {
|
|
|
|
require.NoError(t, err)
|
|
|
|
return
|
|
|
|
}
|
2021-05-05 14:06:39 +01:00
|
|
|
|
2024-11-10 18:25:41 +01:00
|
|
|
if _, err := io.Copy(part, imgData); err != nil {
|
|
|
|
require.NoError(t, err)
|
|
|
|
return
|
|
|
|
}
|
2021-05-05 14:06:39 +01:00
|
|
|
|
2024-11-10 18:25:41 +01:00
|
|
|
if err := writer.Close(); err != nil {
|
|
|
|
require.NoError(t, err)
|
|
|
|
return
|
|
|
|
}
|
2021-05-05 14:06:39 +01:00
|
|
|
|
2024-11-10 18:25:41 +01:00
|
|
|
req := NewRequestWithBody(t, "POST", "/user/settings/avatar", body)
|
|
|
|
req.Header.Add("X-Csrf-Token", csrf)
|
|
|
|
req.Header.Add("Content-Type", writer.FormDataContentType())
|
2021-05-05 14:06:39 +01:00
|
|
|
|
2024-11-10 18:25:41 +01:00
|
|
|
session.MakeRequest(t, req, http.StatusSeeOther)
|
2021-05-05 14:06:39 +01:00
|
|
|
|
2024-11-10 18:25:41 +01:00
|
|
|
user2 = unittest.AssertExistsAndLoadBean(t, &user_model.User{ID: 2}) // owner of the repo3, is an org
|
2021-05-05 14:06:39 +01:00
|
|
|
|
2024-11-10 18:25:41 +01:00
|
|
|
req = NewRequest(t, "GET", user2.AvatarLinkWithSize(db.DefaultContext, 0))
|
|
|
|
_ = session.MakeRequest(t, req, http.StatusOK)
|
2021-05-05 14:06:39 +01:00
|
|
|
|
2024-11-10 18:25:41 +01:00
|
|
|
req = NewRequestf(t, "GET", "/%s.png", user2.Name)
|
|
|
|
resp := MakeRequest(t, req, http.StatusSeeOther)
|
2025-03-28 22:22:21 +00:00
|
|
|
assert.Equal(t, fmt.Sprintf("/avatars/%s", user2.Avatar), resp.Header().Get("location"))
|
2023-04-10 22:14:16 +02:00
|
|
|
|
2024-11-10 18:25:41 +01:00
|
|
|
// 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.
|
2023-04-10 22:14:16 +02:00
|
|
|
}
|
2025-04-29 13:31:07 +00:00
|
|
|
|
|
|
|
func TestAvatarAnchorDestination(t *testing.T) {
|
|
|
|
defer tests.PrepareTestEnv(t)()
|
|
|
|
|
|
|
|
// If the user is logged in, and looking at their own profile,
|
|
|
|
// the avatar becomes a link towards the user settings page.
|
|
|
|
// Test that the link does not show up when not viewing one's own profile,
|
|
|
|
// and that, if the link does show up, there is a corresponding element
|
|
|
|
// on the user settings page matching the fragment of the anchor.
|
|
|
|
|
|
|
|
t.Run("viewing other's profile", func(t *testing.T) {
|
|
|
|
defer tests.PrintCurrentTest(t)()
|
|
|
|
|
|
|
|
profilePage := NewHTMLParser(t, MakeRequest(t, NewRequest(t, "GET", "/user2"), http.StatusOK).Body)
|
|
|
|
profilePage.AssertElement(t, "#profile-avatar", true)
|
|
|
|
// When viewing another user's profile, there shouldn't be a link to user settings
|
|
|
|
profilePage.AssertElement(t, "#profile-avatar a", false)
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("viewing own profile", func(t *testing.T) {
|
|
|
|
defer tests.PrintCurrentTest(t)()
|
|
|
|
|
|
|
|
session := loginUser(t, "user2")
|
|
|
|
|
|
|
|
profilePage := NewHTMLParser(t, session.MakeRequest(t, NewRequest(t, "GET", "/user2"), http.StatusOK).Body)
|
|
|
|
profilePage.AssertElement(t, "#profile-avatar a", true)
|
|
|
|
href, has := profilePage.Find("#profile-avatar a").Attr("href")
|
|
|
|
assert.True(t, has)
|
|
|
|
|
|
|
|
settingsURL, err := url.Parse(href)
|
|
|
|
require.NoError(t, err, "Change avatar link can't be parsed to URL")
|
|
|
|
|
|
|
|
settingsPage := NewHTMLParser(t, session.MakeRequest(t, NewRequest(t, "GET", href), http.StatusOK).Body)
|
|
|
|
settingsPage.AssertElement(t, fmt.Sprintf("#%s", settingsURL.Fragment), true)
|
|
|
|
})
|
|
|
|
}
|