if request.post?
@user.safe_attributes = params[:user]
@user.pref.attributes = params[:pref]
- @user.pref[:no_self_notified] = (params[:no_self_notified] == '1')
if @user.save
@user.pref.save
@user.notified_project_ids = (@user.mail_notification == 'selected' ? params[:notified_project_ids] : [])
if @user.save
@user.pref.attributes = params[:pref]
- @user.pref[:no_self_notified] = (params[:no_self_notified] == '1')
@user.pref.save
@user.notified_project_ids = (@user.mail_notification == 'selected' ? params[:notified_project_ids] : [])
was_activated = (@user.status_change == [User::STATUS_REGISTERED, User::STATUS_ACTIVE])
# TODO: Similar to My#account
@user.pref.attributes = params[:pref]
- @user.pref[:no_self_notified] = (params[:no_self_notified] == '1')
if @user.save
@user.pref.save
# Removes the author from the recipients and cc
# if he doesn't want to receive notifications about what he does
- if @author && @author.logged? && @author.pref[:no_self_notified]
+ if @author && @author.logged? && @author.pref.no_self_notified
headers[:to].delete(@author.mail) if headers[:to].is_a?(Array)
headers[:cc].delete(@author.mail) if headers[:cc].is_a?(Array)
end
def warn_on_leaving_unsaved; self[:warn_on_leaving_unsaved] || '1'; end
def warn_on_leaving_unsaved=(value); self[:warn_on_leaving_unsaved]=value; end
+
+ def no_self_notified; (self[:no_self_notified] == true || self[:no_self_notified] == '1'); end
+ def no_self_notified=(value); self[:no_self_notified]=value; end
end
end %>
<p><em class="info"><%= l(:text_user_mail_option) %></em></p>
<% end %>
+
+<%= fields_for :pref, @user.pref do |pref_fields| %>
<p>
- <label>
- <%= l(:label_user_mail_no_self_notified) %>
- <%= check_box_tag 'no_self_notified', 1, @user.pref[:no_self_notified] %>
- </label>
+ <%= pref_fields.check_box :no_self_notified %>
+ <label for="pref_no_self_notified"><%= l(:label_user_mail_no_self_notified) %></label>
</p>
+<% end %>
def test_test_email
user = User.find(1)
- user.pref[:no_self_notified] = '1'
+ user.pref.no_self_notified = '1'
user.pref.save!
ActionMailer::Base.deliveries.clear
assert_equal [1, 2], u.notified_projects_ids.sort
end
+ def test_update_status_should_not_update_attributes
+ user = User.find(2)
+ user.pref[:no_self_notified] = '1'
+ user.pref.save
+
+ put :update, :id => 2, :user => {:status => 3}
+ assert_response 302
+ user = User.find(2)
+ assert_equal 3, user.status
+ assert_equal '1', user.pref[:no_self_notified]
+ end
+
def test_destroy
assert_difference 'User.count', -1 do
delete :destroy, :id => 2
# Remove members except news author
news.project.memberships.each {|m| m.destroy unless m.user == user}
- user.pref[:no_self_notified] = false
+ user.pref.no_self_notified = false
user.pref.save
User.current = user
Mailer.news_added(news.reload).deliver
assert_equal 1, last_email.bcc.size
# nobody to notify
- user.pref[:no_self_notified] = true
+ user.pref.no_self_notified = true
user.pref.save
User.current = user
ActionMailer::Base.deliveries.clear
issue = Issue.find(1)
user = User.find(9)
# minimal email notification options
- user.pref[:no_self_notified] = '1'
+ user.pref.no_self_notified = '1'
user.pref.save
user.mail_notification = false
user.save