2013-02-05 14:16:51 -05:00
|
|
|
require "spec_helper"
|
|
|
|
|
|
|
|
describe UserNotifications do
|
2013-02-25 11:42:20 -05:00
|
|
|
|
2013-06-18 15:54:02 -04:00
|
|
|
let(:user) { Fabricate(:admin) }
|
2013-02-05 14:16:51 -05:00
|
|
|
|
2014-01-31 00:37:40 -05:00
|
|
|
describe "#get_context_posts" do
|
|
|
|
it "does not include hidden/deleted/user_deleted posts in context" do
|
|
|
|
post = create_post
|
|
|
|
reply1 = create_post(topic: post.topic)
|
|
|
|
reply2 = create_post(topic: post.topic)
|
|
|
|
reply3 = create_post(topic: post.topic)
|
|
|
|
reply4 = create_post(topic: post.topic)
|
|
|
|
|
|
|
|
reply1.trash!
|
|
|
|
|
|
|
|
reply2.user_deleted = true
|
|
|
|
reply2.save
|
|
|
|
|
|
|
|
reply3.hidden = true
|
|
|
|
reply3.save
|
|
|
|
|
|
|
|
UserNotifications.get_context_posts(reply4, nil).count.should == 1
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-02-05 14:16:51 -05:00
|
|
|
describe ".signup" do
|
|
|
|
subject { UserNotifications.signup(user) }
|
|
|
|
|
|
|
|
its(:to) { should == [user.email] }
|
|
|
|
its(:subject) { should be_present }
|
|
|
|
its(:from) { should == [SiteSetting.notification_email] }
|
|
|
|
its(:body) { should be_present }
|
|
|
|
end
|
|
|
|
|
|
|
|
describe ".forgot_password" do
|
|
|
|
subject { UserNotifications.forgot_password(user) }
|
|
|
|
|
|
|
|
its(:to) { should == [user.email] }
|
|
|
|
its(:subject) { should be_present }
|
|
|
|
its(:from) { should == [SiteSetting.notification_email] }
|
2013-02-25 11:42:20 -05:00
|
|
|
its(:body) { should be_present }
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|
|
|
|
|
2013-06-10 16:46:08 -04:00
|
|
|
describe '.digest' do
|
2013-02-05 14:16:51 -05:00
|
|
|
subject { UserNotifications.digest(user) }
|
|
|
|
|
|
|
|
context "without new topics" do
|
|
|
|
its(:to) { should be_blank }
|
|
|
|
end
|
|
|
|
|
|
|
|
context "with new topics" do
|
|
|
|
before do
|
2013-06-03 16:12:24 -04:00
|
|
|
Topic.expects(:for_digest).returns([Fabricate(:topic, user: Fabricate(:coding_horror))])
|
2014-04-17 16:42:40 -04:00
|
|
|
Topic.expects(:new_since_last_seen).returns(Topic.none)
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
its(:to) { should == [user.email] }
|
|
|
|
its(:subject) { should be_present }
|
|
|
|
its(:from) { should == [SiteSetting.notification_email] }
|
2013-11-28 17:20:56 -05:00
|
|
|
|
|
|
|
it 'should have a html body' do
|
|
|
|
subject.html_part.body.to_s.should be_present
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'should have a text body' do
|
|
|
|
subject.html_part.body.to_s.should be_present
|
|
|
|
end
|
|
|
|
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-07-26 03:27:46 -04:00
|
|
|
describe '.user_replied' do
|
2014-02-12 00:51:26 -05:00
|
|
|
let(:post) { Fabricate(:post) }
|
|
|
|
let(:response) { Fabricate(:post, topic: post.topic)}
|
|
|
|
let(:user) { Fabricate(:user) }
|
|
|
|
let(:notification) { Fabricate(:notification, user: user) }
|
|
|
|
|
2013-07-26 03:27:46 -04:00
|
|
|
|
|
|
|
it 'generates a correct email' do
|
|
|
|
mail = UserNotifications.user_replied(response.user, post: response, notification: notification)
|
|
|
|
|
|
|
|
# 2 respond to links cause we have 1 context post
|
|
|
|
mail.html_part.to_s.scan(/To respond/).count.should == 2
|
|
|
|
|
|
|
|
# 1 unsubscribe
|
|
|
|
mail.html_part.to_s.scan(/To unsubscribe/).count.should == 1
|
|
|
|
|
2013-12-29 21:02:12 -05:00
|
|
|
# side effect, topic user is updated with post number
|
|
|
|
tu = TopicUser.get(post.topic_id, response.user)
|
|
|
|
tu.last_emailed_post_number.should == response.post_number
|
2014-02-12 00:51:26 -05:00
|
|
|
|
|
|
|
# in mailing list mode user_replies is not sent through
|
|
|
|
response.user.mailing_list_mode = true
|
|
|
|
mail = UserNotifications.user_replied(response.user, post: response, notification: notification)
|
|
|
|
mail.class.should == ActionMailer::Base::NullMail
|
|
|
|
|
|
|
|
|
|
|
|
response.user.mailing_list_mode = nil
|
|
|
|
mail = UserNotifications.user_replied(response.user, post: response, notification: notification)
|
|
|
|
|
|
|
|
mail.class.should_not == ActionMailer::Base::NullMail
|
|
|
|
|
2013-07-26 03:27:46 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-02-05 14:16:51 -05:00
|
|
|
|
2013-06-12 16:35:46 -04:00
|
|
|
def expects_build_with(condition)
|
|
|
|
UserNotifications.any_instance.expects(:build_email).with(user.email, condition)
|
|
|
|
UserNotifications.send(mail_type, user, notification: notification, post: notification.post)
|
|
|
|
end
|
|
|
|
|
|
|
|
shared_examples "supports reply by email" do
|
|
|
|
context "reply_by_email" do
|
|
|
|
it "should have allow_reply_by_email set when that feature is enabled" do
|
|
|
|
expects_build_with(has_entry(:allow_reply_by_email, true))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
shared_examples "no reply by email" do
|
|
|
|
context "reply_by_email" do
|
2013-06-13 10:56:16 -04:00
|
|
|
it "doesn't support reply by email" do
|
2013-06-12 16:35:46 -04:00
|
|
|
expects_build_with(Not(has_entry(:allow_reply_by_email, true)))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
shared_examples "notification email building" do
|
2013-02-05 14:16:51 -05:00
|
|
|
let(:post) { Fabricate(:post, user: user) }
|
2013-06-12 16:35:46 -04:00
|
|
|
let(:mail_type) { "user_#{notification_type}"}
|
2013-02-27 18:30:14 -05:00
|
|
|
let(:username) { "walterwhite"}
|
2013-02-05 14:16:51 -05:00
|
|
|
let(:notification) do
|
2013-06-12 16:35:46 -04:00
|
|
|
Fabricate(:notification,
|
|
|
|
user: user,
|
|
|
|
topic: post.topic,
|
|
|
|
notification_type: Notification.types[notification_type],
|
|
|
|
post_number: post.post_number,
|
2014-02-03 20:56:28 -05:00
|
|
|
data: {original_username: username}.to_json )
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|
|
|
|
|
2013-06-12 16:35:46 -04:00
|
|
|
describe '.user_mentioned' do
|
|
|
|
it "has a username" do
|
|
|
|
expects_build_with(has_entry(:username, username))
|
|
|
|
end
|
2013-02-05 14:16:51 -05:00
|
|
|
|
2013-06-12 16:35:46 -04:00
|
|
|
it "has a url" do
|
|
|
|
expects_build_with(has_key(:url))
|
|
|
|
end
|
|
|
|
|
|
|
|
it "has a template" do
|
|
|
|
expects_build_with(has_entry(:template, "user_notifications.#{mail_type}"))
|
|
|
|
end
|
|
|
|
|
|
|
|
it "has a message" do
|
2013-07-22 15:06:37 -04:00
|
|
|
expects_build_with(has_key(:message))
|
|
|
|
end
|
|
|
|
|
|
|
|
it "has a context" do
|
|
|
|
expects_build_with(has_key(:context))
|
2013-06-12 16:35:46 -04:00
|
|
|
end
|
2013-02-27 18:30:14 -05:00
|
|
|
|
2013-06-12 16:35:46 -04:00
|
|
|
it "has an unsubscribe link" do
|
|
|
|
expects_build_with(has_key(:add_unsubscribe_link))
|
|
|
|
end
|
|
|
|
|
2013-06-13 18:11:10 -04:00
|
|
|
it "has an post_id" do
|
|
|
|
expects_build_with(has_key(:post_id))
|
|
|
|
end
|
|
|
|
|
|
|
|
it "has an topic_id" do
|
|
|
|
expects_build_with(has_key(:topic_id))
|
|
|
|
end
|
|
|
|
|
2013-06-12 16:35:46 -04:00
|
|
|
it "has a from alias" do
|
2013-09-12 01:55:18 -04:00
|
|
|
expects_build_with(has_entry(:from_alias, "#{username}"))
|
2013-06-12 16:35:46 -04:00
|
|
|
end
|
2014-05-06 15:01:19 -04:00
|
|
|
|
|
|
|
it "should explain how to respond" do
|
|
|
|
expects_build_with(Not(has_entry(:include_respond_instructions, false)))
|
|
|
|
end
|
|
|
|
|
|
|
|
it "should not explain how to respond if the user is suspended" do
|
|
|
|
User.any_instance.stubs(:suspended?).returns(true)
|
|
|
|
expects_build_with(has_entry(:include_respond_instructions, false))
|
|
|
|
end
|
2013-02-27 18:30:14 -05:00
|
|
|
end
|
2013-06-12 16:35:46 -04:00
|
|
|
end
|
2013-02-27 18:30:14 -05:00
|
|
|
|
2013-06-12 16:35:46 -04:00
|
|
|
describe "user mentioned email" do
|
|
|
|
include_examples "notification email building" do
|
|
|
|
let(:notification_type) { :mentioned }
|
|
|
|
include_examples "supports reply by email"
|
|
|
|
end
|
|
|
|
end
|
2013-02-27 18:30:14 -05:00
|
|
|
|
2013-06-12 16:35:46 -04:00
|
|
|
describe "user replied" do
|
|
|
|
include_examples "notification email building" do
|
|
|
|
let(:notification_type) { :replied }
|
|
|
|
include_examples "supports reply by email"
|
|
|
|
end
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|
|
|
|
|
2013-06-12 16:35:46 -04:00
|
|
|
describe "user quoted" do
|
|
|
|
include_examples "notification email building" do
|
|
|
|
let(:notification_type) { :quoted }
|
|
|
|
include_examples "supports reply by email"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "user posted" do
|
|
|
|
include_examples "notification email building" do
|
|
|
|
let(:notification_type) { :posted }
|
|
|
|
include_examples "supports reply by email"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "user posted" do
|
|
|
|
include_examples "notification email building" do
|
|
|
|
let(:notification_type) { :posted }
|
|
|
|
include_examples "supports reply by email"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "user invited to a private message" do
|
|
|
|
include_examples "notification email building" do
|
|
|
|
let(:notification_type) { :invited_to_private_message }
|
|
|
|
include_examples "no reply by email"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|