mailer_test.rb
853 lines
| 28.8 KiB
| text/x-ruby
|
RubyLexer
|
r4883 | # Redmine - project management software | ||
|
r13490 | # Copyright (C) 2006-2015 Jean-Philippe Lang | ||
|
r212 | # | ||
# This program is free software; you can redistribute it and/or | ||||
# modify it under the terms of the GNU General Public License | ||||
# as published by the Free Software Foundation; either version 2 | ||||
# of the License, or (at your option) any later version. | ||||
|
r6806 | # | ||
|
r212 | # This program is distributed in the hope that it will be useful, | ||
# but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||||
# GNU General Public License for more details. | ||||
|
r6806 | # | ||
|
r212 | # You should have received a copy of the GNU General Public License | ||
# along with this program; if not, write to the Free Software | ||||
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | ||||
|
r4395 | require File.expand_path('../../test_helper', __FILE__) | ||
|
r212 | |||
|
r2773 | class MailerTest < ActiveSupport::TestCase | ||
|
r2430 | include Redmine::I18n | ||
|
r13510 | include Rails::Dom::Testing::Assertions | ||
|
r13504 | fixtures :projects, :enabled_modules, :issues, :users, :email_addresses, :members, | ||
|
r7377 | :member_roles, :roles, :documents, :attachments, :news, | ||
|
r9451 | :tokens, :journals, :journal_details, :changesets, | ||
:trackers, :projects_trackers, | ||||
|
r7377 | :issue_statuses, :enumerations, :messages, :boards, :repositories, | ||
:wikis, :wiki_pages, :wiki_contents, :wiki_content_versions, | ||||
:versions, | ||||
:comments | ||||
|
r6806 | |||
|
r3344 | def setup | ||
ActionMailer::Base.deliveries.clear | ||||
Setting.host_name = 'mydomain.foo' | ||||
Setting.protocol = 'http' | ||||
|
r5110 | Setting.plain_text_mail = '0' | ||
|
r13543 | Setting.default_language = 'en' | ||
|
r13100 | User.current = nil | ||
|
r3344 | end | ||
|
r6806 | |||
|
r1147 | def test_generated_links_in_emails | ||
Setting.host_name = 'mydomain.foo' | ||||
Setting.protocol = 'https' | ||||
|
r6806 | |||
|
r8902 | journal = Journal.find(3) | ||
|
r11782 | assert Mailer.deliver_issue_edit(journal) | ||
|
r6806 | |||
|
r8902 | mail = last_email | ||
|
r8871 | assert_not_nil mail | ||
|
r6806 | |||
|
r2935 | assert_select_email do | ||
# link to the main ticket | ||||
|
r8902 | assert_select 'a[href=?]', | ||
'https://mydomain.foo/issues/2#change-3', | ||||
:text => 'Feature request #2: Add ingredients categories' | ||||
|
r2935 | # link to a referenced ticket | ||
|
r8902 | assert_select 'a[href=?][title=?]', | ||
'https://mydomain.foo/issues/1', | ||||
|
r14238 | "Bug: Cannot print recipes (New)", | ||
|
r8902 | :text => '#1' | ||
|
r2935 | # link to a changeset | ||
|
r8902 | assert_select 'a[href=?][title=?]', | ||
'https://mydomain.foo/projects/ecookbook/repository/revisions/2', | ||||
|
r13510 | 'This commit fixes #1, #2 and references #1 & #3', | ||
|
r8902 | :text => 'r2' | ||
# link to a description diff | ||||
|
r13510 | assert_select 'a[href^=?][title=?]', | ||
# should be https://mydomain.foo/journals/diff/3?detail_id=4 | ||||
# but the Rails 4.2 DOM assertion doesn't handle the ? in the | ||||
# attribute value | ||||
'https://mydomain.foo/journals/diff/3', | ||||
|
r8902 | 'View differences', | ||
:text => 'diff' | ||||
# link to an attachment | ||||
assert_select 'a[href=?]', | ||||
'https://mydomain.foo/attachments/download/4/source.rb', | ||||
:text => 'source.rb' | ||||
|
r2935 | end | ||
|
r1147 | end | ||
|
r6806 | |||
|
r1990 | def test_generated_links_with_prefix | ||
|
r2232 | relative_url_root = Redmine::Utils.relative_url_root | ||
|
r1990 | Setting.host_name = 'mydomain.foo/rdm' | ||
Setting.protocol = 'http' | ||||
|
r6806 | |||
|
r8902 | journal = Journal.find(3) | ||
|
r11782 | assert Mailer.deliver_issue_edit(journal) | ||
|
r6806 | |||
|
r8902 | mail = last_email | ||
|
r8871 | assert_not_nil mail | ||
|
r2935 | |||
assert_select_email do | ||||
# link to the main ticket | ||||
|
r8902 | assert_select 'a[href=?]', | ||
'http://mydomain.foo/rdm/issues/2#change-3', | ||||
:text => 'Feature request #2: Add ingredients categories' | ||||
|
r2935 | # link to a referenced ticket | ||
|
r8902 | assert_select 'a[href=?][title=?]', | ||
'http://mydomain.foo/rdm/issues/1', | ||||
|
r14238 | "Bug: Cannot print recipes (New)", | ||
|
r8902 | :text => '#1' | ||
|
r2935 | # link to a changeset | ||
|
r8902 | assert_select 'a[href=?][title=?]', | ||
'http://mydomain.foo/rdm/projects/ecookbook/repository/revisions/2', | ||||
|
r13510 | 'This commit fixes #1, #2 and references #1 & #3', | ||
|
r8902 | :text => 'r2' | ||
# link to a description diff | ||||
|
r13510 | assert_select 'a[href^=?][title=?]', | ||
# should be http://mydomain.foo/rdm/journals/diff/3?detail_id=4 | ||||
# but the Rails 4.2 DOM assertion doesn't handle the ? in the | ||||
# attribute value | ||||
'http://mydomain.foo/rdm/journals/diff/3', | ||||
|
r8902 | 'View differences', | ||
:text => 'diff' | ||||
# link to an attachment | ||||
assert_select 'a[href=?]', | ||||
'http://mydomain.foo/rdm/attachments/download/4/source.rb', | ||||
:text => 'source.rb' | ||||
|
r2935 | end | ||
|
r1990 | end | ||
|
r6806 | |||
|
r13699 | def test_generated_links_with_port_and_prefix | ||
with_settings :host_name => '10.0.0.1:81/redmine', :protocol => 'http' do | ||||
Mailer.test_email(User.find(1)).deliver | ||||
mail = last_email | ||||
assert_not_nil mail | ||||
assert_include 'http://10.0.0.1:81/redmine', mail_body(mail) | ||||
end | ||||
end | ||||
def test_generated_links_with_port | ||||
with_settings :host_name => '10.0.0.1:81', :protocol => 'http' do | ||||
Mailer.test_email(User.find(1)).deliver | ||||
mail = last_email | ||||
assert_not_nil mail | ||||
assert_include 'http://10.0.0.1:81', mail_body(mail) | ||||
end | ||||
end | ||||
|
r12140 | def test_issue_edit_should_generate_url_with_hostname_for_relations | ||
journal = Journal.new(:journalized => Issue.find(1), :user => User.find(1), :created_on => Time.now) | ||||
journal.details << JournalDetail.new(:property => 'relation', :prop_key => 'label_relates_to', :value => 2) | ||||
Mailer.deliver_issue_edit(journal) | ||||
assert_not_nil last_email | ||||
assert_select_email do | ||||
assert_select 'a[href=?]', 'http://mydomain.foo/issues/2', :text => 'Feature request #2' | ||||
end | ||||
end | ||||
|
r1990 | def test_generated_links_with_prefix_and_no_relative_url_root | ||
|
r2232 | relative_url_root = Redmine::Utils.relative_url_root | ||
|
r1990 | Setting.host_name = 'mydomain.foo/rdm' | ||
Setting.protocol = 'http' | ||||
|
r2232 | Redmine::Utils.relative_url_root = nil | ||
|
r6806 | |||
|
r8902 | journal = Journal.find(3) | ||
|
r11782 | assert Mailer.deliver_issue_edit(journal) | ||
|
r6806 | |||
|
r8902 | mail = last_email | ||
|
r8871 | assert_not_nil mail | ||
|
r2935 | |||
assert_select_email do | ||||
# link to the main ticket | ||||
|
r8902 | assert_select 'a[href=?]', | ||
'http://mydomain.foo/rdm/issues/2#change-3', | ||||
:text => 'Feature request #2: Add ingredients categories' | ||||
|
r2935 | # link to a referenced ticket | ||
|
r8902 | assert_select 'a[href=?][title=?]', | ||
'http://mydomain.foo/rdm/issues/1', | ||||
|
r14238 | "Bug: Cannot print recipes (New)", | ||
|
r8902 | :text => '#1' | ||
|
r2935 | # link to a changeset | ||
|
r8902 | assert_select 'a[href=?][title=?]', | ||
'http://mydomain.foo/rdm/projects/ecookbook/repository/revisions/2', | ||||
|
r13510 | 'This commit fixes #1, #2 and references #1 & #3', | ||
|
r8902 | :text => 'r2' | ||
# link to a description diff | ||||
|
r13510 | assert_select 'a[href^=?][title=?]', | ||
# should be http://mydomain.foo/rdm/journals/diff/3?detail_id=4 | ||||
# but the Rails 4.2 DOM assertion doesn't handle the ? in the | ||||
# attribute value | ||||
'http://mydomain.foo/rdm/journals/diff/3', | ||||
|
r8902 | 'View differences', | ||
:text => 'diff' | ||||
# link to an attachment | ||||
assert_select 'a[href=?]', | ||||
'http://mydomain.foo/rdm/attachments/download/4/source.rb', | ||||
:text => 'source.rb' | ||||
|
r2935 | end | ||
|
r1990 | ensure | ||
# restore it | ||||
|
r2232 | Redmine::Utils.relative_url_root = relative_url_root | ||
|
r1990 | end | ||
|
r6806 | |||
|
r2566 | def test_email_headers | ||
issue = Issue.find(1) | ||||
|
r11782 | Mailer.deliver_issue_add(issue) | ||
|
r8902 | mail = last_email | ||
|
r2566 | assert_not_nil mail | ||
|
r13777 | assert_equal 'All', mail.header['X-Auto-Response-Suppress'].to_s | ||
|
r9346 | assert_equal 'auto-generated', mail.header['Auto-Submitted'].to_s | ||
|
r9504 | assert_equal '<redmine.example.net>', mail.header['List-Id'].to_s | ||
|
r2566 | end | ||
|
r1930 | |||
|
r8665 | def test_email_headers_should_include_sender | ||
issue = Issue.find(1) | ||||
|
r11782 | Mailer.deliver_issue_add(issue) | ||
|
r8902 | mail = last_email | ||
|
r9346 | assert_equal issue.author.login, mail.header['X-Redmine-Sender'].to_s | ||
|
r8665 | end | ||
|
r1930 | def test_plain_text_mail | ||
Setting.plain_text_mail = 1 | ||||
journal = Journal.find(2) | ||||
|
r11782 | Mailer.deliver_issue_edit(journal) | ||
|
r8902 | mail = last_email | ||
|
r9346 | assert_equal "text/plain; charset=UTF-8", mail.content_type | ||
|
r2847 | assert_equal 0, mail.parts.size | ||
|
r2773 | assert !mail.encoded.include?('href') | ||
|
r1930 | end | ||
|
r2773 | |||
def test_html_mail | ||||
Setting.plain_text_mail = 0 | ||||
journal = Journal.find(2) | ||||
|
r11782 | Mailer.deliver_issue_edit(journal) | ||
|
r8902 | mail = last_email | ||
|
r2773 | assert_equal 2, mail.parts.size | ||
assert mail.encoded.include?('href') | ||||
end | ||||
|
r6806 | |||
|
r7687 | def test_from_header | ||
with_settings :mail_from => 'redmine@example.net' do | ||||
|
r9455 | Mailer.test_email(User.find(1)).deliver | ||
|
r7687 | end | ||
|
r8902 | mail = last_email | ||
|
r9346 | assert_equal 'redmine@example.net', mail.from_addrs.first | ||
|
r7687 | end | ||
def test_from_header_with_phrase | ||||
|
r3329 | with_settings :mail_from => 'Redmine app <redmine@example.net>' do | ||
|
r9455 | Mailer.test_email(User.find(1)).deliver | ||
|
r3329 | end | ||
|
r8902 | mail = last_email | ||
|
r9346 | assert_equal 'redmine@example.net', mail.from_addrs.first | ||
assert_equal 'Redmine app <redmine@example.net>', mail.header['From'].to_s | ||||
|
r3329 | end | ||
|
r6806 | |||
|
r3404 | def test_should_not_send_email_without_recipient | ||
|
r10701 | news = News.first | ||
|
r3404 | user = news.author | ||
# Remove members except news author | ||||
news.project.memberships.each {|m| m.destroy unless m.user == user} | ||||
|
r6806 | |||
|
r11609 | user.pref.no_self_notified = false | ||
|
r3404 | user.pref.save | ||
User.current = user | ||||
|
r9455 | Mailer.news_added(news.reload).deliver | ||
|
r3404 | assert_equal 1, last_email.bcc.size | ||
# nobody to notify | ||||
|
r11609 | user.pref.no_self_notified = true | ||
|
r3404 | user.pref.save | ||
User.current = user | ||||
ActionMailer::Base.deliveries.clear | ||||
|
r9455 | Mailer.news_added(news.reload).deliver | ||
|
r3404 | assert ActionMailer::Base.deliveries.empty? | ||
end | ||||
|
r2773 | |||
|
r2279 | def test_issue_add_message_id | ||
|
r11782 | issue = Issue.find(2) | ||
Mailer.deliver_issue_add(issue) | ||||
|
r8902 | mail = last_email | ||
|
r11782 | assert_match /^redmine\.issue-2\.20060719190421\.[a-f0-9]+@example\.net/, mail.message_id | ||
assert_include "redmine.issue-2.20060719190421@example.net", mail.references | ||||
|
r2279 | end | ||
|
r6806 | |||
|
r2279 | def test_issue_edit_message_id | ||
|
r11782 | journal = Journal.find(3) | ||
journal.issue = Issue.find(2) | ||||
Mailer.deliver_issue_edit(journal) | ||||
|
r8902 | mail = last_email | ||
|
r11782 | assert_match /^redmine\.journal-3\.\d+\.[a-f0-9]+@example\.net/, mail.message_id | ||
assert_include "redmine.issue-2.20060719190421@example.net", mail.references | ||||
|
r7910 | assert_select_email do | ||
# link to the update | ||||
assert_select "a[href=?]", | ||||
"http://mydomain.foo/issues/#{journal.journalized_id}#change-#{journal.id}" | ||||
end | ||||
|
r2279 | end | ||
|
r6806 | |||
|
r2279 | def test_message_posted_message_id | ||
message = Message.find(1) | ||||
|
r9455 | Mailer.message_posted(message).deliver | ||
|
r8902 | mail = last_email | ||
|
r11782 | assert_match /^redmine\.message-1\.\d+\.[a-f0-9]+@example\.net/, mail.message_id | ||
assert_include "redmine.message-1.20070512151532@example.net", mail.references | ||||
|
r3344 | assert_select_email do | ||
# link to the message | ||||
|
r7381 | assert_select "a[href=?]", | ||
"http://mydomain.foo/boards/#{message.board.id}/topics/#{message.id}", | ||||
:text => message.subject | ||||
|
r3344 | end | ||
|
r2279 | end | ||
|
r6806 | |||
|
r2279 | def test_reply_posted_message_id | ||
message = Message.find(3) | ||||
|
r9455 | Mailer.message_posted(message).deliver | ||
|
r8902 | mail = last_email | ||
|
r11782 | assert_match /^redmine\.message-3\.\d+\.[a-f0-9]+@example\.net/, mail.message_id | ||
assert_include "redmine.message-1.20070512151532@example.net", mail.references | ||||
|
r3344 | assert_select_email do | ||
# link to the reply | ||||
|
r7382 | assert_select "a[href=?]", | ||
"http://mydomain.foo/boards/#{message.board.id}/topics/#{message.root.id}?r=#{message.id}#message-#{message.id}", | ||||
:text => message.subject | ||||
|
r3344 | end | ||
|
r2279 | end | ||
|
r6806 | |||
|
r11085 | test "#issue_add should notify project members" do | ||
issue = Issue.find(1) | ||||
|
r11782 | assert Mailer.deliver_issue_add(issue) | ||
|
r11085 | assert last_email.bcc.include?('dlopper@somenet.foo') | ||
end | ||||
|
r6806 | |||
|
r13504 | def test_issue_add_should_send_mail_to_all_user_email_address | ||
EmailAddress.create!(:user_id => 3, :address => 'otheremail@somenet.foo') | ||||
issue = Issue.find(1) | ||||
assert Mailer.deliver_issue_add(issue) | ||||
assert last_email.bcc.include?('dlopper@somenet.foo') | ||||
assert last_email.bcc.include?('otheremail@somenet.foo') | ||||
end | ||||
|
r11085 | test "#issue_add should not notify project members that are not allow to view the issue" do | ||
issue = Issue.find(1) | ||||
Role.find(2).remove_permission!(:view_issues) | ||||
|
r11782 | assert Mailer.deliver_issue_add(issue) | ||
|
r11085 | assert !last_email.bcc.include?('dlopper@somenet.foo') | ||
end | ||||
|
r6806 | |||
|
r11085 | test "#issue_add should notify issue watchers" do | ||
issue = Issue.find(1) | ||||
user = User.find(9) | ||||
# minimal email notification options | ||||
|
r11609 | user.pref.no_self_notified = '1' | ||
|
r11085 | user.pref.save | ||
user.mail_notification = false | ||||
user.save | ||||
|
r6806 | |||
|
r11085 | Watcher.create!(:watchable => issue, :user => user) | ||
|
r11782 | assert Mailer.deliver_issue_add(issue) | ||
|
r11085 | assert last_email.bcc.include?(user.mail) | ||
end | ||||
|
r6806 | |||
|
r11085 | test "#issue_add should not notify watchers not allowed to view the issue" do | ||
issue = Issue.find(1) | ||||
user = User.find(9) | ||||
Watcher.create!(:watchable => issue, :user => user) | ||||
Role.non_member.remove_permission!(:view_issues) | ||||
|
r11782 | assert Mailer.deliver_issue_add(issue) | ||
|
r11085 | assert !last_email.bcc.include?(user.mail) | ||
|
r3055 | end | ||
|
r6806 | |||
|
r11849 | def test_issue_add_should_include_enabled_fields | ||
issue = Issue.find(2) | ||||
assert Mailer.deliver_issue_add(issue) | ||||
assert_mail_body_match '* Target version: 1.0', last_email | ||||
assert_select_email do | ||||
assert_select 'li', :text => 'Target version: 1.0' | ||||
end | ||||
end | ||||
def test_issue_add_should_not_include_disabled_fields | ||||
issue = Issue.find(2) | ||||
tracker = issue.tracker | ||||
tracker.core_fields -= ['fixed_version_id'] | ||||
tracker.save! | ||||
assert Mailer.deliver_issue_add(issue) | ||||
assert_mail_body_no_match 'Target version', last_email | ||||
assert_select_email do | ||||
assert_select 'li', :text => /Target version/, :count => 0 | ||||
end | ||||
end | ||||
|
r212 | # test mailer methods for each language | ||
def test_issue_add | ||||
issue = Issue.find(1) | ||||
|
r13543 | with_each_language_as_default do | ||
|
r11782 | assert Mailer.deliver_issue_add(issue) | ||
|
r212 | end | ||
end | ||||
def test_issue_edit | ||||
journal = Journal.find(1) | ||||
|
r13543 | with_each_language_as_default do | ||
|
r11782 | assert Mailer.deliver_issue_edit(journal) | ||
|
r212 | end | ||
end | ||||
|
r6806 | |||
|
r10336 | def test_issue_edit_should_send_private_notes_to_users_with_permission_only | ||
journal = Journal.find(1) | ||||
journal.private_notes = true | ||||
journal.save! | ||||
Role.find(2).add_permission! :view_private_notes | ||||
|
r11782 | Mailer.deliver_issue_edit(journal) | ||
|
r10336 | assert_equal %w(dlopper@somenet.foo jsmith@somenet.foo), ActionMailer::Base.deliveries.last.bcc.sort | ||
Role.find(2).remove_permission! :view_private_notes | ||||
|
r11782 | Mailer.deliver_issue_edit(journal) | ||
|
r10336 | assert_equal %w(jsmith@somenet.foo), ActionMailer::Base.deliveries.last.bcc.sort | ||
end | ||||
|
r10567 | def test_issue_edit_should_send_private_notes_to_watchers_with_permission_only | ||
Issue.find(1).set_watcher(User.find_by_login('someone')) | ||||
journal = Journal.find(1) | ||||
journal.private_notes = true | ||||
journal.save! | ||||
Role.non_member.add_permission! :view_private_notes | ||||
|
r11782 | Mailer.deliver_issue_edit(journal) | ||
|
r10567 | assert_include 'someone@foo.bar', ActionMailer::Base.deliveries.last.bcc.sort | ||
Role.non_member.remove_permission! :view_private_notes | ||||
|
r11782 | Mailer.deliver_issue_edit(journal) | ||
|
r10567 | assert_not_include 'someone@foo.bar', ActionMailer::Base.deliveries.last.bcc.sort | ||
end | ||||
|
r11639 | def test_issue_edit_should_mark_private_notes | ||
journal = Journal.find(2) | ||||
journal.private_notes = true | ||||
journal.save! | ||||
with_settings :default_language => 'en' do | ||||
|
r11782 | Mailer.deliver_issue_edit(journal) | ||
|
r11639 | end | ||
assert_mail_body_match '(Private notes)', last_email | ||||
end | ||||
|
r11785 | def test_issue_edit_with_relation_should_notify_users_who_can_see_the_related_issue | ||
issue = Issue.generate! | ||||
|
r13152 | issue.init_journal(User.find(1)) | ||
|
r11785 | private_issue = Issue.generate!(:is_private => true) | ||
IssueRelation.create!(:issue_from => issue, :issue_to => private_issue, :relation_type => 'relates') | ||||
issue.reload | ||||
assert_equal 1, issue.journals.size | ||||
journal = issue.journals.first | ||||
ActionMailer::Base.deliveries.clear | ||||
Mailer.deliver_issue_edit(journal) | ||||
last_email.bcc.each do |email| | ||||
user = User.find_by_mail(email) | ||||
assert private_issue.visible?(user), "Issue was not visible to #{user}" | ||||
end | ||||
end | ||||
|
r864 | def test_document_added | ||
|
r212 | document = Document.find(1) | ||
|
r13543 | with_each_language_as_default do | ||
|
r9455 | assert Mailer.document_added(document).deliver | ||
|
r212 | end | ||
end | ||||
|
r6806 | |||
|
r864 | def test_attachments_added | ||
attachements = [ Attachment.find_by_container_type('Document') ] | ||||
|
r13543 | with_each_language_as_default do | ||
|
r9455 | assert Mailer.attachments_added(attachements).deliver | ||
|
r864 | end | ||
end | ||||
|
r6806 | |||
|
r3418 | def test_version_file_added | ||
attachements = [ Attachment.find_by_container_type('Version') ] | ||||
|
r9455 | assert Mailer.attachments_added(attachements).deliver | ||
|
r3418 | assert_not_nil last_email.bcc | ||
assert last_email.bcc.any? | ||||
|
r5110 | assert_select_email do | ||
assert_select "a[href=?]", "http://mydomain.foo/projects/ecookbook/files" | ||||
end | ||||
|
r3418 | end | ||
|
r6806 | |||
|
r3418 | def test_project_file_added | ||
attachements = [ Attachment.find_by_container_type('Project') ] | ||||
|
r9455 | assert Mailer.attachments_added(attachements).deliver | ||
|
r3418 | assert_not_nil last_email.bcc | ||
assert last_email.bcc.any? | ||||
|
r5110 | assert_select_email do | ||
assert_select "a[href=?]", "http://mydomain.foo/projects/ecookbook/files" | ||||
end | ||||
|
r3418 | end | ||
|
r6806 | |||
|
r864 | def test_news_added | ||
|
r10701 | news = News.first | ||
|
r13543 | with_each_language_as_default do | ||
|
r9455 | assert Mailer.news_added(news).deliver | ||
|
r864 | end | ||
end | ||||
|
r6806 | |||
|
r12591 | def test_news_added_should_notify_project_news_watchers | ||
user1 = User.generate! | ||||
user2 = User.generate! | ||||
|
r12595 | news = News.find(1) | ||
|
r12591 | news.project.enabled_module('news').add_watcher(user1) | ||
Mailer.news_added(news).deliver | ||||
assert_include user1.mail, last_email.bcc | ||||
assert_not_include user2.mail, last_email.bcc | ||||
end | ||||
|
r4883 | def test_news_comment_added | ||
comment = Comment.find(2) | ||||
|
r13543 | with_each_language_as_default do | ||
|
r9455 | assert Mailer.news_comment_added(comment).deliver | ||
|
r4883 | end | ||
end | ||||
|
r6806 | |||
|
r864 | def test_message_posted | ||
|
r10701 | message = Message.first | ||
|
r864 | recipients = ([message.root] + message.root.children).collect {|m| m.author.mail if m.author} | ||
recipients = recipients.compact.uniq | ||||
|
r13543 | with_each_language_as_default do | ||
|
r9455 | assert Mailer.message_posted(message).deliver | ||
|
r864 | end | ||
end | ||||
|
r6806 | |||
|
r4365 | def test_wiki_content_added | ||
|
r8908 | content = WikiContent.find(1) | ||
|
r13543 | with_each_language_as_default do | ||
|
r4365 | assert_difference 'ActionMailer::Base.deliveries.size' do | ||
|
r9455 | assert Mailer.wiki_content_added(content).deliver | ||
|
r9713 | assert_select_email do | ||
assert_select 'a[href=?]', | ||||
'http://mydomain.foo/projects/ecookbook/wiki/CookBook_documentation', | ||||
:text => 'CookBook documentation' | ||||
end | ||||
|
r4365 | end | ||
end | ||||
end | ||||
|
r6806 | |||
|
r4365 | def test_wiki_content_updated | ||
|
r8908 | content = WikiContent.find(1) | ||
|
r13543 | with_each_language_as_default do | ||
|
r4365 | assert_difference 'ActionMailer::Base.deliveries.size' do | ||
|
r9455 | assert Mailer.wiki_content_updated(content).deliver | ||
|
r9713 | assert_select_email do | ||
assert_select 'a[href=?]', | ||||
'http://mydomain.foo/projects/ecookbook/wiki/CookBook_documentation', | ||||
:text => 'CookBook documentation' | ||||
end | ||||
|
r4365 | end | ||
end | ||||
end | ||||
|
r6806 | |||
|
r864 | def test_account_information | ||
|
r3593 | user = User.find(2) | ||
|
r2430 | valid_languages.each do |lang| | ||
|
r864 | user.update_attribute :language, lang.to_s | ||
user.reload | ||||
|
r9455 | assert Mailer.account_information(user, 'pAsswORd').deliver | ||
|
r864 | end | ||
end | ||||
|
r212 | |||
def test_lost_password | ||||
token = Token.find(2) | ||||
|
r2430 | valid_languages.each do |lang| | ||
|
r320 | token.user.update_attribute :language, lang.to_s | ||
|
r864 | token.reload | ||
|
r9455 | assert Mailer.lost_password(token).deliver | ||
|
r212 | end | ||
end | ||||
def test_register | ||||
token = Token.find(1) | ||||
|
r2493 | Setting.host_name = 'redmine.foo' | ||
Setting.protocol = 'https' | ||||
|
r6806 | |||
|
r2430 | valid_languages.each do |lang| | ||
|
r320 | token.user.update_attribute :language, lang.to_s | ||
|
r864 | token.reload | ||
|
r2493 | ActionMailer::Base.deliveries.clear | ||
|
r9455 | assert Mailer.register(token).deliver | ||
|
r8902 | mail = last_email | ||
|
r8796 | assert_select_email do | ||
assert_select "a[href=?]", | ||||
"https://redmine.foo/account/activate?token=#{token.value}", | ||||
:text => "https://redmine.foo/account/activate?token=#{token.value}" | ||||
end | ||||
|
r212 | end | ||
end | ||||
|
r6806 | |||
|
r3494 | def test_test | ||
user = User.find(1) | ||||
valid_languages.each do |lang| | ||||
user.update_attribute :language, lang.to_s | ||||
|
r9455 | assert Mailer.test_email(user).deliver | ||
|
r3494 | end | ||
end | ||||
|
r6806 | |||
|
r1445 | def test_reminders | ||
Mailer.reminders(:days => 42) | ||||
assert_equal 1, ActionMailer::Base.deliveries.size | ||||
|
r8902 | mail = last_email | ||
|
r1445 | assert mail.bcc.include?('dlopper@somenet.foo') | ||
|
r8966 | assert_mail_body_match 'Bug #3: Error 281 when updating a recipe', mail | ||
|
r3793 | assert_equal '1 issue(s) due in the next 42 days', mail.subject | ||
|
r1445 | end | ||
|
r6806 | |||
|
r8570 | def test_reminders_should_not_include_closed_issues | ||
|
r8798 | with_settings :default_language => 'en' do | ||
|
r8958 | Issue.create!(:project_id => 1, :tracker_id => 1, :status_id => 5, | ||
|
r8798 | :subject => 'Closed issue', :assigned_to_id => 3, | ||
|
r8958 | :due_date => 5.days.from_now, | ||
:author_id => 2) | ||||
|
r8798 | ActionMailer::Base.deliveries.clear | ||
|
r8570 | |||
|
r8798 | Mailer.reminders(:days => 42) | ||
assert_equal 1, ActionMailer::Base.deliveries.size | ||||
|
r8902 | mail = last_email | ||
|
r8798 | assert mail.bcc.include?('dlopper@somenet.foo') | ||
|
r8966 | assert_mail_body_no_match 'Closed issue', mail | ||
|
r8798 | end | ||
|
r8570 | end | ||
|
r4053 | def test_reminders_for_users | ||
Mailer.reminders(:days => 42, :users => ['5']) | ||||
assert_equal 0, ActionMailer::Base.deliveries.size # No mail for dlopper | ||||
Mailer.reminders(:days => 42, :users => ['3']) | ||||
assert_equal 1, ActionMailer::Base.deliveries.size # No mail for dlopper | ||||
|
r8902 | mail = last_email | ||
|
r4053 | assert mail.bcc.include?('dlopper@somenet.foo') | ||
|
r8966 | assert_mail_body_match 'Bug #3: Error 281 when updating a recipe', mail | ||
|
r4053 | end | ||
|
r6806 | |||
|
r10152 | def test_reminder_should_include_issues_assigned_to_groups | ||
with_settings :default_language => 'en' do | ||||
group = Group.generate! | ||||
group.users << User.find(2) | ||||
group.users << User.find(3) | ||||
Issue.create!(:project_id => 1, :tracker_id => 1, :status_id => 1, | ||||
:subject => 'Assigned to group', :assigned_to => group, | ||||
:due_date => 5.days.from_now, | ||||
:author_id => 2) | ||||
ActionMailer::Base.deliveries.clear | ||||
Mailer.reminders(:days => 7) | ||||
assert_equal 2, ActionMailer::Base.deliveries.size | ||||
assert_equal %w(dlopper@somenet.foo jsmith@somenet.foo), ActionMailer::Base.deliveries.map(&:bcc).flatten.sort | ||||
ActionMailer::Base.deliveries.each do |mail| | ||||
assert_mail_body_match 'Assigned to group', mail | ||||
end | ||||
end | ||||
end | ||||
|
r13585 | def test_reminders_with_version_option | ||
|
r13582 | with_settings :default_language => 'en' do | ||
|
r13584 | version = Version.generate!(:name => 'Acme', :project_id => 1) | ||
Issue.generate!(:assigned_to => User.find(2), :due_date => 5.days.from_now) | ||||
Issue.generate!(:assigned_to => User.find(3), :due_date => 5.days.from_now, :fixed_version => version) | ||||
|
r13582 | ActionMailer::Base.deliveries.clear | ||
|
r13584 | |||
Mailer.reminders(:days => 42, :version => 'acme') | ||||
assert_equal 1, ActionMailer::Base.deliveries.size | ||||
|
r13582 | |||
mail = last_email | ||||
assert mail.bcc.include?('dlopper@somenet.foo') | ||||
end | ||||
end | ||||
|
r3193 | def test_mailer_should_not_change_locale | ||
# Set current language to italian | ||||
set_language_if_valid 'it' | ||||
# Send an email to a french user | ||||
user = User.find(1) | ||||
user.language = 'fr' | ||||
|
r9455 | Mailer.account_activated(user).deliver | ||
|
r8902 | mail = last_email | ||
|
r8966 | assert_mail_body_match 'Votre compte', mail | ||
|
r6806 | |||
|
r3193 | assert_equal :it, current_language | ||
end | ||||
|
r6806 | |||
|
r3494 | def test_with_deliveries_off | ||
Mailer.with_deliveries false do | ||||
|
r9455 | Mailer.test_email(User.find(1)).deliver | ||
|
r3494 | end | ||
assert ActionMailer::Base.deliveries.empty? | ||||
# should restore perform_deliveries | ||||
assert ActionMailer::Base.perform_deliveries | ||||
end | ||||
|
r4248 | |||
|
r12851 | def test_token_for_should_strip_trailing_gt_from_address_with_full_name | ||
with_settings :mail_from => "Redmine Mailer<no-reply@redmine.org>" do | ||||
assert_match /\Aredmine.issue-\d+\.\d+\.[0-9a-f]+@redmine.org\z/, Mailer.token_for(Issue.generate!) | ||||
end | ||||
end | ||||
|
r8349 | def test_layout_should_include_the_emails_header | ||
with_settings :emails_header => "*Header content*" do | ||||
|
r11489 | with_settings :plain_text_mail => 0 do | ||
assert Mailer.test_email(User.find(1)).deliver | ||||
assert_select_email do | ||||
assert_select ".header" do | ||||
assert_select "strong", :text => "Header content" | ||||
end | ||||
|
r4248 | end | ||
end | ||||
|
r11489 | with_settings :plain_text_mail => 1 do | ||
assert Mailer.test_email(User.find(1)).deliver | ||||
mail = last_email | ||||
assert_not_nil mail | ||||
assert_include "*Header content*", mail.body.decoded | ||||
end | ||||
|
r4248 | end | ||
end | ||||
|
r9452 | |||
|
r11491 | def test_layout_should_not_include_empty_emails_header | ||
with_settings :emails_header => "", :plain_text_mail => 0 do | ||||
assert Mailer.test_email(User.find(1)).deliver | ||||
assert_select_email do | ||||
assert_select ".header", false | ||||
end | ||||
end | ||||
end | ||||
|
r11490 | def test_layout_should_include_the_emails_footer | ||
with_settings :emails_footer => "*Footer content*" do | ||||
with_settings :plain_text_mail => 0 do | ||||
assert Mailer.test_email(User.find(1)).deliver | ||||
assert_select_email do | ||||
assert_select ".footer" do | ||||
assert_select "strong", :text => "Footer content" | ||||
end | ||||
end | ||||
end | ||||
with_settings :plain_text_mail => 1 do | ||||
assert Mailer.test_email(User.find(1)).deliver | ||||
mail = last_email | ||||
assert_not_nil mail | ||||
assert_include "\n-- \n", mail.body.decoded | ||||
assert_include "*Footer content*", mail.body.decoded | ||||
end | ||||
end | ||||
end | ||||
|
r11492 | def test_layout_should_not_include_empty_emails_footer | ||
|
r11491 | with_settings :emails_footer => "" do | ||
with_settings :plain_text_mail => 0 do | ||||
assert Mailer.test_email(User.find(1)).deliver | ||||
assert_select_email do | ||||
assert_select ".footer", false | ||||
end | ||||
end | ||||
with_settings :plain_text_mail => 1 do | ||||
assert Mailer.test_email(User.find(1)).deliver | ||||
mail = last_email | ||||
assert_not_nil mail | ||||
assert_not_include "\n-- \n", mail.body.decoded | ||||
end | ||||
end | ||||
end | ||||
|
r10022 | def test_should_escape_html_templates_only | ||
Issue.generate!(:project_id => 1, :tracker_id => 1, :subject => 'Subject with a <tag>') | ||||
mail = last_email | ||||
assert_equal 2, mail.parts.size | ||||
assert_include '<tag>', text_part.body.encoded | ||||
assert_include '<tag>', html_part.body.encoded | ||||
end | ||||
|
r11780 | def test_should_raise_delivery_errors_when_raise_delivery_errors_is_true | ||
mail = Mailer.test_email(User.find(1)) | ||||
mail.delivery_method.stubs(:deliver!).raises(Exception.new("delivery error")) | ||||
ActionMailer::Base.raise_delivery_errors = true | ||||
assert_raise Exception, "delivery error" do | ||||
mail.deliver | ||||
end | ||||
ensure | ||||
ActionMailer::Base.raise_delivery_errors = false | ||||
end | ||||
def test_should_log_delivery_errors_when_raise_delivery_errors_is_false | ||||
mail = Mailer.test_email(User.find(1)) | ||||
mail.delivery_method.stubs(:deliver!).raises(Exception.new("delivery error")) | ||||
Rails.logger.expects(:error).with("Email delivery error: delivery error") | ||||
ActionMailer::Base.raise_delivery_errors = false | ||||
assert_nothing_raised do | ||||
mail.deliver | ||||
end | ||||
end | ||||
|
r13352 | def test_with_synched_deliveries_should_yield_with_synced_deliveries | ||
ActionMailer::Base.delivery_method = :async_smtp | ||||
ActionMailer::Base.async_smtp_settings = {:foo => 'bar'} | ||||
Mailer.with_synched_deliveries do | ||||
assert_equal :smtp, ActionMailer::Base.delivery_method | ||||
assert_equal({:foo => 'bar'}, ActionMailer::Base.smtp_settings) | ||||
end | ||||
assert_equal :async_smtp, ActionMailer::Base.delivery_method | ||||
ensure | ||||
ActionMailer::Base.delivery_method = :test | ||||
end | ||||
|
r13504 | def test_email_addresses_should_keep_addresses | ||
assert_equal ["foo@example.net"], | ||||
Mailer.email_addresses("foo@example.net") | ||||
assert_equal ["foo@example.net", "bar@example.net"], | ||||
Mailer.email_addresses(["foo@example.net", "bar@example.net"]) | ||||
end | ||||
def test_email_addresses_should_replace_users_with_their_email_addresses | ||||
assert_equal ["admin@somenet.foo"], | ||||
Mailer.email_addresses(User.find(1)) | ||||
assert_equal ["admin@somenet.foo", "jsmith@somenet.foo"], | ||||
Mailer.email_addresses(User.where(:id => [1,2])).sort | ||||
end | ||||
def test_email_addresses_should_include_notified_emails_addresses_only | ||||
EmailAddress.create!(:user_id => 2, :address => "another@somenet.foo", :notify => false) | ||||
EmailAddress.create!(:user_id => 2, :address => "another2@somenet.foo") | ||||
assert_equal ["another2@somenet.foo", "jsmith@somenet.foo"], | ||||
Mailer.email_addresses(User.find(2)).sort | ||||
end | ||||
|
r10022 | private | ||
|
r9452 | def last_email | ||
mail = ActionMailer::Base.deliveries.last | ||||
assert_not_nil mail | ||||
end | ||||
|
r10022 | |||
def text_part | ||||
last_email.parts.detect {|part| part.content_type.include?('text/plain')} | ||||
end | ||||
def html_part | ||||
last_email.parts.detect {|part| part.content_type.include?('text/html')} | ||||
end | ||||
|
r13543 | |||
def with_each_language_as_default(&block) | ||||
valid_languages.each do |lang| | ||||
with_settings :default_language => lang.to_s do | ||||
yield lang | ||||
end | ||||
end | ||||
end | ||||
|
r864 | end | ||