summaryrefslogtreecommitdiffstats
path: root/test/unit/mailer_test.rb
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2009-12-13 14:26:54 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2009-12-13 14:26:54 +0000
commitbb477a3a0fe71f0e15b78b6e0fafb017065fba26 (patch)
tree5fe5daa3d87fa80c93b0e77bc95552079a1389c5 /test/unit/mailer_test.rb
parent6610bb6b6cbb1ef72787542063359de04fbab6be (diff)
downloadredmine-bb477a3a0fe71f0e15b78b6e0fafb017065fba26.tar.gz
redmine-bb477a3a0fe71f0e15b78b6e0fafb017065fba26.zip
Make sure users don't get notified for thing they can not view (#3589).
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@3169 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'test/unit/mailer_test.rb')
-rw-r--r--test/unit/mailer_test.rb46
1 files changed, 43 insertions, 3 deletions
diff --git a/test/unit/mailer_test.rb b/test/unit/mailer_test.rb
index b8ff4f003..dfc6caf88 100644
--- a/test/unit/mailer_test.rb
+++ b/test/unit/mailer_test.rb
@@ -147,7 +147,7 @@ class MailerTest < ActiveSupport::TestCase
def test_message_posted_message_id
ActionMailer::Base.deliveries.clear
message = Message.find(1)
- Mailer.deliver_message_posted(message, message.author.mail)
+ Mailer.deliver_message_posted(message)
mail = ActionMailer::Base.deliveries.last
assert_not_nil mail
assert_equal Mailer.message_id_for(message), mail.message_id
@@ -157,13 +157,47 @@ class MailerTest < ActiveSupport::TestCase
def test_reply_posted_message_id
ActionMailer::Base.deliveries.clear
message = Message.find(3)
- Mailer.deliver_message_posted(message, message.author.mail)
+ Mailer.deliver_message_posted(message)
mail = ActionMailer::Base.deliveries.last
assert_not_nil mail
assert_equal Mailer.message_id_for(message), mail.message_id
assert_equal Mailer.message_id_for(message.parent), mail.references.first.to_s
end
+ context("#issue_add") do
+ setup do
+ ActionMailer::Base.deliveries.clear
+ Setting.bcc_recipients = '1'
+ @issue = Issue.find(1)
+ end
+
+ should "notify project members" do
+ assert Mailer.deliver_issue_add(@issue)
+ assert last_email.bcc.include?('dlopper@somenet.foo')
+ end
+
+ should "not notify project members that are not allow to view the issue" do
+ Role.find(2).remove_permission!(:view_issues)
+ assert Mailer.deliver_issue_add(@issue)
+ assert !last_email.bcc.include?('dlopper@somenet.foo')
+ end
+
+ should "notify issue watchers" do
+ user = User.find(9)
+ Watcher.create!(:watchable => @issue, :user => user)
+ assert Mailer.deliver_issue_add(@issue)
+ assert last_email.bcc.include?(user.mail)
+ end
+
+ should "not notify watchers not allowed to view the issue" do
+ user = User.find(9)
+ Watcher.create!(:watchable => @issue, :user => user)
+ Role.non_member.remove_permission!(:view_issues)
+ assert Mailer.deliver_issue_add(@issue)
+ assert !last_email.bcc.include?(user.mail)
+ end
+ end
+
# test mailer methods for each language
def test_issue_add
issue = Issue.find(1)
@@ -211,7 +245,7 @@ class MailerTest < ActiveSupport::TestCase
recipients = recipients.compact.uniq
valid_languages.each do |lang|
Setting.default_language = lang.to_s
- assert Mailer.deliver_message_posted(message, recipients)
+ assert Mailer.deliver_message_posted(message)
end
end
@@ -256,4 +290,10 @@ class MailerTest < ActiveSupport::TestCase
assert mail.bcc.include?('dlopper@somenet.foo')
assert mail.body.include?('Bug #3: Error 281 when updating a recipe')
end
+
+ def last_email
+ mail = ActionMailer::Base.deliveries.last
+ assert_not_nil mail
+ mail
+ end
end