2023-04-11 21:09:06 -04:00
|
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
2023-06-06 21:26:58 -04:00
|
|
|
|
describe "Thread indicator for chat messages", type: :system do
|
2023-04-11 21:09:06 -04:00
|
|
|
|
fab!(:current_user) { Fabricate(:user) }
|
|
|
|
|
fab!(:other_user) { Fabricate(:user) }
|
|
|
|
|
|
|
|
|
|
let(:chat_page) { PageObjects::Pages::Chat.new }
|
|
|
|
|
let(:channel_page) { PageObjects::Pages::ChatChannel.new }
|
|
|
|
|
let(:side_panel) { PageObjects::Pages::ChatSidePanel.new }
|
|
|
|
|
let(:open_thread) { PageObjects::Pages::ChatThread.new }
|
|
|
|
|
|
|
|
|
|
before do
|
|
|
|
|
chat_system_bootstrap(current_user, [channel])
|
|
|
|
|
sign_in(current_user)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "when threading_enabled is false for the channel" do
|
|
|
|
|
fab!(:channel) { Fabricate(:chat_channel) }
|
2023-07-26 06:46:23 -04:00
|
|
|
|
before { channel.update!(threading_enabled: false) }
|
2023-04-11 21:09:06 -04:00
|
|
|
|
|
|
|
|
|
it "shows no thread inidcators in the channel" do
|
|
|
|
|
thread = chat_thread_chain_bootstrap(channel: channel, users: [current_user, other_user])
|
|
|
|
|
chat_page.visit_channel(channel)
|
2023-05-04 20:16:23 -04:00
|
|
|
|
expect(channel_page).to have_no_thread_indicator(thread.original_message)
|
2023-04-11 21:09:06 -04:00
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2023-07-26 06:46:23 -04:00
|
|
|
|
context "when threading is enabled for the channel" do
|
2023-04-11 21:09:06 -04:00
|
|
|
|
fab!(:channel) { Fabricate(:chat_channel) }
|
|
|
|
|
fab!(:thread_1) do
|
|
|
|
|
chat_thread_chain_bootstrap(channel: channel, users: [current_user, other_user])
|
|
|
|
|
end
|
|
|
|
|
fab!(:thread_2) do
|
|
|
|
|
chat_thread_chain_bootstrap(
|
|
|
|
|
channel: channel,
|
|
|
|
|
users: [current_user, other_user],
|
|
|
|
|
messages_count: 2,
|
|
|
|
|
)
|
|
|
|
|
end
|
|
|
|
|
|
2023-07-26 06:46:23 -04:00
|
|
|
|
before { channel.update!(threading_enabled: true) }
|
2023-04-11 21:09:06 -04:00
|
|
|
|
|
|
|
|
|
it "throws thread indicators on all original messages" do
|
|
|
|
|
chat_page.visit_channel(channel)
|
|
|
|
|
expect(channel_page).to have_thread_indicator(thread_1.original_message)
|
|
|
|
|
expect(channel_page).to have_thread_indicator(thread_2.original_message)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
it "shows the correct reply counts" do
|
|
|
|
|
chat_page.visit_channel(channel)
|
2023-06-14 20:49:27 -04:00
|
|
|
|
expect(channel_page.message_thread_indicator(thread_1.original_message)).to have_reply_count(
|
|
|
|
|
3,
|
2023-04-11 21:09:06 -04:00
|
|
|
|
)
|
2023-06-14 20:49:27 -04:00
|
|
|
|
expect(channel_page.message_thread_indicator(thread_2.original_message)).to have_reply_count(
|
|
|
|
|
1,
|
2023-04-11 21:09:06 -04:00
|
|
|
|
)
|
|
|
|
|
end
|
|
|
|
|
|
2023-07-06 00:31:18 -04:00
|
|
|
|
it "it shows the reply count but no participant avatars when there is only one participant" do
|
|
|
|
|
single_user_thread =
|
2023-08-24 09:22:51 -04:00
|
|
|
|
chat_thread_chain_bootstrap(channel: channel, users: [current_user], messages_count: 3)
|
|
|
|
|
|
2023-07-06 00:31:18 -04:00
|
|
|
|
chat_page.visit_channel(channel)
|
|
|
|
|
expect(
|
|
|
|
|
channel_page.message_thread_indicator(single_user_thread.original_message),
|
|
|
|
|
).to have_reply_count(2)
|
|
|
|
|
expect(
|
|
|
|
|
channel_page.message_thread_indicator(single_user_thread.original_message),
|
|
|
|
|
).to have_no_participants
|
|
|
|
|
end
|
|
|
|
|
|
2023-04-11 21:09:06 -04:00
|
|
|
|
it "clicking a thread indicator opens the thread panel" do
|
|
|
|
|
chat_page.visit_channel(channel)
|
|
|
|
|
channel_page.message_thread_indicator(thread_1.original_message).click
|
|
|
|
|
expect(side_panel).to have_open_thread(thread_1)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
it "shows the thread indicator and hides the sent message when a user first replies to a message without a thread" do
|
|
|
|
|
message_without_thread = Fabricate(:chat_message, chat_channel: channel, user: other_user)
|
|
|
|
|
chat_page.visit_channel(channel)
|
|
|
|
|
channel_page.reply_to(message_without_thread)
|
2023-05-05 02:55:55 -04:00
|
|
|
|
open_thread.fill_composer("this is a reply to make a new thread")
|
|
|
|
|
open_thread.click_send_message
|
2023-04-25 04:23:03 -04:00
|
|
|
|
|
2023-04-11 21:09:06 -04:00
|
|
|
|
expect(channel_page).to have_thread_indicator(message_without_thread)
|
2023-04-25 04:23:03 -04:00
|
|
|
|
|
|
|
|
|
new_thread = nil
|
|
|
|
|
try_until_success(timeout: 5) do
|
|
|
|
|
new_thread = message_without_thread.reload.thread
|
|
|
|
|
expect(new_thread).to be_present
|
|
|
|
|
end
|
|
|
|
|
|
2023-04-11 21:09:06 -04:00
|
|
|
|
expect(page).not_to have_css(channel_page.message_by_id_selector(new_thread.replies.first))
|
|
|
|
|
end
|
2023-04-13 08:45:50 -04:00
|
|
|
|
|
|
|
|
|
it "increments the indicator when a new reply is sent in the thread" do
|
|
|
|
|
chat_page.visit_channel(channel)
|
2023-05-30 12:37:30 -04:00
|
|
|
|
|
2023-06-14 20:49:27 -04:00
|
|
|
|
expect(channel_page.message_thread_indicator(thread_1.original_message)).to have_reply_count(
|
|
|
|
|
3,
|
2023-04-13 08:45:50 -04:00
|
|
|
|
)
|
2023-05-30 12:37:30 -04:00
|
|
|
|
|
2023-04-13 08:45:50 -04:00
|
|
|
|
channel_page.message_thread_indicator(thread_1.original_message).click
|
2023-05-30 12:37:30 -04:00
|
|
|
|
|
2023-04-13 08:45:50 -04:00
|
|
|
|
expect(side_panel).to have_open_thread(thread_1)
|
2023-05-30 12:37:30 -04:00
|
|
|
|
|
|
|
|
|
open_thread.send_message
|
|
|
|
|
|
2023-06-14 20:49:27 -04:00
|
|
|
|
expect(channel_page.message_thread_indicator(thread_1.original_message)).to have_reply_count(
|
|
|
|
|
4,
|
|
|
|
|
)
|
|
|
|
|
end
|
|
|
|
|
|
2023-07-06 00:31:18 -04:00
|
|
|
|
it "shows avatars for the participants of the thread" do
|
2023-06-14 20:49:27 -04:00
|
|
|
|
chat_page.visit_channel(channel)
|
|
|
|
|
expect(channel_page.message_thread_indicator(thread_1.original_message)).to have_participant(
|
|
|
|
|
current_user,
|
|
|
|
|
)
|
|
|
|
|
expect(channel_page.message_thread_indicator(thread_1.original_message)).to have_participant(
|
|
|
|
|
other_user,
|
|
|
|
|
)
|
|
|
|
|
end
|
|
|
|
|
|
2023-06-27 23:14:01 -04:00
|
|
|
|
it "shows an excerpt of the last reply in the thread" do
|
2023-11-07 05:34:35 -05:00
|
|
|
|
update_message!(
|
2023-11-06 09:45:30 -05:00
|
|
|
|
thread_1.original_message,
|
|
|
|
|
user: thread_1.original_message.user,
|
|
|
|
|
text: "test for excerpt",
|
|
|
|
|
)
|
2023-06-27 23:14:01 -04:00
|
|
|
|
|
2023-06-14 20:49:27 -04:00
|
|
|
|
chat_page.visit_channel(channel)
|
2023-11-06 09:45:30 -05:00
|
|
|
|
|
2023-06-15 22:08:26 -04:00
|
|
|
|
expect(
|
2023-11-06 09:45:30 -05:00
|
|
|
|
channel_page.message_thread_indicator(thread_1.original_message.reload).excerpt,
|
|
|
|
|
).to have_content(thread_excerpt(thread_1.last_message.reload))
|
2023-06-14 20:49:27 -04:00
|
|
|
|
end
|
|
|
|
|
|
2024-04-26 02:29:35 -04:00
|
|
|
|
it "builds an excerpt for the last reply if it doesn’t 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
|
|
|
|
|
|
2023-06-27 23:14:01 -04:00
|
|
|
|
it "updates the last reply excerpt and participants when a new message is added to the thread" do
|
2023-06-14 20:49:27 -04:00
|
|
|
|
new_user = Fabricate(:user)
|
|
|
|
|
chat_system_user_bootstrap(user: new_user, channel: channel)
|
2023-07-12 20:28:11 -04:00
|
|
|
|
original_last_reply = thread_1.last_message
|
2023-11-07 05:34:35 -05:00
|
|
|
|
update_message!(original_last_reply, user: original_last_reply.user, text: "test for excerpt")
|
2023-06-14 20:49:27 -04:00
|
|
|
|
|
|
|
|
|
chat_page.visit_channel(channel)
|
|
|
|
|
|
2023-11-06 09:45:30 -05:00
|
|
|
|
excerpt_text = thread_excerpt(original_last_reply.reload)
|
2023-06-15 22:08:26 -04:00
|
|
|
|
|
|
|
|
|
expect(channel_page.message_thread_indicator(thread_1.original_message)).to have_content(
|
|
|
|
|
excerpt_text,
|
2023-06-14 20:49:27 -04:00
|
|
|
|
)
|
|
|
|
|
|
2023-11-06 09:45:30 -05:00
|
|
|
|
new_message =
|
|
|
|
|
Fabricate(
|
|
|
|
|
:chat_message,
|
|
|
|
|
chat_channel: channel,
|
|
|
|
|
thread: thread_1,
|
|
|
|
|
user: new_user,
|
|
|
|
|
in_reply_to: thread_1.original_message,
|
|
|
|
|
use_service: true,
|
|
|
|
|
)
|
2023-06-14 20:49:27 -04:00
|
|
|
|
|
|
|
|
|
expect(channel_page.message_thread_indicator(thread_1.original_message)).to have_participant(
|
|
|
|
|
new_user,
|
|
|
|
|
)
|
2023-06-15 22:08:26 -04:00
|
|
|
|
expect(
|
|
|
|
|
channel_page.message_thread_indicator(thread_1.original_message).excerpt,
|
2023-11-06 09:45:30 -05:00
|
|
|
|
).to have_content(thread_excerpt(new_message))
|
2023-04-13 08:45:50 -04:00
|
|
|
|
end
|
2023-04-11 21:09:06 -04:00
|
|
|
|
end
|
|
|
|
|
end
|