FIX: broken mentioned users with capitalized usernames (#28421)

This commit fixes two codepaths which where incorrectly working with capitalized usernames as we were doing a mix of username_lower and non lower username.

Also adds two specs for these cases.
This commit is contained in:
Joffrey JAFFEUX 2024-08-19 20:57:45 +02:00 committed by GitHub
parent 02678b3107
commit 5b17e85fe1
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 44 additions and 19 deletions

View File

@ -591,7 +591,7 @@ class PostSerializer < BasicPostSerializer
else else
query = User.includes(:user_option) query = User.includes(:user_option)
query = query.includes(:user_status) if SiteSetting.enable_user_status query = query.includes(:user_status) if SiteSetting.enable_user_status
query = query.where(username: object.mentions) query = query.where(username_lower: object.mentions)
end end
users.map { |user| BasicUserSerializer.new(user, root: false, include_status: true).as_json } users.map { |user| BasicUserSerializer.new(user, root: false, include_status: true).as_json }

View File

@ -744,7 +744,8 @@ class TopicView
usernames.flatten! usernames.flatten!
usernames.uniq! usernames.uniq!
users = User.where(username: usernames).includes(:user_status).index_by(&:username) users =
User.where(username_lower: usernames).includes(:user_status).index_by(&:username_lower)
mentions.reduce({}) do |hash, (post_id, post_mentioned_usernames)| mentions.reduce({}) do |hash, (post_id, post_mentioned_usernames)|
hash[post_id] = post_mentioned_usernames.map { |username| users[username] }.compact hash[post_id] = post_mentioned_usernames.map { |username| users[username] }.compact

View File

@ -950,6 +950,17 @@ RSpec.describe TopicView do
end end
end end
describe "#mentioned_users" do
it "works with capitalized usernames" do
user = Fabricate(:user, username: "JoJo")
post_1 = Fabricate(:post, topic: topic, raw: "Hey @#{user.username}")
view = TopicView.new(topic.id, user).mentioned_users
expect(view[post_1.id]).to eq([user])
end
end
describe "#image_url" do describe "#image_url" do
fab!(:op_upload) { Fabricate(:image_upload) } fab!(:op_upload) { Fabricate(:image_upload) }
fab!(:post3_upload) { Fabricate(:image_upload) } fab!(:post3_upload) { Fabricate(:image_upload) }

View File

@ -365,29 +365,42 @@ RSpec.describe PostSerializer do
context "with mentions" do context "with mentions" do
fab!(:user_status) fab!(:user_status)
fab!(:user) fab!(:user)
fab!(:user1) { Fabricate(:user, user_status: user_status) }
fab!(:post) { Fabricate(:post, user: user, raw: "Hey @#{user1.username}") } let(:username) { "joffrey" }
let(:user1) { Fabricate(:user, user_status: user_status, username: username) }
let(:post) { Fabricate(:post, user: user, raw: "Hey @#{user1.username}") }
let(:serializer) { described_class.new(post, scope: Guardian.new(user), root: false) } let(:serializer) { described_class.new(post, scope: Guardian.new(user), root: false) }
it "returns mentioned users with user status when user status is enabled" do context "when user status is enabled" do
SiteSetting.enable_user_status = true before { SiteSetting.enable_user_status = true }
json = serializer.as_json it "returns mentioned users with user status" do
json = serializer.as_json
expect(json[:mentioned_users]).to be_present
expect(json[:mentioned_users].length).to be(1)
expect(json[:mentioned_users][0]).to_not be_nil
expect(json[:mentioned_users][0][:id]).to eq(user1.id)
expect(json[:mentioned_users][0][:username]).to eq(user1.username)
expect(json[:mentioned_users][0][:name]).to eq(user1.name)
expect(json[:mentioned_users][0][:status][:description]).to eq(user_status.description)
expect(json[:mentioned_users][0][:status][:emoji]).to eq(user_status.emoji)
end
expect(json[:mentioned_users]).to be_present context "when username has a capital letter" do
expect(json[:mentioned_users].length).to be(1) let(:username) { "JoJo" }
expect(json[:mentioned_users][0]).to_not be_nil
expect(json[:mentioned_users][0][:id]).to eq(user1.id) it "returns mentioned users with user status" do
expect(json[:mentioned_users][0][:username]).to eq(user1.username) expect(serializer.as_json[:mentioned_users][0][:username]).to eq(user1.username)
expect(json[:mentioned_users][0][:name]).to eq(user1.name) end
expect(json[:mentioned_users][0][:status][:description]).to eq(user_status.description) end
expect(json[:mentioned_users][0][:status][:emoji]).to eq(user_status.emoji)
end end
it "doesn't return mentioned users when user status is disabled" do context "when user status is disabled" do
SiteSetting.enable_user_status = false before { SiteSetting.enable_user_status = false }
json = serializer.as_json
expect(json[:mentioned_users]).to be_nil it "doesn't return mentioned users" do
expect(serializer.as_json[:mentioned_users]).to be_nil
end
end end
end end