mirror of
https://github.com/meineerde/redmine.git
synced 2025-12-19 15:01:14 +00:00
Fixed that user with permission can't remove a locked watcher (#21382).
git-svn-id: http://svn.redmine.org/redmine/trunk@14946 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
parent
3f44fad9ba
commit
9b52ae5c5a
@ -62,12 +62,14 @@ class WatchersController < ApplicationController
|
|||||||
end
|
end
|
||||||
|
|
||||||
def destroy
|
def destroy
|
||||||
@watched.set_watcher(User.visible.find(params[:user_id]), false)
|
@watched.set_watcher(User.find(params[:user_id]), false)
|
||||||
respond_to do |format|
|
respond_to do |format|
|
||||||
format.html { redirect_to :back }
|
format.html { redirect_to :back }
|
||||||
format.js
|
format.js
|
||||||
format.api { render_api_ok }
|
format.api { render_api_ok }
|
||||||
end
|
end
|
||||||
|
rescue ActiveRecord::RecordNotFound
|
||||||
|
render_404
|
||||||
end
|
end
|
||||||
|
|
||||||
def autocomplete_for_user
|
def autocomplete_for_user
|
||||||
|
|||||||
@ -259,7 +259,7 @@ class WatchersControllerTest < ActionController::TestCase
|
|||||||
assert response.body.blank?
|
assert response.body.blank?
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_remove_watcher
|
def test_destroy
|
||||||
@request.session[:user_id] = 2
|
@request.session[:user_id] = 2
|
||||||
assert_difference('Watcher.count', -1) do
|
assert_difference('Watcher.count', -1) do
|
||||||
xhr :delete, :destroy, :object_type => 'issue', :object_id => '2', :user_id => '3'
|
xhr :delete, :destroy, :object_type => 'issue', :object_id => '2', :user_id => '3'
|
||||||
@ -268,4 +268,26 @@ class WatchersControllerTest < ActionController::TestCase
|
|||||||
end
|
end
|
||||||
assert !Issue.find(2).watched_by?(User.find(3))
|
assert !Issue.find(2).watched_by?(User.find(3))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_destroy_locked_user
|
||||||
|
user = User.find(3)
|
||||||
|
user.lock!
|
||||||
|
assert user.reload.locked?
|
||||||
|
|
||||||
|
@request.session[:user_id] = 2
|
||||||
|
assert_difference('Watcher.count', -1) do
|
||||||
|
xhr :delete, :destroy, :object_type => 'issue', :object_id => '2', :user_id => '3'
|
||||||
|
assert_response :success
|
||||||
|
assert_match /watchers/, response.body
|
||||||
|
end
|
||||||
|
assert !Issue.find(2).watched_by?(User.find(3))
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_destroy_invalid_user_should_respond_with_404
|
||||||
|
@request.session[:user_id] = 2
|
||||||
|
assert_no_difference('Watcher.count') do
|
||||||
|
delete :destroy, :object_type => 'issue', :object_id => '2', :user_id => '999'
|
||||||
|
assert_response 404
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user