FIX: correctly show user info (#21023)

This PR primarily fixes this case:

- USER A message
- USER B message
- USER B reply to USER A message <-- not showing user info when it should

Moreover, this commit also improves the spec to correctly test more cases.
This commit is contained in:
Joffrey JAFFEUX 2023-04-07 20:08:31 +02:00 committed by GitHub
parent 1f0aff2719
commit 6d99e6408f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 102 additions and 40 deletions

View File

@ -212,27 +212,43 @@ export default class ChatMessage extends Component {
get hideUserInfo() { get hideUserInfo() {
const message = this.args.message; const message = this.args.message;
const previousMessage = message?.previousMessage;
const previousMessage = message.previousMessage;
if (!previousMessage) { if (!previousMessage) {
return false; return false;
} }
// this is a micro optimization to avoid layout changes when we load more messages // this is a micro optimization to avoid layout changes when we load more messages
if (message?.firstOfResults) { if (message.firstOfResults) {
return false; return false;
} }
return ( if (message.chatWebhookEvent) {
!message?.chatWebhookEvent && return false;
(!message?.inReplyTo || }
message?.inReplyTo?.user?.id !== message?.user?.id) &&
!message?.previousMessage?.deletedAt && if (previousMessage.deletedAt) {
return false;
}
if (
Math.abs( Math.abs(
new Date(message?.createdAt) - new Date(previousMessage?.createdAt) new Date(message.createdAt) - new Date(previousMessage.createdAt)
) < 300000 && // If the time between messages is over 5 minutes, break. ) > 300000
message?.user?.id === message?.previousMessage?.user?.id ) {
); return false;
}
if (message.inReplyTo) {
if (message.inReplyTo?.id === previousMessage.id) {
return message.user?.id === previousMessage.user?.id;
} else {
return false;
}
}
return message.user?.id === previousMessage.user?.id;
} }
get hideReplyToInfo() { get hideReplyToInfo() {

View File

@ -1,6 +1,6 @@
# frozen_string_literal: true # frozen_string_literal: true
RSpec.describe "Sticky date", type: :system, js: true do RSpec.describe "Message user info", type: :system, js: true do
fab!(:current_user) { Fabricate(:user) } fab!(:current_user) { Fabricate(:user) }
fab!(:channel_1) { Fabricate(:category_channel) } fab!(:channel_1) { Fabricate(:category_channel) }
@ -8,53 +8,99 @@ RSpec.describe "Sticky date", type: :system, js: true do
before do before do
chat_system_bootstrap chat_system_bootstrap
channel_1.add(current_user)
sign_in(current_user) sign_in(current_user)
end end
context "when previous message is from a different user" do context "with one message" do
fab!(:message_1) { Fabricate(:chat_message, chat_channel: channel_1) } fab!(:message_1) { Fabricate(:chat_message, chat_channel: channel_1) }
fab!(:message_2) { Fabricate(:chat_message, chat_channel: channel_1) }
it "shows user info on the message" do it "shows user info on the message" do
chat_page.visit_channel(channel_1) chat_page.visit_channel(channel_1)
expect(page.find("[data-id='#{message_1.id}']")).to have_css(".chat-message-avatar")
end
end
context "with two messages from the same user" do
fab!(:message_1) { Fabricate(:chat_message, chat_channel: channel_1, user: current_user) }
fab!(:message_2) { Fabricate(:chat_message, chat_channel: channel_1, user: current_user) }
it "shows user info only on first message" do
chat_page.visit_channel(channel_1)
expect(page.find("[data-id='#{message_1.id}']")).to have_css(".chat-message-avatar")
expect(page.find("[data-id='#{message_2.id}']")).to have_no_css(".chat-message-avatar")
end
end
context "with a deleted previous message" do
fab!(:message_1) { Fabricate(:chat_message, chat_channel: channel_1, user: current_user) }
fab!(:message_2) { Fabricate(:chat_message, chat_channel: channel_1, user: current_user) }
it "shows user info only on second message" do
message_1.trash!
chat_page.visit_channel(channel_1)
expect(page.find("[data-id='#{message_2.id}']")).to have_css(".chat-message-avatar") expect(page.find("[data-id='#{message_2.id}']")).to have_css(".chat-message-avatar")
end end
end end
context "when previous message is from the same user" do context "with messages from a webhook" do
fab!(:message_1) { Fabricate(:chat_message, chat_channel: channel_1, user: current_user) } fab!(:message_1) { Fabricate(:chat_message, chat_channel: channel_1) }
fab!(:message_2) { Fabricate(:chat_message, chat_channel: channel_1, user: current_user) } fab!(:message_2) { Fabricate(:chat_message, chat_channel: channel_1) }
it "doesn’t show user info on the message" do it "shows user info only on boths messages" do
Fabricate(:chat_webhook_event, chat_message: message_1)
Fabricate(:chat_webhook_event, chat_message: message_2)
chat_page.visit_channel(channel_1) chat_page.visit_channel(channel_1)
expect(page.find("[data-id='#{message_2.id}']")).to have_no_css(".chat-message-avatar") expect(page.find("[data-id='#{message_1.id}']")).to have_css(".chat-message-avatar")
expect(page.find("[data-id='#{message_2.id}']")).to have_css(".chat-message-avatar")
end
end
context "with large time difference between messages" do
fab!(:message_1) do
Fabricate(:chat_message, chat_channel: channel_1, user: current_user, created_at: 1.days.ago)
end
fab!(:message_2) { Fabricate(:chat_message, chat_channel: channel_1, user: current_user) }
it "shows user info on both messages" do
chat_page.visit_channel(channel_1)
expect(page.find("[data-id='#{message_1.id}']")).to have_css(".chat-message-avatar")
expect(page.find("[data-id='#{message_2.id}']")).to have_css(".chat-message-avatar")
end
end
context "when replying to own previous message" do
fab!(:message_1) { Fabricate(:chat_message, chat_channel: channel_1, user: current_user) }
fab!(:message_2) do
Fabricate(:chat_message, in_reply_to: message_1, user: current_user, chat_channel: channel_1)
end end
context "when previous message is old" do it "shows user info on first message only" do
fab!(:message_1) do chat_page.visit_channel(channel_1)
Fabricate(
:chat_message,
chat_channel: channel_1,
user: current_user,
created_at: DateTime.parse("2018-11-10 17:00"),
)
end
fab!(:message_2) do
Fabricate(
:chat_message,
chat_channel: channel_1,
user: current_user,
created_at: DateTime.parse("2018-11-10 17:30"),
)
end
it "shows user info on the message" do expect(page.find("[data-id='#{message_1.id}']")).to have_css(".chat-message-avatar")
chat_page.visit_channel(channel_1) expect(page.find("[data-id='#{message_2.id}']")).to have_no_css(".chat-message-avatar")
end
end
expect(page.find("[data-id='#{message_2.id}']")).to have_no_css(".chat-message-avatar") context "when replying to another user previous message and previous message is yours" do
end fab!(:message_1) { Fabricate(:chat_message, chat_channel: channel_1) }
fab!(:message_2) { Fabricate(:chat_message, chat_channel: channel_1, user: current_user) }
fab!(:message_3) do
Fabricate(:chat_message, in_reply_to: message_1, user: current_user, chat_channel: channel_1)
end
it "shows user info on each message" do
chat_page.visit_channel(channel_1)
expect(page.find("[data-id='#{message_1.id}']")).to have_css(".chat-message-avatar")
expect(page.find("[data-id='#{message_2.id}']")).to have_css(".chat-message-avatar")
expect(page.find("[data-id='#{message_3.id}']")).to have_css(".chat-message-avatar")
end end
end end
end end