Commit 4844d8a7f0e501c6aea07fba8038a7d7b29896a7
Committed by
Antonio Terceiro
1 parent
3abf2bac
Exists in
master
and in
29 other branches
The suggestion of the article must be reported to the profile(s) moderator(s) by email.
(ActionItem1732)
Showing
8 changed files
with
58 additions
and
14 deletions
Show diff stats
app/models/change_password.rb
app/models/invitation.rb
app/models/suggest_article.rb
... | ... | @@ -38,4 +38,9 @@ class SuggestArticle < Task |
38 | 38 | ) |
39 | 39 | end |
40 | 40 | |
41 | + def target_notification_message | |
42 | + description + "\n\n" + | |
43 | + _('You need to login on %{system} in order to approve or reject this article.') % { :system => target.environment.name } | |
44 | + end | |
45 | + | |
41 | 46 | end | ... | ... |
app/models/task.rb
... | ... | @@ -144,6 +144,10 @@ class Task < ActiveRecord::Base |
144 | 144 | :perform_task |
145 | 145 | end |
146 | 146 | |
147 | + def environment | |
148 | + self.target.environment unless self.target.nil? | |
149 | + end | |
150 | + | |
147 | 151 | protected |
148 | 152 | |
149 | 153 | # This method must be overrided in subclasses, and its implementation must do | ... | ... |
app/models/task_mailer.rb
... | ... | @@ -17,11 +17,10 @@ class TaskMailer < ActionMailer::Base |
17 | 17 | url_for_tasks_list = task.target.kind_of?(Environment) ? '' : url_for(task.target.url.merge(:controller => 'tasks', :action => 'index')) |
18 | 18 | |
19 | 19 | from self.class.generate_from(task) |
20 | - subject '[%s] %s' % [task.requestor.environment.name, task.description] | |
21 | - body :requestor => task.requestor.name, | |
22 | - :target => task.target.name, | |
20 | + subject '[%s] %s' % [task.environment.name, task.description] | |
21 | + body :target => task.target.name, | |
23 | 22 | :message => msg, |
24 | - :environment => task.requestor.environment.name, | |
23 | + :environment => task.environment.name, | |
25 | 24 | :url => generate_environment_url(task, :controller => 'home'), |
26 | 25 | :tasks_url => url_for_tasks_list |
27 | 26 | end |
... | ... | @@ -61,11 +60,11 @@ class TaskMailer < ActionMailer::Base |
61 | 60 | end |
62 | 61 | |
63 | 62 | def self.generate_from(task) |
64 | - "#{task.requestor.environment.name} <#{task.requestor.environment.contact_email}>" | |
63 | + "#{task.environment.name} <#{task.environment.contact_email}>" | |
65 | 64 | end |
66 | 65 | |
67 | 66 | def generate_environment_url(task, url = {}) |
68 | - url_for(Noosfero.url_options.merge(:host => task.requestor.environment.default_hostname).merge(url)) | |
67 | + url_for(Noosfero.url_options.merge(:host => task.environment.default_hostname).merge(url)) | |
69 | 68 | end |
70 | 69 | |
71 | 70 | end | ... | ... |
test/unit/suggest_article_test.rb
... | ... | @@ -119,4 +119,16 @@ class SuggestArticleTest < ActiveSupport::TestCase |
119 | 119 | assert article.highlighted |
120 | 120 | end |
121 | 121 | |
122 | + should 'override target notification message method from Task' do | |
123 | + task = build(SuggestArticle, :target => @profile) | |
124 | + assert_nothing_raised NotImplementedError do | |
125 | + task.target_notification_message | |
126 | + end | |
127 | + end | |
128 | + | |
129 | + should 'notify community moderators after create article suggestions' do | |
130 | + task = build(SuggestArticle, :target => @profile) | |
131 | + task.save | |
132 | + end | |
133 | + | |
122 | 134 | end | ... | ... |
test/unit/task_mailer_test.rb
... | ... | @@ -30,6 +30,7 @@ class TaskMailerTest < Test::Unit::TestCase |
30 | 30 | |
31 | 31 | task.expects(:requestor).returns(requestor).at_least_once |
32 | 32 | requestor.expects(:environment).returns(environment).at_least_once |
33 | + task.expects(:environment).returns(environment).at_least_once | |
33 | 34 | |
34 | 35 | TaskMailer.deliver_task_finished(task) |
35 | 36 | assert !ActionMailer::Base.deliveries.empty? |
... | ... | @@ -52,6 +53,7 @@ class TaskMailerTest < Test::Unit::TestCase |
52 | 53 | |
53 | 54 | task.expects(:requestor).returns(requestor).at_least_once |
54 | 55 | requestor.expects(:environment).returns(environment).at_least_once |
56 | + task.expects(:environment).returns(environment).at_least_once | |
55 | 57 | |
56 | 58 | TaskMailer.deliver_task_cancelled(task) |
57 | 59 | assert !ActionMailer::Base.deliveries.empty? |
... | ... | @@ -75,6 +77,7 @@ class TaskMailerTest < Test::Unit::TestCase |
75 | 77 | |
76 | 78 | task.expects(:requestor).returns(requestor).at_least_once |
77 | 79 | requestor.expects(:environment).returns(environment).at_least_once |
80 | + task.expects(:environment).returns(environment).at_least_once | |
78 | 81 | |
79 | 82 | TaskMailer.deliver_task_created(task) |
80 | 83 | assert !ActionMailer::Base.deliveries.empty? |
... | ... | @@ -84,9 +87,6 @@ class TaskMailerTest < Test::Unit::TestCase |
84 | 87 | task = Task.new |
85 | 88 | task.expects(:description).returns('the task') |
86 | 89 | |
87 | - requestor = mock() | |
88 | - requestor.expects(:name).returns('my name') | |
89 | - | |
90 | 90 | target = mock() |
91 | 91 | target.expects(:notification_emails).returns(['target@example.com']) |
92 | 92 | target.expects(:name).returns('Target') |
... | ... | @@ -97,9 +97,8 @@ class TaskMailerTest < Test::Unit::TestCase |
97 | 97 | environment.expects(:default_hostname).returns('example.com') |
98 | 98 | environment.expects(:name).returns('example').at_least_once |
99 | 99 | |
100 | - task.expects(:requestor).returns(requestor).at_least_once | |
101 | 100 | task.expects(:target).returns(target).at_least_once |
102 | - requestor.expects(:environment).returns(environment).at_least_once | |
101 | + task.expects(:environment).returns(environment).at_least_once | |
103 | 102 | |
104 | 103 | TaskMailer.deliver_target_notification(task, 'the message') |
105 | 104 | assert !ActionMailer::Base.deliveries.empty? |
... | ... | @@ -126,6 +125,7 @@ class TaskMailerTest < Test::Unit::TestCase |
126 | 125 | task.expects(:requestor).returns(requestor).at_least_once |
127 | 126 | task.expects(:person).returns(requestor).at_least_once |
128 | 127 | requestor.expects(:environment).returns(environment).at_least_once |
128 | + task.expects(:environment).returns(environment).at_least_once | |
129 | 129 | |
130 | 130 | mail = TaskMailer.create_invitation_notification(task) |
131 | 131 | |
... | ... | @@ -137,13 +137,11 @@ class TaskMailerTest < Test::Unit::TestCase |
137 | 137 | |
138 | 138 | should 'use environment name and contact email' do |
139 | 139 | task = mock |
140 | - requestor = mock | |
141 | 140 | environment = mock |
142 | 141 | environment.expects(:name).returns('My name') |
143 | 142 | environment.expects(:contact_email).returns('email@example.com') |
144 | 143 | |
145 | - task.expects(:requestor).returns(requestor).at_least_once | |
146 | - requestor.expects(:environment).returns(environment).at_least_once | |
144 | + task.expects(:environment).returns(environment).at_least_once | |
147 | 145 | |
148 | 146 | assert_equal 'My name <email@example.com>', TaskMailer.generate_from(task) |
149 | 147 | end | ... | ... |
test/unit/task_test.rb
... | ... | @@ -214,6 +214,23 @@ class TaskTest < Test::Unit::TestCase |
214 | 214 | task.save! |
215 | 215 | end |
216 | 216 | |
217 | + should 'the environment method be defined' do | |
218 | + task = Task.new | |
219 | + assert task.method_exists?('environment') | |
220 | + end | |
221 | + | |
222 | + should 'the task environment method return the target environment' do | |
223 | + task = Task.new | |
224 | + target = Profile.new(:environment => Environment.new) | |
225 | + task.target = target | |
226 | + assert_equal task.environment, target.environment | |
227 | + end | |
228 | + | |
229 | + should 'the task environment method return nil if the target task is nil' do | |
230 | + task = Task.new | |
231 | + assert_equal task.environment, nil | |
232 | + end | |
233 | + | |
217 | 234 | protected |
218 | 235 | |
219 | 236 | def sample_user | ... | ... |