DEV: fix and enable flaky specs (#21753)
These specs were disabled in 786f7503
. While investigating this, I found out that at some point `:user_membership` got deleted. It's hard to tell why exactly without investing more time, but it seems using `let!` instead of `fab!` solves the issue.
If in the future we decide to investigate why these tests were flaky with `fab!` to reproduce the failure run:
LOAD_PLUGINS=1 rspec --seed 46586 plugins/chat/spec/mailers/user_notifications_spec.rb
This commit is contained in:
parent
deda61b3a4
commit
6491be9f2b
|
@ -149,7 +149,8 @@ describe UserNotifications do
|
||||||
context "with public channel" do
|
context "with public channel" do
|
||||||
fab!(:channel) { Fabricate(:category_channel) }
|
fab!(:channel) { Fabricate(:category_channel) }
|
||||||
fab!(:chat_message) { Fabricate(:chat_message, user: sender, chat_channel: channel) }
|
fab!(:chat_message) { Fabricate(:chat_message, user: sender, chat_channel: channel) }
|
||||||
fab!(:user_membership) do
|
# using fab! for user_membership below makes these specs flaky
|
||||||
|
let!(:user_membership) do
|
||||||
Fabricate(
|
Fabricate(
|
||||||
:user_chat_channel_membership,
|
:user_chat_channel_membership,
|
||||||
chat_channel: channel,
|
chat_channel: channel,
|
||||||
|
@ -164,71 +165,71 @@ describe UserNotifications do
|
||||||
expect(email.to).to be_blank
|
expect(email.to).to be_blank
|
||||||
end
|
end
|
||||||
|
|
||||||
# context "with channel-wide mentions" do
|
context "with channel-wide mentions" do
|
||||||
# before { Jobs.run_immediately! }
|
before { Jobs.run_immediately! }
|
||||||
|
|
||||||
# def create_chat_message_with_mentions_and_notifications(content)
|
def create_chat_message_with_mentions_and_notifications(content)
|
||||||
# # Sometimes it's not enough to just fabricate a message
|
# Sometimes it's not enough to just fabricate a message
|
||||||
# # and we have to create it like here. In this case all the necessary
|
# and we have to create it like here. In this case all the necessary
|
||||||
# # db records for mentions and notifications will be created under the hood.
|
# db records for mentions and notifications will be created under the hood.
|
||||||
# Chat::MessageCreator.create(chat_channel: channel, user: sender, content: content)
|
Chat::MessageCreator.create(chat_channel: channel, user: sender, content: content)
|
||||||
# end
|
end
|
||||||
|
|
||||||
# it "returns email for @all mention by default" do
|
it "returns email for @all mention by default" do
|
||||||
# create_chat_message_with_mentions_and_notifications("Mentioning @all")
|
create_chat_message_with_mentions_and_notifications("Mentioning @all")
|
||||||
# email = described_class.chat_summary(user, {})
|
email = described_class.chat_summary(user, {})
|
||||||
# expect(email.to).to contain_exactly(user.email)
|
expect(email.to).to contain_exactly(user.email)
|
||||||
# end
|
end
|
||||||
|
|
||||||
# it "returns email for @here mention by default" do
|
it "returns email for @here mention by default" do
|
||||||
# user.update(last_seen_at: 1.second.ago)
|
user.update(last_seen_at: 1.second.ago)
|
||||||
|
|
||||||
# create_chat_message_with_mentions_and_notifications("Mentioning @here")
|
create_chat_message_with_mentions_and_notifications("Mentioning @here")
|
||||||
# email = described_class.chat_summary(user, {})
|
email = described_class.chat_summary(user, {})
|
||||||
|
|
||||||
# expect(email.to).to contain_exactly(user.email)
|
expect(email.to).to contain_exactly(user.email)
|
||||||
# end
|
end
|
||||||
|
|
||||||
# context "when channel-wide mentions are disabled in a channel" do
|
context "when channel-wide mentions are disabled in a channel" do
|
||||||
# before { channel.update!(allow_channel_wide_mentions: false) }
|
before { channel.update!(allow_channel_wide_mentions: false) }
|
||||||
|
|
||||||
# it "doesn't return email for @all mention" do
|
it "doesn't return email for @all mention" do
|
||||||
# create_chat_message_with_mentions_and_notifications("Mentioning @all")
|
create_chat_message_with_mentions_and_notifications("Mentioning @all")
|
||||||
# email = described_class.chat_summary(user, {})
|
email = described_class.chat_summary(user, {})
|
||||||
|
|
||||||
# expect(email.to).to be_blank
|
expect(email.to).to be_blank
|
||||||
# end
|
end
|
||||||
|
|
||||||
# it "doesn't return email for @here mention" do
|
it "doesn't return email for @here mention" do
|
||||||
# user.update(last_seen_at: 1.second.ago)
|
user.update(last_seen_at: 1.second.ago)
|
||||||
|
|
||||||
# create_chat_message_with_mentions_and_notifications("Mentioning @here")
|
create_chat_message_with_mentions_and_notifications("Mentioning @here")
|
||||||
# email = described_class.chat_summary(user, {})
|
email = described_class.chat_summary(user, {})
|
||||||
|
|
||||||
# expect(email.to).to be_blank
|
expect(email.to).to be_blank
|
||||||
# end
|
end
|
||||||
# end
|
end
|
||||||
|
|
||||||
# context "when user has disabled channel-wide mentions" do
|
context "when user has disabled channel-wide mentions" do
|
||||||
# before { user.user_option.update!(ignore_channel_wide_mention: true) }
|
before { user.user_option.update!(ignore_channel_wide_mention: true) }
|
||||||
|
|
||||||
# it "doesn't return email for @all mention" do
|
it "doesn't return email for @all mention" do
|
||||||
# create_chat_message_with_mentions_and_notifications("Mentioning @all")
|
create_chat_message_with_mentions_and_notifications("Mentioning @all")
|
||||||
# email = described_class.chat_summary(user, {})
|
email = described_class.chat_summary(user, {})
|
||||||
|
|
||||||
# expect(email.to).to be_blank
|
expect(email.to).to be_blank
|
||||||
# end
|
end
|
||||||
|
|
||||||
# it "doesn't return email for @here mention" do
|
it "doesn't return email for @here mention" do
|
||||||
# user.update(last_seen_at: 1.second.ago)
|
user.update(last_seen_at: 1.second.ago)
|
||||||
|
|
||||||
# create_chat_message_with_mentions_and_notifications("Mentioning @here")
|
create_chat_message_with_mentions_and_notifications("Mentioning @here")
|
||||||
# email = described_class.chat_summary(user, {})
|
email = described_class.chat_summary(user, {})
|
||||||
|
|
||||||
# expect(email.to).to be_blank
|
expect(email.to).to be_blank
|
||||||
# end
|
end
|
||||||
# end
|
end
|
||||||
# end
|
end
|
||||||
|
|
||||||
describe "email subject" do
|
describe "email subject" do
|
||||||
context "with regular mentions" do
|
context "with regular mentions" do
|
||||||
|
|
Loading…
Reference in New Issue