2011-03-04 17:32:58 +03:00
|
|
|
# Redmine - project management software
|
2013-01-12 13:29:31 +04:00
|
|
|
# Copyright (C) 2006-2013 Jean-Philippe Lang
|
2007-02-02 17:47:40 +03:00
|
|
|
#
|
|
|
|
# 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.
|
2011-09-01 02:58:46 +04:00
|
|
|
#
|
2007-02-02 17:47:40 +03:00
|
|
|
# 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.
|
2011-09-01 02:58:46 +04:00
|
|
|
#
|
2007-02-02 17:47:40 +03:00
|
|
|
# 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.
|
|
|
|
|
2010-12-13 02:24:34 +03:00
|
|
|
require File.expand_path('../../test_helper', __FILE__)
|
2007-02-02 17:47:40 +03:00
|
|
|
|
2009-09-13 21:14:35 +04:00
|
|
|
class MailerTest < ActiveSupport::TestCase
|
2009-02-21 14:04:50 +03:00
|
|
|
include Redmine::I18n
|
2012-05-01 16:45:39 +04:00
|
|
|
include ActionDispatch::Assertions::SelectorAssertions
|
2011-09-24 15:10:21 +04:00
|
|
|
fixtures :projects, :enabled_modules, :issues, :users, :members,
|
|
|
|
:member_roles, :roles, :documents, :attachments, :news,
|
2012-05-05 16:20:01 +04:00
|
|
|
:tokens, :journals, :journal_details, :changesets,
|
|
|
|
:trackers, :projects_trackers,
|
2011-09-24 15:10:21 +04:00
|
|
|
:issue_statuses, :enumerations, :messages, :boards, :repositories,
|
|
|
|
:wikis, :wiki_pages, :wiki_contents, :wiki_content_versions,
|
|
|
|
:versions,
|
|
|
|
:comments
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2010-02-20 13:07:53 +03:00
|
|
|
def setup
|
|
|
|
ActionMailer::Base.deliveries.clear
|
|
|
|
Setting.host_name = 'mydomain.foo'
|
|
|
|
Setting.protocol = 'http'
|
2011-03-27 20:38:08 +04:00
|
|
|
Setting.plain_text_mail = '0'
|
2010-02-20 13:07:53 +03:00
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2008-02-17 17:17:20 +03:00
|
|
|
def test_generated_links_in_emails
|
2012-02-27 22:42:03 +04:00
|
|
|
Setting.default_language = 'en'
|
2008-02-17 17:17:20 +03:00
|
|
|
Setting.host_name = 'mydomain.foo'
|
|
|
|
Setting.protocol = 'https'
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2012-02-27 22:42:03 +04:00
|
|
|
journal = Journal.find(3)
|
2013-07-13 13:20:11 +04:00
|
|
|
assert Mailer.deliver_issue_edit(journal)
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2012-02-27 22:42:03 +04:00
|
|
|
mail = last_email
|
2012-02-25 13:58:23 +04:00
|
|
|
assert_not_nil mail
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2009-11-14 22:40:56 +03:00
|
|
|
assert_select_email do
|
|
|
|
# link to the main ticket
|
2012-02-27 22:42:03 +04:00
|
|
|
assert_select 'a[href=?]',
|
|
|
|
'https://mydomain.foo/issues/2#change-3',
|
|
|
|
:text => 'Feature request #2: Add ingredients categories'
|
2009-11-14 22:40:56 +03:00
|
|
|
# link to a referenced ticket
|
2012-02-27 22:42:03 +04:00
|
|
|
assert_select 'a[href=?][title=?]',
|
|
|
|
'https://mydomain.foo/issues/1',
|
2012-09-02 14:08:51 +04:00
|
|
|
'Can't print recipes (New)',
|
2012-02-27 22:42:03 +04:00
|
|
|
:text => '#1'
|
2009-11-14 22:40:56 +03:00
|
|
|
# link to a changeset
|
2012-02-27 22:42:03 +04:00
|
|
|
assert_select 'a[href=?][title=?]',
|
|
|
|
'https://mydomain.foo/projects/ecookbook/repository/revisions/2',
|
|
|
|
'This commit fixes #1, #2 and references #1 & #3',
|
|
|
|
:text => 'r2'
|
|
|
|
# link to a description diff
|
|
|
|
assert_select 'a[href=?][title=?]',
|
|
|
|
'https://mydomain.foo/journals/diff/3?detail_id=4',
|
|
|
|
'View differences',
|
|
|
|
:text => 'diff'
|
|
|
|
# link to an attachment
|
|
|
|
assert_select 'a[href=?]',
|
|
|
|
'https://mydomain.foo/attachments/download/4/source.rb',
|
|
|
|
:text => 'source.rb'
|
2009-11-14 22:40:56 +03:00
|
|
|
end
|
2008-02-17 17:17:20 +03:00
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2008-11-08 16:25:45 +03:00
|
|
|
def test_generated_links_with_prefix
|
2012-02-27 22:42:03 +04:00
|
|
|
Setting.default_language = 'en'
|
2009-01-04 20:09:25 +03:00
|
|
|
relative_url_root = Redmine::Utils.relative_url_root
|
2008-11-08 16:25:45 +03:00
|
|
|
Setting.host_name = 'mydomain.foo/rdm'
|
|
|
|
Setting.protocol = 'http'
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2012-02-27 22:42:03 +04:00
|
|
|
journal = Journal.find(3)
|
2013-07-13 13:20:11 +04:00
|
|
|
assert Mailer.deliver_issue_edit(journal)
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2012-02-27 22:42:03 +04:00
|
|
|
mail = last_email
|
2012-02-25 13:58:23 +04:00
|
|
|
assert_not_nil mail
|
2009-11-14 22:40:56 +03:00
|
|
|
|
|
|
|
assert_select_email do
|
|
|
|
# link to the main ticket
|
2012-02-27 22:42:03 +04:00
|
|
|
assert_select 'a[href=?]',
|
|
|
|
'http://mydomain.foo/rdm/issues/2#change-3',
|
|
|
|
:text => 'Feature request #2: Add ingredients categories'
|
2009-11-14 22:40:56 +03:00
|
|
|
# link to a referenced ticket
|
2012-02-27 22:42:03 +04:00
|
|
|
assert_select 'a[href=?][title=?]',
|
|
|
|
'http://mydomain.foo/rdm/issues/1',
|
2012-09-02 14:08:51 +04:00
|
|
|
'Can't print recipes (New)',
|
2012-02-27 22:42:03 +04:00
|
|
|
:text => '#1'
|
2009-11-14 22:40:56 +03:00
|
|
|
# link to a changeset
|
2012-02-27 22:42:03 +04:00
|
|
|
assert_select 'a[href=?][title=?]',
|
|
|
|
'http://mydomain.foo/rdm/projects/ecookbook/repository/revisions/2',
|
|
|
|
'This commit fixes #1, #2 and references #1 & #3',
|
|
|
|
:text => 'r2'
|
|
|
|
# link to a description diff
|
|
|
|
assert_select 'a[href=?][title=?]',
|
|
|
|
'http://mydomain.foo/rdm/journals/diff/3?detail_id=4',
|
|
|
|
'View differences',
|
|
|
|
:text => 'diff'
|
|
|
|
# link to an attachment
|
|
|
|
assert_select 'a[href=?]',
|
|
|
|
'http://mydomain.foo/rdm/attachments/download/4/source.rb',
|
|
|
|
:text => 'source.rb'
|
2009-11-14 22:40:56 +03:00
|
|
|
end
|
2008-11-08 16:25:45 +03:00
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2008-11-08 16:25:45 +03:00
|
|
|
def test_generated_links_with_prefix_and_no_relative_url_root
|
2012-02-27 22:42:03 +04:00
|
|
|
Setting.default_language = 'en'
|
2009-01-04 20:09:25 +03:00
|
|
|
relative_url_root = Redmine::Utils.relative_url_root
|
2008-11-08 16:25:45 +03:00
|
|
|
Setting.host_name = 'mydomain.foo/rdm'
|
|
|
|
Setting.protocol = 'http'
|
2009-01-04 20:09:25 +03:00
|
|
|
Redmine::Utils.relative_url_root = nil
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2012-02-27 22:42:03 +04:00
|
|
|
journal = Journal.find(3)
|
2013-07-13 13:20:11 +04:00
|
|
|
assert Mailer.deliver_issue_edit(journal)
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2012-02-27 22:42:03 +04:00
|
|
|
mail = last_email
|
2012-02-25 13:58:23 +04:00
|
|
|
assert_not_nil mail
|
2009-11-14 22:40:56 +03:00
|
|
|
|
|
|
|
assert_select_email do
|
|
|
|
# link to the main ticket
|
2012-02-27 22:42:03 +04:00
|
|
|
assert_select 'a[href=?]',
|
|
|
|
'http://mydomain.foo/rdm/issues/2#change-3',
|
|
|
|
:text => 'Feature request #2: Add ingredients categories'
|
2009-11-14 22:40:56 +03:00
|
|
|
# link to a referenced ticket
|
2012-02-27 22:42:03 +04:00
|
|
|
assert_select 'a[href=?][title=?]',
|
|
|
|
'http://mydomain.foo/rdm/issues/1',
|
2012-09-02 14:08:51 +04:00
|
|
|
'Can't print recipes (New)',
|
2012-02-27 22:42:03 +04:00
|
|
|
:text => '#1'
|
2009-11-14 22:40:56 +03:00
|
|
|
# link to a changeset
|
2012-02-27 22:42:03 +04:00
|
|
|
assert_select 'a[href=?][title=?]',
|
|
|
|
'http://mydomain.foo/rdm/projects/ecookbook/repository/revisions/2',
|
|
|
|
'This commit fixes #1, #2 and references #1 & #3',
|
|
|
|
:text => 'r2'
|
|
|
|
# link to a description diff
|
|
|
|
assert_select 'a[href=?][title=?]',
|
|
|
|
'http://mydomain.foo/rdm/journals/diff/3?detail_id=4',
|
|
|
|
'View differences',
|
|
|
|
:text => 'diff'
|
|
|
|
# link to an attachment
|
|
|
|
assert_select 'a[href=?]',
|
|
|
|
'http://mydomain.foo/rdm/attachments/download/4/source.rb',
|
|
|
|
:text => 'source.rb'
|
2009-11-14 22:40:56 +03:00
|
|
|
end
|
2008-11-08 16:25:45 +03:00
|
|
|
ensure
|
|
|
|
# restore it
|
2009-01-04 20:09:25 +03:00
|
|
|
Redmine::Utils.relative_url_root = relative_url_root
|
2008-11-08 16:25:45 +03:00
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2009-04-05 16:33:45 +04:00
|
|
|
def test_email_headers
|
|
|
|
issue = Issue.find(1)
|
2013-07-13 13:20:11 +04:00
|
|
|
Mailer.deliver_issue_add(issue)
|
2012-02-27 22:42:03 +04:00
|
|
|
mail = last_email
|
2009-04-05 16:33:45 +04:00
|
|
|
assert_not_nil mail
|
2012-04-25 21:17:49 +04:00
|
|
|
assert_equal 'OOF', mail.header['X-Auto-Response-Suppress'].to_s
|
|
|
|
assert_equal 'auto-generated', mail.header['Auto-Submitted'].to_s
|
2012-05-13 14:44:41 +04:00
|
|
|
assert_equal '<redmine.example.net>', mail.header['List-Id'].to_s
|
2009-04-05 16:33:45 +04:00
|
|
|
end
|
2008-10-16 03:50:33 +04:00
|
|
|
|
2012-02-05 16:57:19 +04:00
|
|
|
def test_email_headers_should_include_sender
|
|
|
|
issue = Issue.find(1)
|
2013-07-13 13:20:11 +04:00
|
|
|
Mailer.deliver_issue_add(issue)
|
2012-02-27 22:42:03 +04:00
|
|
|
mail = last_email
|
2012-04-25 21:17:49 +04:00
|
|
|
assert_equal issue.author.login, mail.header['X-Redmine-Sender'].to_s
|
2012-02-05 16:57:19 +04:00
|
|
|
end
|
|
|
|
|
2008-10-16 03:50:33 +04:00
|
|
|
def test_plain_text_mail
|
|
|
|
Setting.plain_text_mail = 1
|
|
|
|
journal = Journal.find(2)
|
2013-07-13 13:20:11 +04:00
|
|
|
Mailer.deliver_issue_edit(journal)
|
2012-02-27 22:42:03 +04:00
|
|
|
mail = last_email
|
2012-04-25 21:17:49 +04:00
|
|
|
assert_equal "text/plain; charset=UTF-8", mail.content_type
|
2009-10-24 15:57:01 +04:00
|
|
|
assert_equal 0, mail.parts.size
|
2009-09-13 21:14:35 +04:00
|
|
|
assert !mail.encoded.include?('href')
|
2008-10-16 03:50:33 +04:00
|
|
|
end
|
2009-09-13 21:14:35 +04:00
|
|
|
|
|
|
|
def test_html_mail
|
|
|
|
Setting.plain_text_mail = 0
|
|
|
|
journal = Journal.find(2)
|
2013-07-13 13:20:11 +04:00
|
|
|
Mailer.deliver_issue_edit(journal)
|
2012-02-27 22:42:03 +04:00
|
|
|
mail = last_email
|
2009-09-13 21:14:35 +04:00
|
|
|
assert_equal 2, mail.parts.size
|
|
|
|
assert mail.encoded.include?('href')
|
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2011-11-15 00:10:06 +04:00
|
|
|
def test_from_header
|
|
|
|
with_settings :mail_from => 'redmine@example.net' do
|
2012-05-05 17:07:12 +04:00
|
|
|
Mailer.test_email(User.find(1)).deliver
|
2011-11-15 00:10:06 +04:00
|
|
|
end
|
2012-02-27 22:42:03 +04:00
|
|
|
mail = last_email
|
2012-04-25 21:17:49 +04:00
|
|
|
assert_equal 'redmine@example.net', mail.from_addrs.first
|
2011-11-15 00:10:06 +04:00
|
|
|
end
|
|
|
|
|
|
|
|
def test_from_header_with_phrase
|
2010-02-17 22:08:04 +03:00
|
|
|
with_settings :mail_from => 'Redmine app <redmine@example.net>' do
|
2012-05-05 17:07:12 +04:00
|
|
|
Mailer.test_email(User.find(1)).deliver
|
2010-02-17 22:08:04 +03:00
|
|
|
end
|
2012-02-27 22:42:03 +04:00
|
|
|
mail = last_email
|
2012-04-25 21:17:49 +04:00
|
|
|
assert_equal 'redmine@example.net', mail.from_addrs.first
|
|
|
|
assert_equal 'Redmine app <redmine@example.net>', mail.header['From'].to_s
|
2010-02-17 22:08:04 +03:00
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2010-02-28 20:18:21 +03:00
|
|
|
def test_should_not_send_email_without_recipient
|
2012-12-03 22:21:32 +04:00
|
|
|
news = News.first
|
2010-02-28 20:18:21 +03:00
|
|
|
user = news.author
|
|
|
|
# Remove members except news author
|
|
|
|
news.project.memberships.each {|m| m.destroy unless m.user == user}
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2013-05-13 20:38:08 +04:00
|
|
|
user.pref.no_self_notified = false
|
2010-02-28 20:18:21 +03:00
|
|
|
user.pref.save
|
|
|
|
User.current = user
|
2012-05-05 17:07:12 +04:00
|
|
|
Mailer.news_added(news.reload).deliver
|
2010-02-28 20:18:21 +03:00
|
|
|
assert_equal 1, last_email.bcc.size
|
|
|
|
|
|
|
|
# nobody to notify
|
2013-05-13 20:38:08 +04:00
|
|
|
user.pref.no_self_notified = true
|
2010-02-28 20:18:21 +03:00
|
|
|
user.pref.save
|
|
|
|
User.current = user
|
|
|
|
ActionMailer::Base.deliveries.clear
|
2012-05-05 17:07:12 +04:00
|
|
|
Mailer.news_added(news.reload).deliver
|
2010-02-28 20:18:21 +03:00
|
|
|
assert ActionMailer::Base.deliveries.empty?
|
|
|
|
end
|
2009-09-13 21:14:35 +04:00
|
|
|
|
2009-01-18 18:16:31 +03:00
|
|
|
def test_issue_add_message_id
|
2013-07-13 13:20:11 +04:00
|
|
|
issue = Issue.find(2)
|
|
|
|
Mailer.deliver_issue_add(issue)
|
2012-02-27 22:42:03 +04:00
|
|
|
mail = last_email
|
2013-07-13 13:20:11 +04:00
|
|
|
assert_match /^redmine\.issue-2\.20060719190421\.[a-f0-9]+@example\.net/, mail.message_id
|
|
|
|
assert_include "redmine.issue-2.20060719190421@example.net", mail.references
|
2009-01-18 18:16:31 +03:00
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2009-01-18 18:16:31 +03:00
|
|
|
def test_issue_edit_message_id
|
2013-07-13 13:20:11 +04:00
|
|
|
journal = Journal.find(3)
|
|
|
|
journal.issue = Issue.find(2)
|
|
|
|
|
|
|
|
Mailer.deliver_issue_edit(journal)
|
2012-02-27 22:42:03 +04:00
|
|
|
mail = last_email
|
2013-07-13 13:20:11 +04:00
|
|
|
assert_match /^redmine\.journal-3\.\d+\.[a-f0-9]+@example\.net/, mail.message_id
|
|
|
|
assert_include "redmine.issue-2.20060719190421@example.net", mail.references
|
2011-12-03 01:00:42 +04:00
|
|
|
assert_select_email do
|
|
|
|
# link to the update
|
|
|
|
assert_select "a[href=?]",
|
|
|
|
"http://mydomain.foo/issues/#{journal.journalized_id}#change-#{journal.id}"
|
|
|
|
end
|
2009-01-18 18:16:31 +03:00
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2009-01-18 18:16:31 +03:00
|
|
|
def test_message_posted_message_id
|
|
|
|
message = Message.find(1)
|
2012-05-05 17:07:12 +04:00
|
|
|
Mailer.message_posted(message).deliver
|
2012-02-27 22:42:03 +04:00
|
|
|
mail = last_email
|
2013-07-13 13:20:11 +04:00
|
|
|
assert_match /^redmine\.message-1\.\d+\.[a-f0-9]+@example\.net/, mail.message_id
|
|
|
|
assert_include "redmine.message-1.20070512151532@example.net", mail.references
|
2010-02-20 13:07:53 +03:00
|
|
|
assert_select_email do
|
|
|
|
# link to the message
|
2011-09-24 17:13:21 +04:00
|
|
|
assert_select "a[href=?]",
|
|
|
|
"http://mydomain.foo/boards/#{message.board.id}/topics/#{message.id}",
|
|
|
|
:text => message.subject
|
2010-02-20 13:07:53 +03:00
|
|
|
end
|
2009-01-18 18:16:31 +03:00
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2009-01-18 18:16:31 +03:00
|
|
|
def test_reply_posted_message_id
|
|
|
|
message = Message.find(3)
|
2012-05-05 17:07:12 +04:00
|
|
|
Mailer.message_posted(message).deliver
|
2012-02-27 22:42:03 +04:00
|
|
|
mail = last_email
|
2013-07-13 13:20:11 +04:00
|
|
|
assert_match /^redmine\.message-3\.\d+\.[a-f0-9]+@example\.net/, mail.message_id
|
|
|
|
assert_include "redmine.message-1.20070512151532@example.net", mail.references
|
2010-02-20 13:07:53 +03:00
|
|
|
assert_select_email do
|
|
|
|
# link to the reply
|
2011-09-24 17:14:04 +04:00
|
|
|
assert_select "a[href=?]",
|
|
|
|
"http://mydomain.foo/boards/#{message.board.id}/topics/#{message.root.id}?r=#{message.id}#message-#{message.id}",
|
|
|
|
:text => message.subject
|
2010-02-20 13:07:53 +03:00
|
|
|
end
|
2009-01-18 18:16:31 +03:00
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2013-02-03 13:20:05 +04:00
|
|
|
test "#issue_add should notify project members" do
|
|
|
|
issue = Issue.find(1)
|
2013-07-13 13:20:11 +04:00
|
|
|
assert Mailer.deliver_issue_add(issue)
|
2013-02-03 13:20:05 +04:00
|
|
|
assert last_email.bcc.include?('dlopper@somenet.foo')
|
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2013-02-03 13:20:05 +04:00
|
|
|
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)
|
2013-07-13 13:20:11 +04:00
|
|
|
assert Mailer.deliver_issue_add(issue)
|
2013-02-03 13:20:05 +04:00
|
|
|
assert !last_email.bcc.include?('dlopper@somenet.foo')
|
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2013-02-03 13:20:05 +04:00
|
|
|
test "#issue_add should notify issue watchers" do
|
|
|
|
issue = Issue.find(1)
|
|
|
|
user = User.find(9)
|
|
|
|
# minimal email notification options
|
2013-05-13 20:38:08 +04:00
|
|
|
user.pref.no_self_notified = '1'
|
2013-02-03 13:20:05 +04:00
|
|
|
user.pref.save
|
|
|
|
user.mail_notification = false
|
|
|
|
user.save
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2013-02-03 13:20:05 +04:00
|
|
|
Watcher.create!(:watchable => issue, :user => user)
|
2013-07-13 13:20:11 +04:00
|
|
|
assert Mailer.deliver_issue_add(issue)
|
2013-02-03 13:20:05 +04:00
|
|
|
assert last_email.bcc.include?(user.mail)
|
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2013-02-03 13:20:05 +04:00
|
|
|
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)
|
2013-07-13 13:20:11 +04:00
|
|
|
assert Mailer.deliver_issue_add(issue)
|
2013-02-03 13:20:05 +04:00
|
|
|
assert !last_email.bcc.include?(user.mail)
|
2009-12-13 17:26:54 +03:00
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2007-02-02 17:47:40 +03:00
|
|
|
# test mailer methods for each language
|
|
|
|
def test_issue_add
|
|
|
|
issue = Issue.find(1)
|
2009-02-21 14:04:50 +03:00
|
|
|
valid_languages.each do |lang|
|
2007-03-10 18:09:49 +03:00
|
|
|
Setting.default_language = lang.to_s
|
2013-07-13 13:20:11 +04:00
|
|
|
assert Mailer.deliver_issue_add(issue)
|
2007-02-02 17:47:40 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_issue_edit
|
|
|
|
journal = Journal.find(1)
|
2009-02-21 14:04:50 +03:00
|
|
|
valid_languages.each do |lang|
|
2007-03-10 18:09:49 +03:00
|
|
|
Setting.default_language = lang.to_s
|
2013-07-13 13:20:11 +04:00
|
|
|
assert Mailer.deliver_issue_edit(journal)
|
2007-02-02 17:47:40 +03:00
|
|
|
end
|
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2012-10-04 01:36:19 +04:00
|
|
|
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
|
2013-07-13 13:20:11 +04:00
|
|
|
Mailer.deliver_issue_edit(journal)
|
2012-10-04 01:36:19 +04:00
|
|
|
assert_equal %w(dlopper@somenet.foo jsmith@somenet.foo), ActionMailer::Base.deliveries.last.bcc.sort
|
|
|
|
|
|
|
|
Role.find(2).remove_permission! :view_private_notes
|
2013-07-13 13:20:11 +04:00
|
|
|
Mailer.deliver_issue_edit(journal)
|
2012-10-04 01:36:19 +04:00
|
|
|
assert_equal %w(jsmith@somenet.foo), ActionMailer::Base.deliveries.last.bcc.sort
|
|
|
|
end
|
|
|
|
|
2012-11-05 19:49:07 +04:00
|
|
|
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
|
2013-07-13 13:20:11 +04:00
|
|
|
Mailer.deliver_issue_edit(journal)
|
2012-11-05 19:49:07 +04:00
|
|
|
assert_include 'someone@foo.bar', ActionMailer::Base.deliveries.last.bcc.sort
|
|
|
|
|
|
|
|
Role.non_member.remove_permission! :view_private_notes
|
2013-07-13 13:20:11 +04:00
|
|
|
Mailer.deliver_issue_edit(journal)
|
2012-11-05 19:49:07 +04:00
|
|
|
assert_not_include 'someone@foo.bar', ActionMailer::Base.deliveries.last.bcc.sort
|
|
|
|
end
|
|
|
|
|
2013-05-18 21:24:23 +04:00
|
|
|
def test_issue_edit_should_mark_private_notes
|
|
|
|
journal = Journal.find(2)
|
|
|
|
journal.private_notes = true
|
|
|
|
journal.save!
|
|
|
|
|
|
|
|
with_settings :default_language => 'en' do
|
2013-07-13 13:20:11 +04:00
|
|
|
Mailer.deliver_issue_edit(journal)
|
2013-05-18 21:24:23 +04:00
|
|
|
end
|
|
|
|
assert_mail_body_match '(Private notes)', last_email
|
|
|
|
end
|
|
|
|
|
2013-07-13 14:32:48 +04:00
|
|
|
def test_issue_edit_with_relation_should_notify_users_who_can_see_the_related_issue
|
|
|
|
issue = Issue.generate!
|
|
|
|
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
|
|
|
|
|
2007-11-04 13:43:39 +03:00
|
|
|
def test_document_added
|
2007-02-02 17:47:40 +03:00
|
|
|
document = Document.find(1)
|
2009-02-21 14:04:50 +03:00
|
|
|
valid_languages.each do |lang|
|
2007-03-10 18:09:49 +03:00
|
|
|
Setting.default_language = lang.to_s
|
2012-05-05 17:07:12 +04:00
|
|
|
assert Mailer.document_added(document).deliver
|
2007-02-02 17:47:40 +03:00
|
|
|
end
|
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2007-11-04 13:43:39 +03:00
|
|
|
def test_attachments_added
|
|
|
|
attachements = [ Attachment.find_by_container_type('Document') ]
|
2009-02-21 14:04:50 +03:00
|
|
|
valid_languages.each do |lang|
|
2007-11-04 13:43:39 +03:00
|
|
|
Setting.default_language = lang.to_s
|
2012-05-05 17:07:12 +04:00
|
|
|
assert Mailer.attachments_added(attachements).deliver
|
2007-11-04 13:43:39 +03:00
|
|
|
end
|
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2010-03-04 00:32:41 +03:00
|
|
|
def test_version_file_added
|
|
|
|
attachements = [ Attachment.find_by_container_type('Version') ]
|
2012-05-05 17:07:12 +04:00
|
|
|
assert Mailer.attachments_added(attachements).deliver
|
2010-03-04 00:32:41 +03:00
|
|
|
assert_not_nil last_email.bcc
|
|
|
|
assert last_email.bcc.any?
|
2011-03-27 20:38:08 +04:00
|
|
|
assert_select_email do
|
|
|
|
assert_select "a[href=?]", "http://mydomain.foo/projects/ecookbook/files"
|
|
|
|
end
|
2010-03-04 00:32:41 +03:00
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2010-03-04 00:32:41 +03:00
|
|
|
def test_project_file_added
|
|
|
|
attachements = [ Attachment.find_by_container_type('Project') ]
|
2012-05-05 17:07:12 +04:00
|
|
|
assert Mailer.attachments_added(attachements).deliver
|
2010-03-04 00:32:41 +03:00
|
|
|
assert_not_nil last_email.bcc
|
|
|
|
assert last_email.bcc.any?
|
2011-03-27 20:38:08 +04:00
|
|
|
assert_select_email do
|
|
|
|
assert_select "a[href=?]", "http://mydomain.foo/projects/ecookbook/files"
|
|
|
|
end
|
2010-03-04 00:32:41 +03:00
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2007-11-04 13:43:39 +03:00
|
|
|
def test_news_added
|
2012-12-03 22:21:32 +04:00
|
|
|
news = News.first
|
2009-02-21 14:04:50 +03:00
|
|
|
valid_languages.each do |lang|
|
2007-11-04 13:43:39 +03:00
|
|
|
Setting.default_language = lang.to_s
|
2012-05-05 17:07:12 +04:00
|
|
|
assert Mailer.news_added(news).deliver
|
2007-11-04 13:43:39 +03:00
|
|
|
end
|
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2011-03-04 17:32:58 +03:00
|
|
|
def test_news_comment_added
|
|
|
|
comment = Comment.find(2)
|
|
|
|
valid_languages.each do |lang|
|
|
|
|
Setting.default_language = lang.to_s
|
2012-05-05 17:07:12 +04:00
|
|
|
assert Mailer.news_comment_added(comment).deliver
|
2011-03-04 17:32:58 +03:00
|
|
|
end
|
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2007-11-04 13:43:39 +03:00
|
|
|
def test_message_posted
|
2012-12-03 22:21:32 +04:00
|
|
|
message = Message.first
|
2007-11-04 13:43:39 +03:00
|
|
|
recipients = ([message.root] + message.root.children).collect {|m| m.author.mail if m.author}
|
|
|
|
recipients = recipients.compact.uniq
|
2009-02-21 14:04:50 +03:00
|
|
|
valid_languages.each do |lang|
|
2007-11-04 13:43:39 +03:00
|
|
|
Setting.default_language = lang.to_s
|
2012-05-05 17:07:12 +04:00
|
|
|
assert Mailer.message_posted(message).deliver
|
2007-11-04 13:43:39 +03:00
|
|
|
end
|
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2010-12-08 01:07:55 +03:00
|
|
|
def test_wiki_content_added
|
2012-02-28 09:35:33 +04:00
|
|
|
content = WikiContent.find(1)
|
2010-12-08 01:07:55 +03:00
|
|
|
valid_languages.each do |lang|
|
|
|
|
Setting.default_language = lang.to_s
|
|
|
|
assert_difference 'ActionMailer::Base.deliveries.size' do
|
2012-05-05 17:07:12 +04:00
|
|
|
assert Mailer.wiki_content_added(content).deliver
|
2012-06-26 21:03:08 +04:00
|
|
|
assert_select_email do
|
|
|
|
assert_select 'a[href=?]',
|
|
|
|
'http://mydomain.foo/projects/ecookbook/wiki/CookBook_documentation',
|
|
|
|
:text => 'CookBook documentation'
|
|
|
|
end
|
2010-12-08 01:07:55 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2010-12-08 01:07:55 +03:00
|
|
|
def test_wiki_content_updated
|
2012-02-28 09:35:33 +04:00
|
|
|
content = WikiContent.find(1)
|
2010-12-08 01:07:55 +03:00
|
|
|
valid_languages.each do |lang|
|
|
|
|
Setting.default_language = lang.to_s
|
|
|
|
assert_difference 'ActionMailer::Base.deliveries.size' do
|
2012-05-05 17:07:12 +04:00
|
|
|
assert Mailer.wiki_content_updated(content).deliver
|
2012-06-26 21:03:08 +04:00
|
|
|
assert_select_email do
|
|
|
|
assert_select 'a[href=?]',
|
|
|
|
'http://mydomain.foo/projects/ecookbook/wiki/CookBook_documentation',
|
|
|
|
:text => 'CookBook documentation'
|
|
|
|
end
|
2010-12-08 01:07:55 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2007-11-04 13:43:39 +03:00
|
|
|
def test_account_information
|
2010-04-30 15:27:08 +04:00
|
|
|
user = User.find(2)
|
2009-02-21 14:04:50 +03:00
|
|
|
valid_languages.each do |lang|
|
2007-11-04 13:43:39 +03:00
|
|
|
user.update_attribute :language, lang.to_s
|
|
|
|
user.reload
|
2012-05-05 17:07:12 +04:00
|
|
|
assert Mailer.account_information(user, 'pAsswORd').deliver
|
2007-11-04 13:43:39 +03:00
|
|
|
end
|
|
|
|
end
|
2007-02-02 17:47:40 +03:00
|
|
|
|
|
|
|
def test_lost_password
|
|
|
|
token = Token.find(2)
|
2009-02-21 14:04:50 +03:00
|
|
|
valid_languages.each do |lang|
|
2007-03-10 18:09:49 +03:00
|
|
|
token.user.update_attribute :language, lang.to_s
|
2007-11-04 13:43:39 +03:00
|
|
|
token.reload
|
2012-05-05 17:07:12 +04:00
|
|
|
assert Mailer.lost_password(token).deliver
|
2007-02-02 17:47:40 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def test_register
|
|
|
|
token = Token.find(1)
|
2009-03-07 15:45:46 +03:00
|
|
|
Setting.host_name = 'redmine.foo'
|
|
|
|
Setting.protocol = 'https'
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2009-02-21 14:04:50 +03:00
|
|
|
valid_languages.each do |lang|
|
2007-03-10 18:09:49 +03:00
|
|
|
token.user.update_attribute :language, lang.to_s
|
2007-11-04 13:43:39 +03:00
|
|
|
token.reload
|
2009-03-07 15:45:46 +03:00
|
|
|
ActionMailer::Base.deliveries.clear
|
2012-05-05 17:07:12 +04:00
|
|
|
assert Mailer.register(token).deliver
|
2012-02-27 22:42:03 +04:00
|
|
|
mail = last_email
|
2012-02-20 18:36:43 +04:00
|
|
|
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
|
2007-02-02 17:47:40 +03:00
|
|
|
end
|
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2010-03-21 14:17:29 +03:00
|
|
|
def test_test
|
|
|
|
user = User.find(1)
|
|
|
|
valid_languages.each do |lang|
|
|
|
|
user.update_attribute :language, lang.to_s
|
2012-05-05 17:07:12 +04:00
|
|
|
assert Mailer.test_email(user).deliver
|
2010-03-21 14:17:29 +03:00
|
|
|
end
|
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2008-05-25 21:31:50 +04:00
|
|
|
def test_reminders
|
|
|
|
Mailer.reminders(:days => 42)
|
|
|
|
assert_equal 1, ActionMailer::Base.deliveries.size
|
2012-02-27 22:42:03 +04:00
|
|
|
mail = last_email
|
2008-05-25 21:31:50 +04:00
|
|
|
assert mail.bcc.include?('dlopper@somenet.foo')
|
2012-03-04 17:28:18 +04:00
|
|
|
assert_mail_body_match 'Bug #3: Error 281 when updating a recipe', mail
|
2010-08-03 20:01:53 +04:00
|
|
|
assert_equal '1 issue(s) due in the next 42 days', mail.subject
|
2008-05-25 21:31:50 +04:00
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2012-01-21 16:28:39 +04:00
|
|
|
def test_reminders_should_not_include_closed_issues
|
2012-02-22 07:28:42 +04:00
|
|
|
with_settings :default_language => 'en' do
|
2012-03-04 16:15:57 +04:00
|
|
|
Issue.create!(:project_id => 1, :tracker_id => 1, :status_id => 5,
|
2012-02-22 07:28:42 +04:00
|
|
|
:subject => 'Closed issue', :assigned_to_id => 3,
|
2012-03-04 16:15:57 +04:00
|
|
|
:due_date => 5.days.from_now,
|
|
|
|
:author_id => 2)
|
2012-02-22 07:28:42 +04:00
|
|
|
ActionMailer::Base.deliveries.clear
|
2012-01-21 16:28:39 +04:00
|
|
|
|
2012-02-22 07:28:42 +04:00
|
|
|
Mailer.reminders(:days => 42)
|
|
|
|
assert_equal 1, ActionMailer::Base.deliveries.size
|
2012-02-27 22:42:03 +04:00
|
|
|
mail = last_email
|
2012-02-22 07:28:42 +04:00
|
|
|
assert mail.bcc.include?('dlopper@somenet.foo')
|
2012-03-04 17:28:18 +04:00
|
|
|
assert_mail_body_no_match 'Closed issue', mail
|
2012-02-22 07:28:42 +04:00
|
|
|
end
|
2012-01-21 16:28:39 +04:00
|
|
|
end
|
|
|
|
|
2010-09-21 03:17:51 +04:00
|
|
|
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
|
2012-02-27 22:42:03 +04:00
|
|
|
mail = last_email
|
2010-09-21 03:17:51 +04:00
|
|
|
assert mail.bcc.include?('dlopper@somenet.foo')
|
2012-03-04 17:28:18 +04:00
|
|
|
assert_mail_body_match 'Bug #3: Error 281 when updating a recipe', mail
|
2010-09-21 03:17:51 +04:00
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2012-09-09 15:02:13 +04:00
|
|
|
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
|
|
|
|
|
2010-01-10 17:54:02 +03:00
|
|
|
def test_mailer_should_not_change_locale
|
|
|
|
Setting.default_language = 'en'
|
|
|
|
# Set current language to italian
|
|
|
|
set_language_if_valid 'it'
|
|
|
|
# Send an email to a french user
|
|
|
|
user = User.find(1)
|
|
|
|
user.language = 'fr'
|
2012-05-05 17:07:12 +04:00
|
|
|
Mailer.account_activated(user).deliver
|
2012-02-27 22:42:03 +04:00
|
|
|
mail = last_email
|
2012-03-04 17:28:18 +04:00
|
|
|
assert_mail_body_match 'Votre compte', mail
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2010-01-10 17:54:02 +03:00
|
|
|
assert_equal :it, current_language
|
|
|
|
end
|
2011-09-01 02:58:46 +04:00
|
|
|
|
2010-03-21 14:17:29 +03:00
|
|
|
def test_with_deliveries_off
|
|
|
|
Mailer.with_deliveries false do
|
2012-05-05 17:07:12 +04:00
|
|
|
Mailer.test_email(User.find(1)).deliver
|
2010-03-21 14:17:29 +03:00
|
|
|
end
|
|
|
|
assert ActionMailer::Base.deliveries.empty?
|
|
|
|
# should restore perform_deliveries
|
|
|
|
assert ActionMailer::Base.perform_deliveries
|
|
|
|
end
|
2010-11-02 22:00:36 +03:00
|
|
|
|
2012-01-02 15:38:29 +04:00
|
|
|
def test_layout_should_include_the_emails_header
|
|
|
|
with_settings :emails_header => "*Header content*" do
|
2013-04-18 04:29:18 +04:00
|
|
|
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
|
2010-11-02 22:00:36 +03:00
|
|
|
end
|
|
|
|
end
|
2013-04-18 04:29:18 +04:00
|
|
|
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
|
2010-11-02 22:00:36 +03:00
|
|
|
end
|
|
|
|
end
|
2012-05-05 16:20:18 +04:00
|
|
|
|
2013-04-18 04:58:24 +04:00
|
|
|
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
|
|
|
|
|
2013-04-18 04:29:29 +04:00
|
|
|
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
|
|
|
|
|
2013-04-18 05:09:06 +04:00
|
|
|
def test_layout_should_not_include_empty_emails_footer
|
2013-04-18 04:58:24 +04:00
|
|
|
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
|
|
|
|
|
2012-08-13 23:05:42 +04:00
|
|
|
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
|
|
|
|
|
2013-07-13 12:11:20 +04:00
|
|
|
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
|
|
|
|
|
2012-08-13 23:05:42 +04:00
|
|
|
private
|
|
|
|
|
2012-05-05 16:20:18 +04:00
|
|
|
def last_email
|
|
|
|
mail = ActionMailer::Base.deliveries.last
|
|
|
|
assert_not_nil mail
|
|
|
|
mail
|
|
|
|
end
|
2012-08-13 23:05:42 +04:00
|
|
|
|
|
|
|
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
|
2007-11-04 13:43:39 +03:00
|
|
|
end
|