mirror of
https://github.com/discourse/discourse.git
synced 2024-11-25 18:30:26 -06:00
9f9825bb6b
Also changes behaviour of real to not return anonymous users. This means user counts will no longer include them, and the mailing list system will ignore them even if they somehow end up with the feature turned on.
71 lines
2.2 KiB
Ruby
71 lines
2.2 KiB
Ruby
require "spec_helper"
|
|
|
|
describe Jobs::NotifyMailingListSubscribers do
|
|
|
|
context "with mailing list on" do
|
|
let(:user) { Fabricate(:user, mailing_list_mode: true) }
|
|
|
|
context "with a valid post" do
|
|
let!(:post) { Fabricate(:post, user: user) }
|
|
|
|
it "sends the email to the user" do
|
|
UserNotifications.expects(:mailing_list_notify).with(user, post).once
|
|
Jobs::NotifyMailingListSubscribers.new.execute(post_id: post.id)
|
|
end
|
|
end
|
|
|
|
context "with a deleted post" do
|
|
let!(:post) { Fabricate(:post, user: user, deleted_at: Time.now) }
|
|
|
|
it "doesn't send the email to the user" do
|
|
UserNotifications.expects(:mailing_list_notify).with(user, post).never
|
|
Jobs::NotifyMailingListSubscribers.new.execute(post_id: post.id)
|
|
end
|
|
end
|
|
|
|
context "with a user_deleted post" do
|
|
let!(:post) { Fabricate(:post, user: user, user_deleted: true) }
|
|
|
|
it "doesn't send the email to the user" do
|
|
UserNotifications.expects(:mailing_list_notify).with(user, post).never
|
|
Jobs::NotifyMailingListSubscribers.new.execute(post_id: post.id)
|
|
end
|
|
end
|
|
|
|
context "with a deleted topic" do
|
|
let!(:post) { Fabricate(:post, user: user) }
|
|
|
|
before do
|
|
post.topic.update_column(:deleted_at, Time.now)
|
|
end
|
|
|
|
it "doesn't send the email to the user" do
|
|
UserNotifications.expects(:mailing_list_notify).with(user, post).never
|
|
Jobs::NotifyMailingListSubscribers.new.execute(post_id: post.id)
|
|
end
|
|
end
|
|
|
|
end
|
|
|
|
context "to an anonymous user with mailing list on" do
|
|
let(:user) { Fabricate(:anonymous, mailing_list_mode: true) }
|
|
let!(:post) { Fabricate(:post, user: user) }
|
|
|
|
it "doesn't send the email to the user" do
|
|
UserNotifications.expects(:mailing_list_notify).with(user, post).never
|
|
Jobs::NotifyMailingListSubscribers.new.execute(post_id: post.id)
|
|
end
|
|
end
|
|
|
|
context "with mailing list off" do
|
|
let(:user) { Fabricate(:user, mailing_list_mode: false) }
|
|
let!(:post) { Fabricate(:post, user: user) }
|
|
|
|
it "doesn't send the email to the user" do
|
|
UserNotifications.expects(:mailing_list_notify).never
|
|
Jobs::NotifyMailingListSubscribers.new.execute(post_id: post.id)
|
|
end
|
|
end
|
|
|
|
end
|