2019-04-29 20:27:42 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2016-12-21 23:29:34 -05:00
|
|
|
describe NotificationEmailer do
|
|
|
|
|
|
|
|
before do
|
2020-07-24 05:16:52 -04:00
|
|
|
freeze_time
|
2016-12-21 23:29:34 -05:00
|
|
|
NotificationEmailer.enable
|
|
|
|
end
|
2013-02-05 14:16:51 -05:00
|
|
|
|
2019-05-06 23:12:20 -04:00
|
|
|
fab!(:topic) { Fabricate(:topic) }
|
|
|
|
fab!(:post) { Fabricate(:post, topic: topic) }
|
2016-01-18 19:39:57 -05:00
|
|
|
|
2015-09-23 01:24:30 -04:00
|
|
|
# something is off with fabricator
|
2015-11-24 10:58:26 -05:00
|
|
|
def create_notification(type, user = nil)
|
2015-09-23 01:24:30 -04:00
|
|
|
user ||= Fabricate(:user)
|
2016-07-07 12:23:19 -04:00
|
|
|
Notification.create(data: "{\"a\": 1}",
|
|
|
|
user: user,
|
|
|
|
notification_type: Notification.types[type],
|
|
|
|
topic: topic,
|
|
|
|
post_number: post.post_number)
|
2015-09-23 01:24:30 -04:00
|
|
|
end
|
2013-02-05 14:16:51 -05:00
|
|
|
|
2015-11-24 10:58:26 -05:00
|
|
|
shared_examples "enqueue" do
|
2013-02-05 14:16:51 -05:00
|
|
|
|
|
|
|
it "enqueues a job for the email" do
|
2020-07-24 05:16:52 -04:00
|
|
|
expect_enqueued_with(
|
|
|
|
job: :user_email,
|
|
|
|
args: NotificationEmailer::EmailUser.notification_params(notification, type),
|
2021-01-07 11:49:49 -05:00
|
|
|
at: no_delay ? Time.zone.now : Time.zone.now + delay
|
2020-07-24 05:16:52 -04:00
|
|
|
) do
|
2021-01-07 11:49:49 -05:00
|
|
|
NotificationEmailer.process_notification(notification, no_delay: no_delay)
|
2020-07-24 05:16:52 -04:00
|
|
|
end
|
2013-08-26 00:55:35 -04:00
|
|
|
end
|
|
|
|
|
2015-11-24 10:58:26 -05:00
|
|
|
context "inactive user" do
|
|
|
|
before { notification.user.active = false }
|
|
|
|
|
|
|
|
it "doesn't enqueue a job" do
|
2020-07-24 05:16:52 -04:00
|
|
|
expect_not_enqueued_with(job: :user_email, args: { type: type }) do
|
2021-01-07 11:49:49 -05:00
|
|
|
NotificationEmailer.process_notification(notification, no_delay: no_delay)
|
2020-07-24 05:16:52 -04:00
|
|
|
end
|
2015-11-24 10:58:26 -05:00
|
|
|
end
|
|
|
|
|
2020-03-31 22:12:51 -04:00
|
|
|
it "enqueues a job if the user is staged for non-linked and non-quoted types" do
|
2015-11-24 10:58:26 -05:00
|
|
|
notification.user.staged = true
|
2020-07-24 05:16:52 -04:00
|
|
|
|
2020-03-31 22:12:51 -04:00
|
|
|
if type == :user_linked || type == :user_quoted
|
2020-07-24 05:16:52 -04:00
|
|
|
expect_not_enqueued_with(
|
|
|
|
job: :user_email,
|
|
|
|
args: { type: type }
|
|
|
|
) do
|
2021-01-07 11:49:49 -05:00
|
|
|
NotificationEmailer.process_notification(notification, no_delay: no_delay)
|
2020-07-24 05:16:52 -04:00
|
|
|
end
|
2020-03-31 22:12:51 -04:00
|
|
|
else
|
2020-07-24 05:16:52 -04:00
|
|
|
expect_enqueued_with(
|
|
|
|
job: :user_email,
|
|
|
|
args: NotificationEmailer::EmailUser.notification_params(notification, type),
|
2021-01-07 11:49:49 -05:00
|
|
|
at: no_delay ? Time.zone.now : Time.zone.now + delay
|
2020-07-24 05:16:52 -04:00
|
|
|
) do
|
2021-01-07 11:49:49 -05:00
|
|
|
NotificationEmailer.process_notification(notification, no_delay: no_delay)
|
2020-07-24 05:16:52 -04:00
|
|
|
end
|
2020-03-31 22:12:51 -04:00
|
|
|
end
|
2015-11-24 10:58:26 -05:00
|
|
|
end
|
2017-08-28 17:32:07 -04:00
|
|
|
|
2020-03-31 22:12:51 -04:00
|
|
|
it "enqueues a job if the user is staged even if site requires user approval for non-linked and non-quoted typed" do
|
2017-08-28 17:32:07 -04:00
|
|
|
notification.user.staged = true
|
2020-03-31 22:12:51 -04:00
|
|
|
SiteSetting.must_approve_users = true
|
2020-07-24 05:16:52 -04:00
|
|
|
|
2020-03-31 22:12:51 -04:00
|
|
|
if type == :user_linked || type == :user_quoted
|
2020-07-24 05:16:52 -04:00
|
|
|
expect_not_enqueued_with(
|
|
|
|
job: :user_email,
|
|
|
|
args: { type: type }
|
|
|
|
) do
|
2021-01-07 11:49:49 -05:00
|
|
|
NotificationEmailer.process_notification(notification, no_delay: no_delay)
|
2020-07-24 05:16:52 -04:00
|
|
|
end
|
2020-03-31 22:12:51 -04:00
|
|
|
else
|
2020-07-24 05:16:52 -04:00
|
|
|
expect_enqueued_with(
|
|
|
|
job: :user_email,
|
|
|
|
args: NotificationEmailer::EmailUser.notification_params(notification, type),
|
2021-01-07 11:49:49 -05:00
|
|
|
at: no_delay ? Time.zone.now : Time.zone.now + delay
|
2020-07-24 05:16:52 -04:00
|
|
|
) do
|
2021-01-07 11:49:49 -05:00
|
|
|
NotificationEmailer.process_notification(notification, no_delay: no_delay)
|
2020-07-24 05:16:52 -04:00
|
|
|
end
|
2020-03-31 22:12:51 -04:00
|
|
|
end
|
2017-08-28 17:32:07 -04:00
|
|
|
end
|
2016-06-16 12:55:47 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
context "active but unapproved user" do
|
|
|
|
before do
|
|
|
|
SiteSetting.must_approve_users = true
|
|
|
|
notification.user.approved = false
|
|
|
|
notification.user.active = true
|
|
|
|
end
|
2013-02-05 14:16:51 -05:00
|
|
|
|
2016-06-16 12:55:47 -04:00
|
|
|
it "doesn't enqueue a job" do
|
2020-07-24 05:16:52 -04:00
|
|
|
expect_not_enqueued_with(job: :user_email, args: { type: type }) do
|
2021-01-07 11:49:49 -05:00
|
|
|
NotificationEmailer.process_notification(notification, no_delay: no_delay)
|
2020-07-24 05:16:52 -04:00
|
|
|
end
|
2016-06-16 12:55:47 -04:00
|
|
|
end
|
2015-08-31 01:54:37 -04:00
|
|
|
end
|
|
|
|
|
2016-01-18 19:39:57 -05:00
|
|
|
context "small action" do
|
|
|
|
|
|
|
|
it "doesn't enqueue a job" do
|
|
|
|
Post.any_instance.expects(:post_type).returns(Post.types[:small_action])
|
2020-07-24 05:16:52 -04:00
|
|
|
|
|
|
|
expect_not_enqueued_with(job: :user_email, args: { type: type }) do
|
2021-01-07 11:49:49 -05:00
|
|
|
NotificationEmailer.process_notification(notification, no_delay: no_delay)
|
2020-07-24 05:16:52 -04:00
|
|
|
end
|
2016-01-18 19:39:57 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|
|
|
|
|
2015-11-24 10:58:26 -05:00
|
|
|
shared_examples "enqueue_public" do
|
|
|
|
include_examples "enqueue"
|
2013-02-27 15:38:44 -05:00
|
|
|
|
2015-11-24 10:58:26 -05:00
|
|
|
it "doesn't enqueue a job if the user has mention emails disabled" do
|
2019-03-15 10:55:11 -04:00
|
|
|
notification.user.user_option.update_columns(email_level: UserOption.email_level_types[:never])
|
2020-07-24 05:16:52 -04:00
|
|
|
|
|
|
|
expect_not_enqueued_with(job: :user_email, args: { type: type }) do
|
2021-01-07 11:49:49 -05:00
|
|
|
NotificationEmailer.process_notification(notification, no_delay: no_delay)
|
2020-07-24 05:16:52 -04:00
|
|
|
end
|
2013-02-27 15:38:44 -05:00
|
|
|
end
|
2015-11-24 10:58:26 -05:00
|
|
|
end
|
2013-02-27 15:38:44 -05:00
|
|
|
|
2015-11-24 10:58:26 -05:00
|
|
|
shared_examples "enqueue_private" do
|
|
|
|
include_examples "enqueue"
|
2013-02-27 15:38:44 -05:00
|
|
|
|
2015-11-24 10:58:26 -05:00
|
|
|
it "doesn't enqueue a job if the user has private message emails disabled" do
|
2019-03-15 10:55:11 -04:00
|
|
|
notification.user.user_option.update_columns(email_messages_level: UserOption.email_level_types[:never])
|
2020-07-24 05:16:52 -04:00
|
|
|
|
|
|
|
expect_not_enqueued_with(job: :user_email, args: { type: type }) do
|
|
|
|
NotificationEmailer.process_notification(notification)
|
|
|
|
end
|
2015-08-31 01:54:37 -04:00
|
|
|
end
|
2016-02-01 13:12:10 -05:00
|
|
|
|
2013-02-27 15:38:44 -05:00
|
|
|
end
|
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
[true, false].each do |no_delay|
|
2013-02-05 14:16:51 -05:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
context 'user_mentioned' do
|
|
|
|
let(:no_delay) { no_delay }
|
|
|
|
let(:type) { :user_mentioned }
|
|
|
|
let(:delay) { SiteSetting.email_time_window_mins.minutes }
|
|
|
|
let!(:notification) { create_notification(:mentioned) }
|
2013-02-05 14:16:51 -05:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
include_examples "enqueue_public"
|
2020-07-24 05:16:52 -04:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
it "enqueue a delayed job for users that are online" do
|
|
|
|
notification.user.last_seen_at = 1.minute.ago
|
|
|
|
|
|
|
|
expect_enqueued_with(
|
|
|
|
job: :user_email,
|
|
|
|
args: NotificationEmailer::EmailUser.notification_params(notification, type),
|
|
|
|
at: Time.zone.now + delay
|
|
|
|
) do
|
|
|
|
NotificationEmailer.process_notification(notification)
|
|
|
|
end
|
2020-07-24 05:16:52 -04:00
|
|
|
end
|
2013-02-05 14:16:51 -05:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
end
|
2013-02-05 14:16:51 -05:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
context 'user_replied' do
|
|
|
|
let(:no_delay) { no_delay }
|
|
|
|
let(:type) { :user_replied }
|
|
|
|
let(:delay) { SiteSetting.email_time_window_mins.minutes }
|
|
|
|
let!(:notification) { create_notification(:replied) }
|
2015-08-31 01:54:37 -04:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
include_examples "enqueue_public"
|
|
|
|
end
|
2013-02-05 14:16:51 -05:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
context 'user_quoted' do
|
|
|
|
let(:no_delay) { no_delay }
|
|
|
|
let(:type) { :user_quoted }
|
|
|
|
let(:delay) { SiteSetting.email_time_window_mins.minutes }
|
|
|
|
let!(:notification) { create_notification(:quoted) }
|
2015-08-31 01:54:37 -04:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
include_examples "enqueue_public"
|
|
|
|
end
|
2013-02-05 14:16:51 -05:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
context 'user_linked' do
|
|
|
|
let(:no_delay) { no_delay }
|
|
|
|
let(:type) { :user_linked }
|
|
|
|
let(:delay) { SiteSetting.email_time_window_mins.minutes }
|
|
|
|
let!(:notification) { create_notification(:linked) }
|
2016-02-16 12:29:23 -05:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
include_examples "enqueue_public"
|
|
|
|
end
|
2016-02-16 12:29:23 -05:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
context 'user_posted' do
|
|
|
|
let(:no_delay) { no_delay }
|
|
|
|
let(:type) { :user_posted }
|
|
|
|
let(:delay) { SiteSetting.email_time_window_mins.minutes }
|
|
|
|
let!(:notification) { create_notification(:posted) }
|
2015-08-31 01:54:37 -04:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
include_examples "enqueue_public"
|
|
|
|
end
|
2013-02-05 14:16:51 -05:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
context 'user_private_message' do
|
|
|
|
let(:no_delay) { no_delay }
|
|
|
|
let(:type) { :user_private_message }
|
|
|
|
let(:delay) { SiteSetting.personal_email_time_window_seconds }
|
|
|
|
let!(:notification) { create_notification(:private_message) }
|
2015-06-09 03:35:26 -04:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
include_examples "enqueue_private"
|
2016-02-01 13:12:10 -05:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
it "doesn't enqueue a job for a small action" do
|
|
|
|
notification.data_hash["original_post_type"] = Post.types[:small_action]
|
2020-07-24 05:16:52 -04:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
expect_not_enqueued_with(job: :user_email, args: { type: type }) do
|
|
|
|
NotificationEmailer.process_notification(notification)
|
|
|
|
end
|
2020-07-24 05:16:52 -04:00
|
|
|
end
|
2016-02-01 13:12:10 -05:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
end
|
2015-06-09 03:35:26 -04:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
context 'user_invited_to_private_message' do
|
|
|
|
let(:no_delay) { no_delay }
|
|
|
|
let(:type) { :user_invited_to_private_message }
|
|
|
|
let(:delay) { SiteSetting.personal_email_time_window_seconds }
|
|
|
|
let!(:notification) { create_notification(:invited_to_private_message) }
|
2015-08-31 01:54:37 -04:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
include_examples "enqueue_public"
|
|
|
|
end
|
2015-06-09 03:35:26 -04:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
context 'user_invited_to_topic' do
|
|
|
|
let(:no_delay) { no_delay }
|
|
|
|
let(:type) { :user_invited_to_topic }
|
|
|
|
let(:delay) { SiteSetting.personal_email_time_window_seconds }
|
|
|
|
let!(:notification) { create_notification(:invited_to_topic) }
|
2016-07-07 12:23:19 -04:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
include_examples "enqueue_public"
|
|
|
|
end
|
2016-07-07 12:23:19 -04:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
context 'watching the first post' do
|
|
|
|
let(:no_delay) { no_delay }
|
|
|
|
let(:type) { :user_watching_first_post }
|
|
|
|
let(:delay) { SiteSetting.email_time_window_mins.minutes }
|
|
|
|
let!(:notification) { create_notification(:watching_first_post) }
|
2015-08-31 01:54:37 -04:00
|
|
|
|
2021-01-07 11:49:49 -05:00
|
|
|
include_examples "enqueue_public"
|
|
|
|
end
|
2021-04-12 11:08:23 -04:00
|
|
|
|
|
|
|
context 'post_approved' do
|
|
|
|
let(:no_delay) { no_delay }
|
|
|
|
let(:type) { :post_approved }
|
|
|
|
let(:delay) { SiteSetting.email_time_window_mins.minutes }
|
|
|
|
let!(:notification) { create_notification(:post_approved) }
|
|
|
|
|
|
|
|
include_examples "enqueue_public"
|
|
|
|
end
|
2015-03-30 14:36:47 -04:00
|
|
|
end
|
2013-08-26 00:55:35 -04:00
|
|
|
end
|