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:
parent
02678b3107
commit
5b17e85fe1
|
@ -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 }
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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) }
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue