From a00d1eabd7c47ad93cbcffc7eb6d6b7ed7f0f3f0 Mon Sep 17 00:00:00 2001 From: Jean-Philippe Lang Date: Fri, 30 Apr 2010 11:02:27 +0000 Subject: [PATCH] Fixed: watchers selection lost when issue creation fails (#5406). #watched_by? was fixed in order to work with #watcher_user_ids= used in controllers on unsaved objects. git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@3705 e93f8b46-1217-0410-a6f0-8f06a7374b81 --- test/unit/watcher_test.rb | 6 ++++++ vendor/plugins/acts_as_watchable/lib/acts_as_watchable.rb | 4 ++-- 2 files changed, 8 insertions(+), 2 deletions(-) diff --git a/test/unit/watcher_test.rb b/test/unit/watcher_test.rb index db73f8ccc..d0fe588bf 100644 --- a/test/unit/watcher_test.rb +++ b/test/unit/watcher_test.rb @@ -47,6 +47,12 @@ class WatcherTest < ActiveSupport::TestCase assert Issue.watched_by(@user).include?(@issue) end + def test_watcher_user_ids + issue = Issue.new + issue.watcher_user_ids = ['1', '3'] + assert issue.watched_by?(User.find(1)) + end + def test_recipients @issue.watchers.delete_all @issue.reload diff --git a/vendor/plugins/acts_as_watchable/lib/acts_as_watchable.rb b/vendor/plugins/acts_as_watchable/lib/acts_as_watchable.rb index f99f4a60d..b4ac776ec 100644 --- a/vendor/plugins/acts_as_watchable/lib/acts_as_watchable.rb +++ b/vendor/plugins/acts_as_watchable/lib/acts_as_watchable.rb @@ -50,9 +50,9 @@ module Redmine watching ? add_watcher(user) : remove_watcher(user) end - # Returns true if object is watched by user + # Returns true if object is watched by +user+ def watched_by?(user) - !!(user && self.watchers.detect {|w| w.user_id == user.id }) + !!(user && self.watcher_user_ids.detect {|uid| uid == user.id }) end # Returns an array of watchers' email addresses