summaryrefslogtreecommitdiffstats
path: root/test/unit/news_test.rb
diff options
context:
space:
mode:
authorEric Davis <edavis@littlestreamsoftware.com>2009-03-28 00:38:57 +0000
committerEric Davis <edavis@littlestreamsoftware.com>2009-03-28 00:38:57 +0000
commitb4be8849c0de81841c458c0f059787a9cc9bc022 (patch)
tree2db816db1cb3cf2fd0761f1e3ad0bc1373f9f12e /test/unit/news_test.rb
parent3557e767e0b0c1e9fd7f97414a92f3d9dc00d98e (diff)
downloadredmine-b4be8849c0de81841c458c0f059787a9cc9bc022.tar.gz
redmine-b4be8849c0de81841c458c0f059787a9cc9bc022.zip
Added observers to watch model objects for mail delivery instead of calling Mailer.
* Added an IssueObserver to watch when Issues are created * Added a JournalObserver to watch when Journals are created (Issue updates) * Added a NewsObserver for News items. * Added a DocumentObserver for Document notifications. * Setup IssuesController#new to use the IssueObserver. * Setup IssuesController#edit to use the IssueObserver. * Setup IssuesController#bulk_edit to use the JournalObserver. * Removed the Mailer call in Changeset#scan_commit_for_issue_ids, the JournalObserver will handle it. * Removed Mailer calls in MailHandler in favor of the Observers. #2659 git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@2637 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'test/unit/news_test.rb')
-rw-r--r--test/unit/news_test.rb20
1 files changed, 17 insertions, 3 deletions
diff --git a/test/unit/news_test.rb b/test/unit/news_test.rb
index 527715b00..3a908dcc8 100644
--- a/test/unit/news_test.rb
+++ b/test/unit/news_test.rb
@@ -20,9 +20,23 @@ require File.dirname(__FILE__) + '/../test_helper'
class NewsTest < Test::Unit::TestCase
fixtures :projects, :users, :roles, :members, :enabled_modules, :news
+ def valid_news
+ { :title => 'Test news', :description => 'Lorem ipsum etc', :author => User.find(:first) }
+ end
+
+
def setup
end
+ def test_create_should_send_email_notification
+ ActionMailer::Base.deliveries.clear
+ Setting.notified_events << 'news_added'
+ news = Project.find(:first).news.new(valid_news)
+
+ assert news.save
+ assert_equal 1, ActionMailer::Base.deliveries.size
+ end
+
def test_should_include_news_for_projects_with_news_enabled
project = projects(:projects_001)
assert project.enabled_modules.any?{ |em| em.name == 'news' }
@@ -37,7 +51,7 @@ class NewsTest < Test::Unit::TestCase
assert ! project.enabled_modules.any?{ |em| em.name == 'news' }
# Add a piece of news to the project
- news = project.news.create(:title => 'Test news', :description => 'This should not be returned by News.latest')
+ news = project.news.create(valid_news)
# News.latest should not return that new piece of news
assert News.latest.include?(news) == false
@@ -50,14 +64,14 @@ class NewsTest < Test::Unit::TestCase
def test_should_limit_the_amount_of_returned_news
# Make sure we have a bunch of news stories
- 10.times { projects(:projects_001).news.create(:title => 'Test news', :description => 'Lorem ipsum etc') }
+ 10.times { projects(:projects_001).news.create(valid_news) }
assert_equal 2, News.latest(users(:users_002), 2).size
assert_equal 6, News.latest(users(:users_002), 6).size
end
def test_should_return_5_news_stories_by_default
# Make sure we have a bunch of news stories
- 10.times { projects(:projects_001).news.create(:title => 'Test news', :description => 'Lorem ipsum etc') }
+ 10.times { projects(:projects_001).news.create(valid_news) }
assert_equal 5, News.latest(users(:users_004)).size
end
end