2023-07-05 12:18:27 -04:00
|
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
|
|
RSpec.describe "New message", type: :system do
|
|
|
|
|
fab!(:current_user) { Fabricate(:admin) }
|
|
|
|
|
|
|
|
|
|
let(:chat_page) { PageObjects::Pages::Chat.new }
|
|
|
|
|
|
|
|
|
|
before do
|
|
|
|
|
# simpler user search without having to worry about user search data
|
|
|
|
|
SiteSetting.enable_names = false
|
|
|
|
|
|
|
|
|
|
chat_system_bootstrap
|
|
|
|
|
sign_in(current_user)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
it "cmd + k opens new message" do
|
|
|
|
|
visit("/")
|
|
|
|
|
chat_page.open_new_message
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_opened
|
|
|
|
|
end
|
|
|
|
|
|
2023-07-13 04:00:25 -04:00
|
|
|
|
context "when public channels are disabled" do
|
|
|
|
|
fab!(:channel_1) { Fabricate(:chat_channel) }
|
|
|
|
|
|
|
|
|
|
before do
|
|
|
|
|
SiteSetting.enable_public_channels = false
|
|
|
|
|
channel_1.add(current_user)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
it "doesn’t list public channels" do
|
|
|
|
|
visit("/")
|
|
|
|
|
chat_page.open_new_message
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_not_listing(channel_1)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
it "has a correct placeholder" do
|
|
|
|
|
visit("/")
|
|
|
|
|
chat_page.open_new_message
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator.input["placeholder"]).to eq(
|
|
|
|
|
I18n.t("js.chat.new_message_modal.default_user_search_placeholder"),
|
|
|
|
|
)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "when public channels are disabled and user can't create direct message" do
|
|
|
|
|
fab!(:current_user) { Fabricate(:user) }
|
|
|
|
|
|
|
|
|
|
before do
|
|
|
|
|
SiteSetting.enable_public_channels = false
|
|
|
|
|
SiteSetting.direct_message_enabled_groups = Group::AUTO_GROUPS[:staff]
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
it "doesn’t list public channels" do
|
|
|
|
|
visit("/")
|
|
|
|
|
chat_page.open_new_message(ensure_open: false)
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_closed
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2023-07-05 12:18:27 -04:00
|
|
|
|
context "when the the content is not filtered" do
|
|
|
|
|
fab!(:channel_1) { Fabricate(:chat_channel) }
|
|
|
|
|
fab!(:channel_2) { Fabricate(:chat_channel) }
|
|
|
|
|
fab!(:user_1) { Fabricate(:user) }
|
|
|
|
|
fab!(:user_2) { Fabricate(:user) }
|
|
|
|
|
fab!(:direct_message_channel_1) do
|
|
|
|
|
Fabricate(:direct_message_channel, users: [current_user, user_1])
|
|
|
|
|
end
|
|
|
|
|
fab!(:direct_message_channel_2) { Fabricate(:direct_message_channel, users: [user_1, user_2]) }
|
|
|
|
|
|
|
|
|
|
before { channel_1.add(current_user) }
|
|
|
|
|
|
|
|
|
|
it "lists channels the user is following" do
|
|
|
|
|
visit("/")
|
|
|
|
|
chat_page.open_new_message
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_listing(channel_1)
|
|
|
|
|
expect(chat_page.message_creator).to be_not_listing(channel_2)
|
2023-07-05 15:01:23 -04:00
|
|
|
|
expect(chat_page.message_creator).to be_not_listing(direct_message_channel_2)
|
2023-07-05 12:18:27 -04:00
|
|
|
|
expect(chat_page.message_creator).to be_listing(user_1)
|
|
|
|
|
expect(chat_page.message_creator).to be_not_listing(user_2)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "with no selection" do
|
2023-07-05 15:01:23 -04:00
|
|
|
|
context "with unread state" do
|
|
|
|
|
fab!(:user_1) { Fabricate(:user) }
|
|
|
|
|
fab!(:channel_1) { Fabricate(:chat_channel) }
|
|
|
|
|
fab!(:channel_2) { Fabricate(:direct_message_channel, users: [current_user, user_1]) }
|
|
|
|
|
|
|
|
|
|
before do
|
|
|
|
|
channel_1.add(user_1)
|
|
|
|
|
channel_1.add(current_user)
|
|
|
|
|
Fabricate(:chat_message, chat_channel: channel_1, user: user_1)
|
|
|
|
|
Fabricate(:chat_message, chat_channel: channel_2, user: user_1)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
it "shows the correct state" do
|
|
|
|
|
visit("/")
|
|
|
|
|
chat_page.open_new_message
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to have_unread_row(channel_1, urgent: false)
|
|
|
|
|
expect(chat_page.message_creator).to have_unread_row(user_1, urgent: true)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2023-07-05 12:18:27 -04:00
|
|
|
|
context "when clicking a row" do
|
|
|
|
|
context "when the row is a channel" do
|
|
|
|
|
fab!(:channel_1) { Fabricate(:chat_channel) }
|
|
|
|
|
|
|
|
|
|
before { channel_1.add(current_user) }
|
|
|
|
|
|
|
|
|
|
it "opens the channel" do
|
|
|
|
|
visit("/")
|
|
|
|
|
chat_page.open_new_message
|
|
|
|
|
chat_page.message_creator.click_row(channel_1)
|
|
|
|
|
|
|
|
|
|
expect(chat_page).to have_drawer(channel_id: channel_1.id)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "when the row is a user" do
|
|
|
|
|
fab!(:user_1) { Fabricate(:user) }
|
|
|
|
|
fab!(:channel_1) { Fabricate(:direct_message_channel, users: [current_user, user_1]) }
|
|
|
|
|
|
|
|
|
|
it "opens the channel" do
|
|
|
|
|
visit("/")
|
|
|
|
|
chat_page.open_new_message
|
|
|
|
|
chat_page.message_creator.click_row(user_1)
|
|
|
|
|
|
|
|
|
|
expect(chat_page).to have_drawer(channel_id: channel_1.id)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "when shift clicking a row" do
|
|
|
|
|
context "when the row is a channel" do
|
|
|
|
|
fab!(:channel_1) { Fabricate(:chat_channel) }
|
|
|
|
|
|
|
|
|
|
before { channel_1.add(current_user) }
|
|
|
|
|
|
|
|
|
|
it "opens the channel" do
|
|
|
|
|
visit("/")
|
|
|
|
|
chat_page.open_new_message
|
|
|
|
|
chat_page.message_creator.shift_click_row(channel_1)
|
|
|
|
|
|
|
|
|
|
expect(chat_page).to have_drawer(channel_id: channel_1.id)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "when the row is a user" do
|
|
|
|
|
fab!(:user_1) { Fabricate(:user) }
|
|
|
|
|
fab!(:channel_1) { Fabricate(:direct_message_channel, users: [current_user, user_1]) }
|
|
|
|
|
|
|
|
|
|
it "adds the user" do
|
|
|
|
|
visit("/")
|
|
|
|
|
chat_page.open_new_message
|
|
|
|
|
chat_page.message_creator.shift_click_row(user_1)
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_selecting(user_1)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "when pressing enter" do
|
|
|
|
|
context "when the row is a channel" do
|
|
|
|
|
fab!(:channel_1) { Fabricate(:chat_channel) }
|
|
|
|
|
|
|
|
|
|
before { channel_1.add(current_user) }
|
|
|
|
|
|
|
|
|
|
it "opens the channel" do
|
|
|
|
|
visit("/")
|
|
|
|
|
chat_page.open_new_message
|
|
|
|
|
chat_page.message_creator.click_row(channel_1)
|
|
|
|
|
|
|
|
|
|
expect(chat_page).to have_drawer(channel_id: channel_1.id)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "when the row is a user" do
|
|
|
|
|
fab!(:user_1) { Fabricate(:user) }
|
|
|
|
|
fab!(:channel_1) { Fabricate(:direct_message_channel, users: [current_user, user_1]) }
|
|
|
|
|
|
|
|
|
|
it "opens the channel" do
|
|
|
|
|
visit("/")
|
|
|
|
|
chat_page.open_new_message
|
|
|
|
|
chat_page.message_creator.click_row(user_1)
|
|
|
|
|
|
|
|
|
|
expect(chat_page).to have_drawer(channel_id: channel_1.id)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "when pressing shift+enter" do
|
|
|
|
|
context "when the row is a channel" do
|
|
|
|
|
fab!(:channel_1) { Fabricate(:chat_channel) }
|
|
|
|
|
|
|
|
|
|
before { channel_1.add(current_user) }
|
|
|
|
|
|
|
|
|
|
it "opens the channel" do
|
|
|
|
|
visit("/")
|
|
|
|
|
chat_page.open_new_message
|
|
|
|
|
chat_page.message_creator.shift_enter_shortcut
|
|
|
|
|
|
|
|
|
|
expect(chat_page).to have_drawer(channel_id: channel_1.id)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "when the row is a user" do
|
|
|
|
|
fab!(:user_1) { Fabricate(:user) }
|
|
|
|
|
fab!(:channel_1) { Fabricate(:direct_message_channel, users: [current_user, user_1]) }
|
|
|
|
|
|
|
|
|
|
it "adds the user" do
|
|
|
|
|
visit("/")
|
|
|
|
|
chat_page.open_new_message
|
|
|
|
|
chat_page.message_creator.shift_enter_shortcut
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_selecting(user_1)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "when navigating content with arrows" do
|
|
|
|
|
fab!(:channel_1) { Fabricate(:chat_channel, name: "channela") }
|
|
|
|
|
fab!(:channel_2) { Fabricate(:chat_channel, name: "channelb") }
|
|
|
|
|
|
|
|
|
|
before do
|
|
|
|
|
channel_1.add(current_user)
|
|
|
|
|
channel_2.add(current_user)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
it "changes active content" do
|
|
|
|
|
visit("/")
|
|
|
|
|
chat_page.open_new_message
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_listing(channel_1, active: true)
|
|
|
|
|
|
|
|
|
|
chat_page.message_creator.arrow_down_shortcut
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_listing(channel_2, active: true)
|
|
|
|
|
|
|
|
|
|
chat_page.message_creator.arrow_down_shortcut
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_listing(channel_1, active: true)
|
|
|
|
|
|
|
|
|
|
chat_page.message_creator.arrow_up_shortcut
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_listing(channel_2, active: true)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "with disabled content" do
|
|
|
|
|
fab!(:user_1) { Fabricate(:user) }
|
|
|
|
|
fab!(:channel_1) { Fabricate(:direct_message_channel, users: [current_user, user_1]) }
|
|
|
|
|
|
|
|
|
|
before { user_1.user_option.update!(chat_enabled: false) }
|
|
|
|
|
|
|
|
|
|
it "doesn’t make the content active" do
|
|
|
|
|
visit("/")
|
|
|
|
|
chat_page.open_new_message
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_listing(user_1, inactive: true, disabled: true)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "when filtering" do
|
|
|
|
|
fab!(:channel_1) { Fabricate(:chat_channel, name: "bob-channel") }
|
|
|
|
|
fab!(:user_1) { Fabricate(:user, username: "bob-user") }
|
|
|
|
|
fab!(:user_2) { Fabricate(:user) }
|
|
|
|
|
fab!(:channel_2) { Fabricate(:direct_message_channel, users: [current_user, user_1]) }
|
|
|
|
|
fab!(:channel_3) { Fabricate(:direct_message_channel, users: [current_user, user_1, user_2]) }
|
|
|
|
|
|
|
|
|
|
before { channel_1.add(current_user) }
|
|
|
|
|
|
2023-07-05 15:12:39 -04:00
|
|
|
|
context "when query is the name of the category" do
|
|
|
|
|
fab!(:category) { Fabricate(:category, name: "dev") }
|
|
|
|
|
fab!(:channel_1) { Fabricate(:category_channel, chatable: category, name: "something dev") }
|
|
|
|
|
fab!(:channel_2) { Fabricate(:category_channel, chatable: category, name: "something else") }
|
|
|
|
|
|
|
|
|
|
it "favors the channel name" do
|
|
|
|
|
visit("/")
|
|
|
|
|
chat_page.open_new_message
|
|
|
|
|
|
|
|
|
|
chat_page.message_creator.filter("dev")
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_listing(channel_1)
|
|
|
|
|
expect(chat_page.message_creator).to be_not_listing(channel_2)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
2023-07-05 12:18:27 -04:00
|
|
|
|
context "with no prefix" do
|
|
|
|
|
it "lists all matching content" do
|
|
|
|
|
visit("/")
|
|
|
|
|
chat_page.open_new_message
|
|
|
|
|
|
|
|
|
|
chat_page.message_creator.filter("bob")
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_listing(channel_1)
|
|
|
|
|
expect(chat_page.message_creator).to be_not_listing(channel_2)
|
|
|
|
|
expect(chat_page.message_creator).to be_listing(channel_3)
|
|
|
|
|
expect(chat_page.message_creator).to be_listing(user_1)
|
|
|
|
|
expect(chat_page.message_creator).to be_not_listing(user_2)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "with channel prefix" do
|
|
|
|
|
it "lists matching channel" do
|
|
|
|
|
visit("/")
|
|
|
|
|
chat_page.open_new_message
|
|
|
|
|
|
|
|
|
|
chat_page.message_creator.filter("#bob")
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_listing(channel_1)
|
|
|
|
|
expect(chat_page.message_creator).to be_not_listing(channel_2)
|
|
|
|
|
expect(chat_page.message_creator).to be_listing(channel_3)
|
|
|
|
|
expect(chat_page.message_creator).to be_not_listing(user_1)
|
|
|
|
|
expect(chat_page.message_creator).to be_not_listing(user_2)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "with user prefix" do
|
|
|
|
|
it "lists matching users" do
|
|
|
|
|
visit("/")
|
|
|
|
|
chat_page.open_new_message
|
|
|
|
|
|
|
|
|
|
chat_page.message_creator.filter("@bob")
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_not_listing(channel_1)
|
|
|
|
|
expect(chat_page.message_creator).to be_not_listing(channel_2)
|
|
|
|
|
expect(chat_page.message_creator).to be_not_listing(channel_3)
|
|
|
|
|
expect(chat_page.message_creator).to be_listing(user_1)
|
|
|
|
|
expect(chat_page.message_creator).to be_not_listing(user_2)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "with selection" do
|
|
|
|
|
fab!(:channel_1) { Fabricate(:chat_channel, name: "bob-channel") }
|
|
|
|
|
fab!(:user_1) { Fabricate(:user, username: "bob-user") }
|
|
|
|
|
fab!(:user_2) { Fabricate(:user, username: "bobby-user") }
|
|
|
|
|
fab!(:user_3) { Fabricate(:user, username: "sam-user") }
|
|
|
|
|
fab!(:channel_2) { Fabricate(:direct_message_channel, users: [current_user, user_1]) }
|
|
|
|
|
fab!(:channel_3) { Fabricate(:direct_message_channel, users: [current_user, user_2]) }
|
|
|
|
|
|
|
|
|
|
before do
|
|
|
|
|
channel_1.add(current_user)
|
|
|
|
|
visit("/")
|
|
|
|
|
chat_page.open_new_message
|
|
|
|
|
chat_page.message_creator.shift_click_row(user_1)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "when pressing enter" do
|
|
|
|
|
it "opens the channel" do
|
|
|
|
|
chat_page.message_creator.enter_shortcut
|
|
|
|
|
|
|
|
|
|
expect(chat_page).to have_drawer(channel_id: channel_2.id)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "when clicking cta" do
|
|
|
|
|
it "opens the channel" do
|
|
|
|
|
chat_page.message_creator.click_cta
|
|
|
|
|
|
|
|
|
|
expect(chat_page).to have_drawer(channel_id: channel_2.id)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "when filtering" do
|
|
|
|
|
it "shows only matching users regarless of prefix" do
|
|
|
|
|
chat_page.message_creator.filter("#bob")
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_listing(user_1)
|
|
|
|
|
expect(chat_page.message_creator).to be_listing(user_2)
|
|
|
|
|
expect(chat_page.message_creator).to be_not_listing(user_3)
|
|
|
|
|
expect(chat_page.message_creator).to be_not_listing(channel_1)
|
|
|
|
|
expect(chat_page.message_creator).to be_not_listing(channel_2)
|
|
|
|
|
expect(chat_page.message_creator).to be_not_listing(channel_3)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
it "shows selected user as selected in content" do
|
|
|
|
|
chat_page.message_creator.filter("@bob")
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_listing(user_1, selected: true)
|
|
|
|
|
expect(chat_page.message_creator).to be_listing(user_2, selected: false)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "when clicking another user" do
|
|
|
|
|
it "adds it to the selection" do
|
|
|
|
|
chat_page.message_creator.filter("@bob")
|
|
|
|
|
chat_page.message_creator.click_row(user_2)
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_selecting(user_1)
|
|
|
|
|
expect(chat_page.message_creator).to be_selecting(user_2)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "when pressing backspace" do
|
|
|
|
|
it "removes it" do
|
|
|
|
|
chat_page.message_creator.backspace_shortcut
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_selecting(user_1, active: true)
|
|
|
|
|
|
|
|
|
|
chat_page.message_creator.backspace_shortcut
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_not_selecting(user_1)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "when navigating selection with arrow left/right" do
|
|
|
|
|
it "changes active item" do
|
|
|
|
|
chat_page.message_creator.filter("@bob")
|
|
|
|
|
chat_page.message_creator.click_row(user_2)
|
|
|
|
|
|
|
|
|
|
chat_page.message_creator.arrow_left_shortcut
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_selecting(user_2, active: true)
|
|
|
|
|
|
|
|
|
|
chat_page.message_creator.arrow_left_shortcut
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_selecting(user_1, active: true)
|
|
|
|
|
|
|
|
|
|
chat_page.message_creator.arrow_left_shortcut
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_selecting(user_2, active: true)
|
|
|
|
|
|
|
|
|
|
chat_page.message_creator.arrow_right_shortcut
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_selecting(user_1, active: true)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context "when clicking selection" do
|
|
|
|
|
it "removes it" do
|
|
|
|
|
chat_page.message_creator.click_item(user_1)
|
|
|
|
|
|
|
|
|
|
expect(chat_page.message_creator).to be_not_selecting(user_1)
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
end
|