FIX: build chat message excerpt for thread preview (#26765)

Follow up to #26712 to account for older threads that don't have a persisted excerpt, as this was previously generated on every page load.

This change allows us to build the excerpt on the fly when none exists, fixing the issue of missing message excerpts for thread previews (within channel) and thread lists (on mobile/desktop).
This commit is contained in:
David Battersby 2024-04-26 14:29:35 +08:00 committed by GitHub
parent 9d96fcb821
commit 09f2a42f5f
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
6 changed files with 26 additions and 4 deletions

View File

@ -6,7 +6,7 @@ module Chat
nil nil
end end
def excerpt(max_length: nil) def build_excerpt
nil nil
end end

View File

@ -12,6 +12,10 @@ module Chat
:mentioned_users, :mentioned_users,
:user :user
def excerpt
object.excerpt || object.build_excerpt
end
def mentioned_users def mentioned_users
object object
.user_mentions .user_mentions

View File

@ -28,7 +28,7 @@ module Chat
end end
def last_reply_excerpt def last_reply_excerpt
object.last_message.excerpt object.last_message.excerpt || object.last_message.build_excerpt
end end
def last_reply_user def last_reply_user

View File

@ -9,9 +9,9 @@ describe Chat::NullMessage do
end end
end end
describe "#excerpt" do describe "#build_excerpt" do
it "returns nil" do it "returns nil" do
expect(null_message.excerpt(max_length: 1)).to be_nil expect(null_message.build_excerpt).to be_nil
end end
end end

View File

@ -137,6 +137,15 @@ describe "Thread indicator for chat messages", type: :system do
).to have_content(thread_excerpt(thread_1.last_message.reload)) ).to have_content(thread_excerpt(thread_1.last_message.reload))
end end
it "builds an excerpt for the last reply if it doesnt have one" do
thread_1.last_message.update!(excerpt: nil)
chat_page.visit_channel(channel)
expect(
channel_page.message_thread_indicator(thread_1.original_message).excerpt,
).to have_content(thread_1.last_message.build_excerpt)
end
it "updates the last reply excerpt and participants when a new message is added to the thread" do it "updates the last reply excerpt and participants when a new message is added to the thread" do
new_user = Fabricate(:user) new_user = Fabricate(:user)
chat_system_user_bootstrap(user: new_user, channel: channel) chat_system_user_bootstrap(user: new_user, channel: channel)

View File

@ -111,6 +111,15 @@ describe "Thread list in side panel | full page", type: :system do
) )
end end
it "builds an excerpt for the original message if it doesnt have one" do
thread_1.original_message.update!(excerpt: nil)
chat_page.visit_threads_list(channel)
expect(thread_list_page.item_by_id(thread_1.id)).to have_content(
thread_1.original_message.build_excerpt,
)
end
it "doesnt show the thread original message user avatar" do it "doesnt show the thread original message user avatar" do
chat_page.visit_threads_list(channel) chat_page.visit_threads_list(channel)