summaryrefslogtreecommitdiffstats
path: root/test/functional
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2013-02-10 10:31:12 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2013-02-10 10:31:12 +0000
commit856ef810b4854c5524843f7f4f69157b6223bfc7 (patch)
tree7a70dadf59232d6f1ba565033b9f20ef937527be /test/functional
parent7303cc416c4e60658b6ea9af7d620c3f6c24066b (diff)
downloadredmine-856ef810b4854c5524843f7f4f69157b6223bfc7.tar.gz
redmine-856ef810b4854c5524843f7f4f69157b6223bfc7.zip
Bulk watch/unwatch issues from the context menu (#7159).
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@11339 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'test/functional')
-rw-r--r--test/functional/watchers_controller_test.rb49
1 files changed, 43 insertions, 6 deletions
diff --git a/test/functional/watchers_controller_test.rb b/test/functional/watchers_controller_test.rb
index abce6d558..44bda3d99 100644
--- a/test/functional/watchers_controller_test.rb
+++ b/test/functional/watchers_controller_test.rb
@@ -25,7 +25,7 @@ class WatchersControllerTest < ActionController::TestCase
User.current = nil
end
- def test_watch
+ def test_watch_a_single_object
@request.session[:user_id] = 3
assert_difference('Watcher.count') do
xhr :post, :watch, :object_type => 'issue', :object_id => '1'
@@ -35,6 +35,27 @@ class WatchersControllerTest < ActionController::TestCase
assert Issue.find(1).watched_by?(User.find(3))
end
+ def test_watch_a_collection_with_a_single_object
+ @request.session[:user_id] = 3
+ assert_difference('Watcher.count') do
+ xhr :post, :watch, :object_type => 'issue', :object_id => ['1']
+ assert_response :success
+ assert_include '$(".issue-1-watcher")', response.body
+ end
+ assert Issue.find(1).watched_by?(User.find(3))
+ end
+
+ def test_watch_a_collection_with_multiple_objects
+ @request.session[:user_id] = 3
+ assert_difference('Watcher.count', 2) do
+ xhr :post, :watch, :object_type => 'issue', :object_id => ['1', '3']
+ assert_response :success
+ assert_include '$(".issue-bulk-watcher")', response.body
+ end
+ assert Issue.find(1).watched_by?(User.find(3))
+ assert Issue.find(3).watched_by?(User.find(3))
+ end
+
def test_watch_should_be_denied_without_permission
Role.find(2).remove_permission! :view_issues
@request.session[:user_id] = 3
@@ -70,6 +91,20 @@ class WatchersControllerTest < ActionController::TestCase
assert !Issue.find(1).watched_by?(User.find(3))
end
+ def test_unwatch_a_collection_with_multiple_objects
+ @request.session[:user_id] = 3
+ Watcher.create!(:user_id => 3, :watchable => Issue.find(1))
+ Watcher.create!(:user_id => 3, :watchable => Issue.find(3))
+
+ assert_difference('Watcher.count', -2) do
+ xhr :post, :unwatch, :object_type => 'issue', :object_id => ['1', '3']
+ assert_response :success
+ assert_include '$(".issue-bulk-watcher")', response.body
+ end
+ assert !Issue.find(1).watched_by?(User.find(3))
+ assert !Issue.find(3).watched_by?(User.find(3))
+ end
+
def test_new
@request.session[:user_id] = 2
xhr :get, :new, :object_type => 'issue', :object_id => '2'
@@ -77,7 +112,7 @@ class WatchersControllerTest < ActionController::TestCase
assert_match /ajax-modal/, response.body
end
- def test_new_for_new_record_with_id
+ def test_new_for_new_record_with_project_id
@request.session[:user_id] = 2
xhr :get, :new, :project_id => 1
assert_response :success
@@ -85,7 +120,7 @@ class WatchersControllerTest < ActionController::TestCase
assert_match /ajax-modal/, response.body
end
- def test_new_for_new_record_with_identifier
+ def test_new_for_new_record_with_project_identifier
@request.session[:user_id] = 2
xhr :get, :new, :project_id => 'ecookbook'
assert_response :success
@@ -117,7 +152,8 @@ class WatchersControllerTest < ActionController::TestCase
end
def test_autocomplete_on_watchable_creation
- xhr :get, :autocomplete_for_user, :q => 'mi'
+ @request.session[:user_id] = 2
+ xhr :get, :autocomplete_for_user, :q => 'mi', :project_id => 'ecookbook'
assert_response :success
assert_select 'input', :count => 4
assert_select 'input[name=?][value=1]', 'watcher[user_ids][]'
@@ -127,7 +163,8 @@ class WatchersControllerTest < ActionController::TestCase
end
def test_autocomplete_on_watchable_update
- xhr :get, :autocomplete_for_user, :q => 'mi', :object_id => '2' , :object_type => 'issue'
+ @request.session[:user_id] = 2
+ xhr :get, :autocomplete_for_user, :q => 'mi', :object_id => '2' , :object_type => 'issue', :project_id => 'ecookbook'
assert_response :success
assert_select 'input', :count => 3
assert_select 'input[name=?][value=2]', 'watcher[user_ids][]'
@@ -139,7 +176,7 @@ class WatchersControllerTest < ActionController::TestCase
def test_append
@request.session[:user_id] = 2
assert_no_difference 'Watcher.count' do
- xhr :post, :append, :watcher => {:user_ids => ['4', '7']}
+ xhr :post, :append, :watcher => {:user_ids => ['4', '7']}, :project_id => 'ecookbook'
assert_response :success
assert_include 'watchers_inputs', response.body
assert_include 'issue[watcher_user_ids][]', response.body