2019-04-29 20:27:42 -04:00
# frozen_string_literal: true
2015-10-11 05:41:23 -04:00
require " rails_helper "
2013-02-05 14:16:51 -05:00
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
2016-02-12 06:10:30 -05:00
post1 = create_post
2016-02-18 21:56:52 -05:00
_post2 = Fabricate ( :post , topic : post1 . topic , deleted_at : 1 . day . ago )
_post3 = Fabricate ( :post , topic : post1 . topic , user_deleted : true )
_post4 = Fabricate ( :post , topic : post1 . topic , hidden : true )
_post5 = Fabricate ( :post , topic : post1 . topic , post_type : Post . types [ :moderator_action ] )
_post6 = Fabricate ( :post , topic : post1 . topic , post_type : Post . types [ :small_action ] )
_post7 = Fabricate ( :post , topic : post1 . topic , post_type : Post . types [ :whisper ] )
2017-07-27 21:20:09 -04:00
last = Fabricate ( :post , topic : post1 . topic )
2016-02-12 06:10:30 -05:00
2016-02-25 08:05:40 -05:00
post1 . user . user_option . email_previous_replies = UserOption . previous_replies_type [ :always ]
2016-02-12 06:10:30 -05:00
# default is only post #1
2016-02-25 08:05:40 -05:00
expect ( UserNotifications . get_context_posts ( last , nil , post1 . user ) . count ) . to eq ( 1 )
2016-02-12 06:10:30 -05:00
# staff members can also see the whisper
2016-02-25 08:05:40 -05:00
moderator = build ( :moderator )
moderator . user_option = UserOption . new
moderator . user_option . email_previous_replies = UserOption . previous_replies_type [ :always ]
tu = TopicUser . new ( topic : post1 . topic , user : moderator )
expect ( UserNotifications . get_context_posts ( last , tu , tu . user ) . count ) . to eq ( 2 )
2014-01-31 00:37:40 -05:00
end
2016-02-18 21:56:52 -05:00
it " allows users to control context " do
post1 = create_post
2017-07-27 21:20:09 -04:00
_post2 = Fabricate ( :post , topic : post1 . topic )
post3 = Fabricate ( :post , topic : post1 . topic )
2016-02-18 21:56:52 -05:00
user = Fabricate ( :user )
TopicUser . change ( user . id , post1 . topic_id , last_emailed_post_number : 1 )
topic_user = TopicUser . find_by ( user_id : user . id , topic_id : post1 . topic_id )
# to avoid reloads after update_columns
user = topic_user . user
2016-02-25 08:05:40 -05:00
user . user_option . update_columns ( email_previous_replies : UserOption . previous_replies_type [ :unless_emailed ] )
expect ( UserNotifications . get_context_posts ( post3 , topic_user , user ) . count ) . to eq ( 1 )
2016-02-18 21:56:52 -05:00
user . user_option . update_columns ( email_previous_replies : UserOption . previous_replies_type [ :never ] )
2016-02-25 08:05:40 -05:00
expect ( UserNotifications . get_context_posts ( post3 , topic_user , user ) . count ) . to eq ( 0 )
2016-02-18 21:56:52 -05:00
user . user_option . update_columns ( email_previous_replies : UserOption . previous_replies_type [ :always ] )
2016-02-25 08:05:40 -05:00
expect ( UserNotifications . get_context_posts ( post3 , topic_user , user ) . count ) . to eq ( 2 )
2016-02-18 21:56:52 -05:00
2017-04-24 15:26:06 -04:00
SiteSetting . private_email = true
expect ( UserNotifications . get_context_posts ( post3 , topic_user , user ) . count ) . to eq ( 0 )
2016-02-18 21:56:52 -05:00
end
2017-04-24 15:26:06 -04:00
2014-01-31 00:37:40 -05:00
end
2013-02-05 14:16:51 -05:00
describe " .signup " do
2014-10-29 11:06:50 -04:00
2013-02-05 14:16:51 -05:00
subject { UserNotifications . signup ( user ) }
2014-10-29 11:06:50 -04:00
it " works " do
2014-12-31 09:55:03 -05:00
expect ( subject . to ) . to eq ( [ user . email ] )
expect ( subject . subject ) . to be_present
expect ( subject . from ) . to eq ( [ SiteSetting . notification_email ] )
expect ( subject . body ) . to be_present
2014-10-29 11:06:50 -04:00
end
2013-02-05 14:16:51 -05:00
end
describe " .forgot_password " do
2014-10-29 11:06:50 -04:00
2013-02-05 14:16:51 -05:00
subject { UserNotifications . forgot_password ( user ) }
2014-10-29 11:06:50 -04:00
it " works " do
2014-12-31 09:55:03 -05:00
expect ( subject . to ) . to eq ( [ user . email ] )
expect ( subject . subject ) . to be_present
expect ( subject . from ) . to eq ( [ SiteSetting . notification_email ] )
expect ( subject . body ) . to be_present
2014-10-29 11:06:50 -04:00
end
2013-02-05 14:16:51 -05:00
end
2017-04-20 11:17:24 -04:00
describe '.email_login' do
let ( :email_token ) { user . email_tokens . create! ( email : user . email ) . token }
subject { UserNotifications . email_login ( user , email_token : email_token ) }
it " generates the right email " do
expect ( subject . to ) . to eq ( [ user . email ] )
expect ( subject . from ) . to eq ( [ SiteSetting . notification_email ] )
expect ( subject . subject ) . to eq ( I18n . t (
'user_notifications.email_login.subject_template' ,
email_prefix : SiteSetting . title
) )
expect ( subject . body . to_s ) . to match ( I18n . t (
'user_notifications.email_login.text_body_template' ,
site_name : SiteSetting . title ,
base_url : Discourse . base_url ,
email_token : email_token
) )
end
end
2013-06-10 16:46:08 -04:00
describe '.digest' do
2014-10-29 11:06:50 -04:00
2013-02-05 14:16:51 -05:00
subject { UserNotifications . digest ( user ) }
2019-10-25 16:33:05 -04:00
after do
2019-12-03 04:05:53 -05:00
Discourse . redis . keys ( 'summary-new-users:*' ) . each { | key | Discourse . redis . del ( key ) }
2019-10-25 16:33:05 -04:00
end
2013-02-05 14:16:51 -05:00
context " without new topics " do
2014-10-29 11:06:50 -04:00
it " doesn't send the email " do
2014-12-31 09:55:03 -05:00
expect ( subject . to ) . to be_blank
2014-10-29 11:06:50 -04:00
end
2013-02-05 14:16:51 -05:00
end
2016-12-19 14:53:53 -05:00
context " with topics only from new users " do
2019-01-17 17:46:04 -05:00
let! ( :new_today ) { Fabricate ( :topic , user : Fabricate ( :user , trust_level : TrustLevel [ 0 ] , created_at : 10 . minutes . ago ) , title : " Hey everyone look at me " ) }
2016-12-19 14:53:53 -05:00
let! ( :new_yesterday ) { Fabricate ( :topic , user : Fabricate ( :user , trust_level : TrustLevel [ 0 ] , created_at : 25 . hours . ago ) , created_at : 25 . hours . ago , title : " This topic is of interest to you " ) }
it " returns topics from new users if they're more than 24 hours old " do
expect ( subject . to ) . to eq ( [ user . email ] )
html = subject . html_part . body . to_s
expect ( html ) . to include ( new_yesterday . title )
expect ( html ) . to_not include ( new_today . title )
end
end
2013-02-05 14:16:51 -05:00
context " with new topics " do
2014-10-29 11:06:50 -04:00
2018-08-07 16:38:05 -04:00
let! ( :popular_topic ) { Fabricate ( :topic , user : Fabricate ( :coding_horror ) , created_at : 1 . hour . ago ) }
2013-02-05 14:16:51 -05:00
2014-10-29 11:06:50 -04:00
it " works " do
2014-12-31 09:55:03 -05:00
expect ( subject . to ) . to eq ( [ user . email ] )
expect ( subject . subject ) . to be_present
expect ( subject . from ) . to eq ( [ SiteSetting . notification_email ] )
expect ( subject . html_part . body . to_s ) . to be_present
expect ( subject . text_part . body . to_s ) . to be_present
2016-07-15 05:39:29 -04:00
expect ( subject . header [ " List-Unsubscribe " ] . to_s ) . to match ( / \/ email \/ unsubscribe \/ \ h{64} / )
2019-10-25 16:33:05 -04:00
expect ( subject . html_part . body . to_s ) . to include ( 'New Users' )
end
it " doesn't include new user count if digest_after_minutes is low " do
user . user_option . digest_after_minutes = 60
expect ( subject . html_part . body . to_s ) . to_not include ( 'New Users' )
end
it " works with min_date string " do
digest = UserNotifications . digest ( user , since : 1 . month . ago . to_date . to_s )
expect ( digest . html_part . body . to_s ) . to be_present
expect ( digest . text_part . body . to_s ) . to be_present
expect ( digest . html_part . body . to_s ) . to include ( 'New Users' )
2013-11-28 17:20:56 -05:00
end
2015-06-03 12:49:51 -04:00
it " includes email_prefix in email subject instead of site title " do
SiteSetting . email_prefix = " Try Discourse "
SiteSetting . title = " Discourse Meta "
expect ( subject . subject ) . to match ( / Try Discourse / )
expect ( subject . subject ) . not_to match ( / Discourse Meta / )
end
2016-11-22 13:23:21 -05:00
it " excludes deleted topics and their posts " do
2017-08-14 12:47:33 -04:00
deleted = Fabricate ( :topic , user : Fabricate ( :user ) , title : " Delete this topic plz " , created_at : 1 . hour . ago )
post = Fabricate ( :post , topic : deleted , score : 100 . 0 , post_number : 2 , raw : " Your wish is my command " , created_at : 1 . hour . ago )
2016-11-22 13:23:21 -05:00
deleted . trash!
html = subject . html_part . body . to_s
expect ( html ) . to_not include deleted . title
expect ( html ) . to_not include post . raw
end
2016-12-01 12:01:23 -05:00
it " excludes whispers and other post types that don't belong " do
2017-08-14 12:47:33 -04:00
t = Fabricate ( :topic , user : Fabricate ( :user ) , title : " Who likes the same stuff I like? " , created_at : 1 . hour . ago )
whisper = Fabricate ( :post , topic : t , score : 100 . 0 , post_number : 2 , raw : " You like weird stuff " , post_type : Post . types [ :whisper ] , created_at : 1 . hour . ago )
mod_action = Fabricate ( :post , topic : t , score : 100 . 0 , post_number : 3 , raw : " This topic unlisted " , post_type : Post . types [ :moderator_action ] , created_at : 1 . hour . ago )
small_action = Fabricate ( :post , topic : t , score : 100 . 0 , post_number : 4 , raw : " A small action " , post_type : Post . types [ :small_action ] , created_at : 1 . hour . ago )
2016-12-01 12:01:23 -05:00
html = subject . html_part . body . to_s
expect ( html ) . to_not include whisper . raw
expect ( html ) . to_not include mod_action . raw
expect ( html ) . to_not include small_action . raw
end
it " excludes deleted and hidden posts " do
2017-08-14 12:47:33 -04:00
t = Fabricate ( :topic , user : Fabricate ( :user ) , title : " Post objectionable stuff here " , created_at : 1 . hour . ago )
deleted = Fabricate ( :post , topic : t , score : 100 . 0 , post_number : 2 , raw : " This post is uncalled for " , deleted_at : 5 . minutes . ago , created_at : 1 . hour . ago )
hidden = Fabricate ( :post , topic : t , score : 100 . 0 , post_number : 3 , raw : " Try to find this post " , hidden : true , hidden_at : 5 . minutes . ago , hidden_reason_id : Post . hidden_reasons [ :flagged_by_tl3_user ] , created_at : 1 . hour . ago )
user_deleted = Fabricate ( :post , topic : t , score : 100 . 0 , post_number : 4 , raw : " I regret this post " , user_deleted : true , created_at : 1 . hour . ago )
2016-12-01 12:01:23 -05:00
html = subject . html_part . body . to_s
expect ( html ) . to_not include deleted . raw
expect ( html ) . to_not include hidden . raw
expect ( html ) . to_not include user_deleted . raw
end
2017-05-03 14:35:13 -04:00
2017-08-14 12:47:33 -04:00
it " excludes posts that are newer than editing grace period " do
SiteSetting . editing_grace_period = 5 . minutes
too_new = Fabricate ( :topic , user : Fabricate ( :user ) , title : " Oops I need to edit this " , created_at : 1 . minute . ago )
2019-04-29 20:27:42 -04:00
_too_new_post = Fabricate ( :post , user : too_new . user , topic : too_new , score : 100 . 0 , post_number : 1 , created_at : 1 . minute . ago )
2017-08-14 12:47:33 -04:00
html = subject . html_part . body . to_s
expect ( html ) . to_not include too_new . title
end
2017-05-03 14:35:13 -04:00
it " uses theme color " do
cs = Fabricate ( :color_scheme , name : 'Fancy' , color_scheme_colors : [
2019-01-17 17:46:04 -05:00
Fabricate ( :color_scheme_color , name : 'header_primary' , hex : 'F0F0F0' ) ,
2017-05-03 14:35:13 -04:00
Fabricate ( :color_scheme_color , name : 'header_background' , hex : '1E1E1E' ) ,
Fabricate ( :color_scheme_color , name : 'tertiary' , hex : '858585' )
] )
2018-08-08 00:46:34 -04:00
theme = Fabricate ( :theme ,
2019-01-17 17:46:04 -05:00
user_selectable : true ,
user : Fabricate ( :admin ) ,
color_scheme_id : cs . id
2017-05-03 14:35:13 -04:00
)
2018-08-08 00:46:34 -04:00
2017-05-03 14:35:13 -04:00
theme . set_default!
html = subject . html_part . body . to_s
expect ( html ) . to include 'F0F0F0'
expect ( html ) . to include '1E1E1E'
expect ( html ) . to include '858585'
end
2018-08-07 16:38:05 -04:00
it " supports subfolder " do
2019-11-15 00:48:24 -05:00
set_subfolder " /forum "
2018-08-07 16:38:05 -04:00
html = subject . html_part . body . to_s
text = subject . text_part . body . to_s
expect ( html ) . to be_present
expect ( text ) . to be_present
expect ( html ) . to_not include ( " /forum/forum " )
expect ( text ) . to_not include ( " /forum/forum " )
expect ( subject . header [ " List-Unsubscribe " ] . to_s ) . to match ( / http: \/ \/ test.localhost \/ forum \/ email \/ unsubscribe \/ \ h{64} / )
topic_url = " http://test.localhost/forum/t/ #{ popular_topic . slug } / #{ popular_topic . id } "
expect ( html ) . to include ( topic_url )
expect ( text ) . to include ( topic_url )
end
2013-02-05 14:16:51 -05:00
end
2016-11-22 13:23:21 -05:00
2013-02-05 14:16:51 -05:00
end
2013-07-26 03:27:46 -04:00
describe '.user_replied' do
2014-10-21 10:06:55 -04:00
let ( :response_by_user ) { Fabricate ( :user , name : " John Doe " ) }
2014-10-03 07:44:08 -04:00
let ( :category ) { Fabricate ( :category , name : 'India' ) }
2018-07-10 22:24:07 -04:00
let ( :tag1 ) { Fabricate ( :tag , name : 'Taggo' ) }
let ( :tag2 ) { Fabricate ( :tag , name : 'Taggie' ) }
2019-01-17 17:46:04 -05:00
let ( :topic ) { Fabricate ( :topic , category : category , tags : [ tag1 , tag2 ] , title : " Super cool topic " ) }
2016-02-25 08:05:40 -05:00
let ( :post ) { Fabricate ( :post , topic : topic , raw : 'This is My super duper cool topic' ) }
2019-01-17 17:46:04 -05:00
let ( :response ) { Fabricate ( :basic_reply , topic : post . topic , user : response_by_user ) }
2014-02-12 00:51:26 -05:00
let ( :user ) { Fabricate ( :user ) }
2019-01-17 17:46:04 -05:00
let ( :notification ) { Fabricate ( :replied_notification , user : user , post : response ) }
2014-02-12 00:51:26 -05:00
2013-07-26 03:27:46 -04:00
it 'generates a correct email' do
2016-02-25 08:05:40 -05:00
# Fabricator is not fabricating this ...
2018-07-10 22:24:07 -04:00
SiteSetting . email_subject = " [%{site_name}] %{optional_pm}%{optional_cat}%{optional_tags}%{topic_title} "
2015-02-17 14:37:22 -05:00
SiteSetting . enable_names = true
SiteSetting . display_name_on_posts = true
2019-01-17 17:46:04 -05:00
mail = UserNotifications . user_replied (
user ,
post : response ,
notification_type : notification . notification_type ,
notification_data_hash : notification . data_hash
)
2014-10-21 10:06:55 -04:00
# from should include full user name
2019-01-04 10:06:21 -05:00
expect ( mail [ :from ] . display_names ) . to eql ( [ 'John Doe via Discourse' ] )
2014-10-21 10:06:55 -04:00
2014-10-03 07:44:08 -04:00
# subject should include category name
expect ( mail . subject ) . to match ( / India / )
2018-07-10 22:24:07 -04:00
# subject should include tag names
expect ( mail . subject ) . to match ( / Taggo / )
expect ( mail . subject ) . to match ( / Taggie / )
2019-07-30 15:05:08 -04:00
mail_html = mail . html_part . body . to_s
2016-02-25 08:05:40 -05:00
expect ( mail_html . scan ( / My super duper cool topic / ) . count ) . to eq ( 1 )
expect ( mail_html . scan ( / In Reply To / ) . count ) . to eq ( 1 )
2016-02-09 03:09:10 -05:00
# 2 "visit topic" link
2016-02-25 08:05:40 -05:00
expect ( mail_html . scan ( / Visit Topic / ) . count ) . to eq ( 2 )
2016-02-09 03:09:10 -05:00
2013-07-26 03:27:46 -04:00
# 2 respond to links cause we have 1 context post
2016-02-25 08:05:40 -05:00
expect ( mail_html . scan ( / to respond / ) . count ) . to eq ( 2 )
2013-07-26 03:27:46 -04:00
# 1 unsubscribe
2016-02-25 08:05:40 -05:00
expect ( mail_html . scan ( / To unsubscribe / ) . count ) . to eq ( 1 )
2013-07-26 03:27:46 -04:00
2013-12-29 21:02:12 -05:00
# side effect, topic user is updated with post number
2019-01-17 17:46:04 -05:00
tu = TopicUser . get ( post . topic_id , user )
2014-12-31 09:55:03 -05:00
expect ( tu . last_emailed_post_number ) . to eq ( response . post_number )
2016-02-25 08:05:40 -05:00
# no In Reply To if user opts out
2019-01-17 17:46:04 -05:00
user . user_option . email_in_reply_to = false
mail = UserNotifications . user_replied (
user ,
post : response ,
notification_type : notification . notification_type ,
notification_data_hash : notification . data_hash
)
2016-02-25 08:05:40 -05:00
2019-07-30 15:05:08 -04:00
expect ( mail . html_part . body . to_s . scan ( / In Reply To / ) . count ) . to eq ( 0 )
2016-11-13 19:09:24 -05:00
SiteSetting . enable_names = true
SiteSetting . display_name_on_posts = true
SiteSetting . prioritize_username_in_ux = false
response . user . username = " bobmarley "
response . user . name = " Bob Marley "
response . user . save
2019-01-17 17:46:04 -05:00
mail = UserNotifications . user_replied (
user ,
post : response ,
notification_type : notification . notification_type ,
notification_data_hash : notification . data_hash
)
2016-11-13 19:09:24 -05:00
2019-07-30 15:05:08 -04:00
mail_html = mail . html_part . body . to_s
2016-11-13 19:09:24 -05:00
expect ( mail_html . scan ( / >Bob Marley / ) . count ) . to eq ( 1 )
expect ( mail_html . scan ( / >bobmarley / ) . count ) . to eq ( 0 )
SiteSetting . prioritize_username_in_ux = true
2019-01-17 17:46:04 -05:00
mail = UserNotifications . user_replied (
user ,
post : response ,
notification_type : notification . notification_type ,
notification_data_hash : notification . data_hash
)
2016-11-13 19:09:24 -05:00
2019-07-30 15:05:08 -04:00
mail_html = mail . html_part . body . to_s
2016-11-13 19:09:24 -05:00
expect ( mail_html . scan ( / >Bob Marley / ) . count ) . to eq ( 0 )
expect ( mail_html . scan ( / >bobmarley / ) . count ) . to eq ( 1 )
2013-07-26 03:27:46 -04:00
end
2017-04-24 15:26:06 -04:00
it " doesn't include details when private_email is enabled " do
SiteSetting . private_email = true
mail = UserNotifications . user_replied (
2019-01-17 17:46:04 -05:00
user ,
2017-04-24 15:26:06 -04:00
post : response ,
notification_type : notification . notification_type ,
notification_data_hash : notification . data_hash
)
2019-07-30 15:05:08 -04:00
expect ( mail . html_part . body . to_s ) . to_not include ( response . raw )
expect ( mail . html_part . body . to_s ) . to_not include ( topic . url )
2017-04-24 15:26:06 -04:00
expect ( mail . text_part . to_s ) . to_not include ( response . raw )
expect ( mail . text_part . to_s ) . to_not include ( topic . url )
end
2019-08-06 12:45:28 -04:00
it " includes excerpt when post_excerpts_in_emails is enabled " do
paragraphs = [
" This is the first paragraph, but you should read more. " ,
" And here is its friend, the second paragraph. "
]
SiteSetting . post_excerpts_in_emails = true
SiteSetting . post_excerpt_maxlength = paragraphs . first . length
2019-09-11 20:41:50 -04:00
response . update! ( raw : paragraphs . join ( " \n \n " ) )
2019-08-06 12:45:28 -04:00
mail = UserNotifications . user_replied (
user ,
post : response ,
notification_type : notification . notification_type ,
notification_data_hash : notification . data_hash
)
mail_html = mail . html_part . body . to_s
expect ( mail_html . scan ( / #{ paragraphs [ 0 ] } / ) . count ) . to eq ( 1 )
expect ( mail_html . scan ( / #{ paragraphs [ 1 ] } / ) . count ) . to eq ( 0 )
end
2013-07-26 03:27:46 -04:00
end
2014-09-29 01:16:55 -04:00
describe '.user_posted' do
2014-12-03 02:42:05 -05:00
let ( :response_by_user ) { Fabricate ( :user , name : " John Doe " , username : " john " ) }
2019-01-17 17:46:04 -05:00
let ( :topic ) { Fabricate ( :topic , title : " Super cool topic " ) }
let ( :post ) { Fabricate ( :post , topic : topic ) }
let ( :response ) { Fabricate ( :post , topic : topic , user : response_by_user ) }
2014-09-29 01:16:55 -04:00
let ( :user ) { Fabricate ( :user ) }
2019-01-17 17:46:04 -05:00
let ( :notification ) { Fabricate ( :posted_notification , user : user , post : response ) }
2014-09-29 01:16:55 -04:00
it 'generates a correct email' do
2015-02-17 14:37:22 -05:00
SiteSetting . enable_names = false
2019-01-17 17:46:04 -05:00
mail = UserNotifications . user_posted (
user ,
post : response ,
notification_type : notification . notification_type ,
notification_data_hash : notification . data_hash
)
2014-09-29 01:16:55 -04:00
2014-10-21 10:06:55 -04:00
# from should not include full user name if "show user full names" is disabled
expect ( mail [ :from ] . display_names ) . to_not eql ( [ 'John Doe' ] )
2014-12-03 02:42:05 -05:00
# from should include username if "show user full names" is disabled
2019-01-04 10:06:21 -05:00
expect ( mail [ :from ] . display_names ) . to eql ( [ 'john via Discourse' ] )
2014-12-03 02:42:05 -05:00
2014-10-03 07:44:08 -04:00
# subject should not include category name
expect ( mail . subject ) . not_to match ( / Uncategorized / )
2016-02-25 08:05:40 -05:00
# 1 respond to links as no context by default
2019-07-30 15:05:08 -04:00
expect ( mail . html_part . body . to_s . scan ( / to respond / ) . count ) . to eq ( 1 )
2014-09-29 01:16:55 -04:00
# 1 unsubscribe link
2019-07-30 15:05:08 -04:00
expect ( mail . html_part . body . to_s . scan ( / To unsubscribe / ) . count ) . to eq ( 1 )
2014-09-29 01:16:55 -04:00
# side effect, topic user is updated with post number
2019-01-17 17:46:04 -05:00
tu = TopicUser . get ( post . topic_id , user )
2014-12-31 09:55:03 -05:00
expect ( tu . last_emailed_post_number ) . to eq ( response . post_number )
2014-09-29 01:16:55 -04:00
end
2017-04-24 15:26:06 -04:00
it " doesn't include details when private_email is enabled " do
SiteSetting . private_email = true
mail = UserNotifications . user_posted (
2019-01-17 17:46:04 -05:00
user ,
2017-04-24 15:26:06 -04:00
post : response ,
notification_type : notification . notification_type ,
notification_data_hash : notification . data_hash
)
2019-07-30 15:05:08 -04:00
expect ( mail . html_part . body . to_s ) . to_not include ( response . raw )
2017-04-24 15:26:06 -04:00
expect ( mail . text_part . to_s ) . to_not include ( response . raw )
end
2019-01-18 04:52:48 -05:00
it " uses the original subject for staged users " do
incoming_email = Fabricate (
:incoming_email ,
subject : " Original Subject " ,
post : post ,
topic : post . topic ,
user : user
)
mail = UserNotifications . user_posted (
user ,
post : response ,
notification_type : notification . notification_type ,
notification_data_hash : notification . data_hash
)
expect ( mail . subject ) . to match ( / Super cool topic / )
user . update! ( staged : true )
mail = UserNotifications . user_posted (
user ,
post : response ,
notification_type : notification . notification_type ,
notification_data_hash : notification . data_hash
)
expect ( mail . subject ) . to eq ( " Re: Original Subject " )
another_post = Fabricate ( :post , topic : topic )
incoming_email . update! ( post_id : another_post . id )
mail = UserNotifications . user_private_message (
user ,
post : response ,
notification_type : notification . notification_type ,
notification_data_hash : notification . data_hash
)
expect ( mail . subject ) . to match ( / Super cool topic / )
end
2014-09-29 01:16:55 -04:00
end
describe '.user_private_message' do
2014-12-03 02:42:05 -05:00
let ( :response_by_user ) { Fabricate ( :user , name : " " , username : " john " ) }
2019-01-18 04:52:48 -05:00
let ( :topic ) { Fabricate ( :private_message_topic , title : " Super cool topic " ) }
let ( :post ) { Fabricate ( :post , topic : topic ) }
2017-07-27 21:20:09 -04:00
let ( :response ) { Fabricate ( :post , topic : topic , user : response_by_user ) }
2014-09-29 01:16:55 -04:00
let ( :user ) { Fabricate ( :user ) }
2019-01-17 17:46:04 -05:00
let ( :notification ) { Fabricate ( :private_message_notification , user : user , post : response ) }
2014-09-29 01:16:55 -04:00
it 'generates a correct email' do
2015-02-17 14:37:22 -05:00
SiteSetting . enable_names = true
2016-01-26 20:19:49 -05:00
mail = UserNotifications . user_private_message (
2019-01-17 17:46:04 -05:00
user ,
2016-01-26 20:19:49 -05:00
post : response ,
notification_type : notification . notification_type ,
notification_data_hash : notification . data_hash
)
2014-09-29 01:16:55 -04:00
2014-12-03 02:42:05 -05:00
# from should include username if full user name is not provided
2019-01-04 10:06:21 -05:00
expect ( mail [ :from ] . display_names ) . to eql ( [ 'john via Discourse' ] )
2014-10-21 10:06:55 -04:00
2014-09-29 01:16:55 -04:00
# subject should include "[PM]"
2018-02-19 04:20:17 -05:00
expect ( mail . subject ) . to include ( " [PM] " )
2014-09-29 01:16:55 -04:00
2016-02-09 03:09:10 -05:00
# 1 "visit message" link
2019-07-30 15:05:08 -04:00
expect ( mail . html_part . body . to_s . scan ( / Visit Message / ) . count ) . to eq ( 1 )
2016-02-09 03:09:10 -05:00
2014-09-29 01:16:55 -04:00
# 1 respond to link
2019-07-30 15:05:08 -04:00
expect ( mail . html_part . body . to_s . scan ( / to respond / ) . count ) . to eq ( 1 )
2014-09-29 01:16:55 -04:00
# 1 unsubscribe link
2019-07-30 15:05:08 -04:00
expect ( mail . html_part . body . to_s . scan ( / To unsubscribe / ) . count ) . to eq ( 1 )
2014-09-29 01:16:55 -04:00
# side effect, topic user is updated with post number
2019-01-17 17:46:04 -05:00
tu = TopicUser . get ( topic . id , user )
2014-12-31 09:55:03 -05:00
expect ( tu . last_emailed_post_number ) . to eq ( response . post_number )
2014-09-29 01:16:55 -04:00
end
2017-04-24 15:26:06 -04:00
it " doesn't include details when private_email is enabled " do
SiteSetting . private_email = true
mail = UserNotifications . user_private_message (
2019-01-17 17:46:04 -05:00
user ,
2017-04-24 15:26:06 -04:00
post : response ,
notification_type : notification . notification_type ,
notification_data_hash : notification . data_hash
)
2019-07-30 15:05:08 -04:00
expect ( mail . html_part . body . to_s ) . to_not include ( response . raw )
expect ( mail . html_part . body . to_s ) . to_not include ( topic . url )
2017-04-24 15:26:06 -04:00
expect ( mail . text_part . to_s ) . to_not include ( response . raw )
expect ( mail . text_part . to_s ) . to_not include ( topic . url )
end
2018-02-19 04:20:17 -05:00
it " doesn't include group name in subject " do
group = Fabricate ( :group )
2019-01-17 17:46:04 -05:00
topic . allowed_groups = [ group ]
2018-02-19 04:20:17 -05:00
mail = UserNotifications . user_private_message (
2019-01-17 17:46:04 -05:00
user ,
2018-02-19 04:20:17 -05:00
post : response ,
notification_type : notification . notification_type ,
notification_data_hash : notification . data_hash
)
expect ( mail . subject ) . to include ( " [PM] " )
end
2018-05-03 18:50:06 -04:00
it " includes a list of participants, groups first with member lists " do
2018-05-06 23:25:01 -04:00
group1 = Fabricate ( :group , name : " group1 " )
group2 = Fabricate ( :group , name : " group2 " )
user1 = Fabricate ( :user , username : " one " , groups : [ group1 , group2 ] )
user2 = Fabricate ( :user , username : " two " , groups : [ group1 ] )
topic . allowed_users = [ user1 , user2 ]
topic . allowed_groups = [ group1 , group2 ]
2018-05-03 18:50:06 -04:00
mail = UserNotifications . user_private_message (
2019-01-17 17:46:04 -05:00
user ,
2018-05-03 18:50:06 -04:00
post : response ,
notification_type : notification . notification_type ,
notification_data_hash : notification . data_hash
)
2018-06-11 18:54:39 -04:00
expect ( mail . body ) . to include ( " [group1 (2)](http://test.localhost/groups/group1), [group2 (1)](http://test.localhost/groups/group2), [one](http://test.localhost/u/one), [two](http://test.localhost/u/two) " )
2018-05-03 18:50:06 -04:00
end
2018-02-19 04:20:17 -05:00
context " when SiteSetting.group_name_in_subject is true " do
before do
SiteSetting . group_in_subject = true
end
let ( :group ) { Fabricate ( :group , name : " my_group " ) }
2019-01-17 17:46:04 -05:00
let ( :mail ) do
UserNotifications . user_private_message (
user ,
post : response ,
notification_type : notification . notification_type ,
notification_data_hash : notification . data_hash
)
end
2018-02-19 04:20:17 -05:00
shared_examples " includes first group name " do
it " includes first group name in subject " do
expect ( mail . subject ) . to include ( " [my_group] " )
end
context " when first group has full name " do
it " includes full name in subject " do
group . full_name = " My Group "
group . save
expect ( mail . subject ) . to include ( " [My Group] " )
end
end
end
context " one group in pm " do
before do
2019-01-17 17:46:04 -05:00
topic . allowed_groups = [ group ]
2018-02-19 04:20:17 -05:00
end
include_examples " includes first group name "
end
context " multiple groups in pm " do
let ( :group2 ) { Fabricate ( :group ) }
before do
2019-01-17 17:46:04 -05:00
topic . allowed_groups = [ group , group2 ]
2018-02-19 04:20:17 -05:00
end
include_examples " includes first group name "
end
2018-03-11 08:22:11 -04:00
context " no groups in pm " do
it " includes %{optional_pm} in subject " do
expect ( mail . subject ) . to include ( " [PM] " )
end
end
2018-02-19 04:20:17 -05:00
end
2019-01-18 04:52:48 -05:00
it " uses the original subject for staged users when topic was started via email " do
incoming_email = Fabricate (
:incoming_email ,
subject : " Original Subject " ,
post : post ,
topic : topic ,
user : user
)
mail = UserNotifications . user_private_message (
user ,
post : response ,
notification_type : notification . notification_type ,
notification_data_hash : notification . data_hash
)
expect ( mail . subject ) . to match ( / Super cool topic / )
user . update! ( staged : true )
mail = UserNotifications . user_private_message (
user ,
post : response ,
notification_type : notification . notification_type ,
notification_data_hash : notification . data_hash
)
expect ( mail . subject ) . to eq ( " Re: Original Subject " )
another_post = Fabricate ( :post , topic : topic )
incoming_email . update! ( post_id : another_post . id )
mail = UserNotifications . user_private_message (
user ,
post : response ,
notification_type : notification . notification_type ,
notification_data_hash : notification . data_hash
)
expect ( mail . subject ) . to match ( / Super cool topic / )
end
2014-09-29 01:16:55 -04:00
end
2013-02-05 14:16:51 -05:00
2016-03-23 00:08:34 -04:00
it 'adds a warning when mail limit is reached' do
SiteSetting . max_emails_per_day_per_user = 2
user = Fabricate ( :user )
2018-07-27 00:32:07 -04:00
user . email_logs . create! (
email_type : 'blah' ,
to_address : user . email ,
user_id : user . id
)
2016-03-23 00:08:34 -04:00
post = Fabricate ( :post )
reply = Fabricate ( :post , topic_id : post . topic_id )
2019-01-17 17:46:04 -05:00
notification = Fabricate (
:notification ,
topic_id : post . topic_id ,
post_number : reply . post_number ,
user : post . user ,
data : { original_username : 'bob' } . to_json
)
2016-03-23 00:08:34 -04:00
mail = UserNotifications . user_replied (
user ,
post : reply ,
notification_type : notification . notification_type ,
notification_data_hash : notification . data_hash
)
# WARNING: you reached the limit of 100 email notifications per day. Further emails will be suppressed.
# Consider watching less topics or disabling mailing list mode.
2019-07-30 15:05:08 -04:00
expect ( mail . html_part . body . to_s ) . to match ( I18n . t ( " user_notifications.reached_limit " , count : 2 ) )
2017-05-17 07:30:13 -04:00
expect ( mail . body . to_s ) . to match ( I18n . t ( " user_notifications.reached_limit " , count : 2 ) )
2016-03-23 00:08:34 -04:00
end
2019-11-17 20:25:42 -05:00
describe " secure media " do
let ( :video_upload ) { Fabricate ( :upload , extension : " mov " ) }
let ( :user ) { Fabricate ( :user ) }
let ( :post ) { Fabricate ( :post ) }
before do
SiteSetting . s3_upload_bucket = " some-bucket-on-s3 "
SiteSetting . s3_access_key_id = " s3-access-key-id "
SiteSetting . s3_secret_access_key = " s3-secret-access-key "
SiteSetting . s3_cdn_url = " https://s3.cdn.com "
SiteSetting . enable_s3_uploads = true
SiteSetting . secure_media = true
SiteSetting . login_required = true
video_upload . update! ( url : " #{ SiteSetting . s3_cdn_url } / #{ Discourse . store . get_path_for_upload ( video_upload ) } " )
user . email_logs . create! (
email_type : 'blah' ,
to_address : user . email ,
user_id : user . id
)
end
it " replaces secure audio/video with placeholder " do
reply = Fabricate ( :post , topic_id : post . topic_id , raw : " Video: #{ video_upload . url } " )
notification = Fabricate (
:notification ,
topic_id : post . topic_id ,
post_number : reply . post_number ,
user : post . user ,
data : { original_username : 'bob' } . to_json
)
mail = UserNotifications . user_replied (
user ,
post : reply ,
notification_type : notification . notification_type ,
notification_data_hash : notification . data_hash
)
expect ( mail . body . to_s ) . to match ( I18n . t ( " emails.secure_media_placeholder " ) )
end
end
2013-06-12 16:35:46 -04:00
def expects_build_with ( condition )
UserNotifications . any_instance . expects ( :build_email ) . with ( user . email , condition )
2019-05-06 21:27:05 -04:00
mailer = UserNotifications . public_send (
mail_type , user ,
notification_type : Notification . types [ notification . notification_type ] ,
notification_data_hash : notification . data_hash ,
post : notification . post
)
2016-01-26 20:19:49 -05:00
mailer . message
2013-06-12 16:35:46 -04:00
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
2017-04-24 15:26:06 -04:00
shared_examples " respect for private_email " do
context " private_email " do
it " doesn't support reply by email " do
SiteSetting . private_email = true
2019-05-06 21:27:05 -04:00
mailer = UserNotifications . public_send (
2017-04-24 15:26:06 -04:00
mail_type ,
user ,
notification_type : Notification . types [ notification . notification_type ] ,
notification_data_hash : notification . data_hash ,
post : notification . post
)
message = mailer . message
topic = notification . post . topic
expect ( message . html_part . body . to_s ) . not_to include ( topic . title )
expect ( message . html_part . body . to_s ) . not_to include ( topic . slug )
expect ( message . text_part . body . to_s ) . not_to include ( topic . title )
expect ( message . text_part . body . to_s ) . not_to include ( topic . slug )
end
end
end
2016-02-09 18:54:13 -05:00
# The parts of emails that are derived from templates are translated
shared_examples " sets user locale " do
context " set locale for translating templates " do
it " sets the locale " do
expects_build_with ( has_key ( :locale ) )
end
end
end
2013-06-12 16:35:46 -04:00
shared_examples " notification email building " do
2013-02-05 14:16:51 -05:00
let ( :post ) { Fabricate ( :post , user : user ) }
2017-07-27 21:20:09 -04:00
let ( :mail_type ) { " user_ #{ notification_type } " }
2017-07-26 02:51:44 -04:00
let ( :mail_template ) { " user_notifications. #{ mail_type } " }
2017-07-27 21:20:09 -04: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 ,
2017-07-27 21:20:09 -04:00
data : { original_username : username } . to_json )
2013-02-05 14:16:51 -05:00
end
2017-03-10 14:07:41 -05:00
describe 'email building' do
2013-06-12 16:35:46 -04:00
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
2017-07-26 02:51:44 -04:00
expects_build_with ( has_entry ( :template , mail_template ) )
2013-06-12 16:35:46 -04:00
end
2017-03-10 14:07:41 -05:00
it " overrides the html part " do
expects_build_with ( has_key ( :html_override ) )
end
2013-06-12 16:35:46 -04:00
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
2015-02-17 14:37:22 -05:00
it " should have user name as from_alias " do
SiteSetting . enable_names = true
SiteSetting . display_name_on_posts = true
2019-01-04 10:06:21 -05:00
expects_build_with ( has_entry ( :from_alias , " #{ user . name } via Discourse " ) )
2013-06-12 16:35:46 -04:00
end
2014-05-06 15:01:19 -04:00
2015-02-17 14:37:22 -05:00
it " should not have user name as from_alias if display_name_on_posts is disabled " do
SiteSetting . enable_names = false
SiteSetting . display_name_on_posts = false
2019-01-04 10:06:21 -05:00
expects_build_with ( has_entry ( :from_alias , " walterwhite via Discourse " ) )
2015-02-17 14:37:22 -05: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
2017-03-10 14:07:41 -05:00
context " when customized " do
2017-06-15 20:39:54 -04:00
let ( :custom_body ) do
2019-04-29 20:27:42 -04:00
body = + << ~ BODY
2019-01-17 17:46:04 -05:00
You are now officially notified .
%{ header_instructions }
%{ message } %{ respond_instructions }
%{ topic_title_url_encoded }
%{ site_title_url_encoded }
2017-06-15 20:39:54 -04:00
BODY
body << " %{context} " if notification_type != :invited_to_topic
body
end
2017-03-10 14:07:41 -05:00
before do
2017-07-26 02:51:44 -04:00
TranslationOverride . upsert! (
2019-05-15 17:43:00 -04:00
SiteSetting . default_locale ,
2017-07-26 02:51:44 -04:00
" #{ mail_template } .text_body_template " ,
custom_body
)
2017-03-10 14:07:41 -05:00
end
it " shouldn't use the default html_override " do
expects_build_with ( Not ( has_key ( :html_override ) ) )
end
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 }
2017-04-24 15:26:06 -04:00
include_examples " respect for private_email "
2013-06-12 16:35:46 -04:00
include_examples " supports reply by email "
2016-02-09 18:54:13 -05:00
include_examples " sets user locale "
2013-06-12 16:35:46 -04:00
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 }
2017-04-24 15:26:06 -04:00
include_examples " respect for private_email "
2013-06-12 16:35:46 -04:00
include_examples " supports reply by email "
2016-02-09 18:54:13 -05:00
include_examples " sets user locale "
2013-06-12 16:35:46 -04:00
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 }
2017-04-24 15:26:06 -04:00
include_examples " respect for private_email "
2013-06-12 16:35:46 -04:00
include_examples " supports reply by email "
2016-02-09 18:54:13 -05:00
include_examples " sets user locale "
2013-06-12 16:35:46 -04:00
end
end
describe " user posted " do
include_examples " notification email building " do
let ( :notification_type ) { :posted }
2017-04-24 15:26:06 -04:00
include_examples " respect for private_email "
2013-06-12 16:35:46 -04:00
include_examples " supports reply by email "
2016-02-09 18:54:13 -05:00
include_examples " sets user locale "
2013-06-12 16:35:46 -04:00
end
end
describe " user invited to a private message " do
include_examples " notification email building " do
let ( :notification_type ) { :invited_to_private_message }
2017-07-26 02:51:44 -04:00
let ( :post ) { Fabricate ( :private_message_post ) }
let ( :user ) { post . user }
let ( :mail_template ) { " user_notifications.user_ #{ notification_type } _pm " }
include_examples " respect for private_email "
include_examples " no reply by email "
include_examples " sets user locale "
end
end
describe " group invited to a private message " do
include_examples " notification email building " do
let ( :notification_type ) { :invited_to_private_message }
let ( :post ) { Fabricate ( :private_message_post ) }
let ( :user ) { post . user }
let ( :group ) { Fabricate ( :group ) }
let ( :mail_template ) { " user_notifications.user_ #{ notification_type } _pm_group " }
before do
notification . data_hash [ :group_id ] = group . id
notification . save!
end
it " should include the group name " do
expects_build_with ( has_entry ( :group_name , group . name ) )
end
2017-04-24 15:26:06 -04:00
include_examples " respect for private_email "
2013-06-12 16:35:46 -04:00
include_examples " no reply by email "
2016-02-09 18:54:13 -05:00
include_examples " sets user locale "
2013-06-12 16:35:46 -04:00
end
end
2015-03-30 14:36:47 -04:00
describe " user invited to a topic " do
include_examples " notification email building " do
let ( :notification_type ) { :invited_to_topic }
2017-04-24 15:26:06 -04:00
include_examples " respect for private_email "
2016-07-07 12:23:19 -04:00
include_examples " no reply by email "
include_examples " sets user locale "
end
end
describe " watching first post " do
include_examples " notification email building " do
let ( :notification_type ) { :invited_to_topic }
2017-04-24 15:26:06 -04:00
include_examples " respect for private_email "
2015-03-30 14:36:47 -04:00
include_examples " no reply by email "
2016-02-09 18:54:13 -05:00
include_examples " sets user locale "
2015-03-30 14:36:47 -04:00
end
end
2016-02-09 18:54:13 -05:00
# notification emails derived from templates are translated into the user's locale
shared_examples " notification derived from template " do
let ( :user ) { Fabricate ( :user , locale : locale ) }
let ( :mail_type ) { mail_type }
let ( :notification ) { Fabricate ( :notification , user : user ) }
end
describe " notifications from template " do
2018-09-05 05:44:26 -04:00
context " user locale is allowed " do
before do
SiteSetting . allow_user_locale = true
end
2016-02-09 18:54:13 -05:00
2016-03-07 14:40:11 -05:00
%w( signup signup_after_approval confirm_old_email notify_old_email confirm_new_email
forgot_password admin_login account_created ) . each do | mail_type |
2016-02-09 18:54:13 -05:00
include_examples " notification derived from template " do
let ( :locale ) { " fr " }
let ( :mail_type ) { mail_type }
it " sets the locale " do
expects_build_with ( has_entry ( :locale , " fr " ) )
end
end
end
end
2018-09-05 05:44:26 -04:00
context " user locale is not allowed " do
before do
SiteSetting . allow_user_locale = false
2016-02-09 18:54:13 -05:00
end
2016-03-04 16:21:30 -05:00
2018-09-05 05:44:26 -04:00
%w( signup signup_after_approval notify_old_email confirm_old_email confirm_new_email
2016-03-07 14:40:11 -05:00
forgot_password admin_login account_created ) . each do | mail_type |
2016-03-04 16:21:30 -05:00
include_examples " notification derived from template " do
2018-09-05 05:44:26 -04:00
let ( :locale ) { " fr " }
2016-03-04 16:21:30 -05:00
let ( :mail_type ) { mail_type }
it " sets the locale " do
2019-05-15 17:43:00 -04:00
expects_build_with ( has_entry ( :locale , " en_US " ) )
2016-03-04 16:21:30 -05:00
end
end
end
end
2016-02-09 18:54:13 -05:00
end
2013-02-05 14:16:51 -05:00
end