diff options
author | Go MAEDA <maeda@farend.jp> | 2018-07-08 07:27:12 +0000 |
---|---|---|
committer | Go MAEDA <maeda@farend.jp> | 2018-07-08 07:27:12 +0000 |
commit | ced636c06c3141144b6d94fc90ec2337019e9317 (patch) | |
tree | 7f7a4ecc74b3eb410fafc8668cfb5a36a1d5c1e9 /test/unit | |
parent | defd2034cfce8a402cfcb925b00552071aa43099 (diff) | |
download | redmine-ced636c06c3141144b6d94fc90ec2337019e9317.tar.gz redmine-ced636c06c3141144b6d94fc90ec2337019e9317.zip |
Merged r17436 from trunk to 3.3-stable (#29133).
git-svn-id: http://svn.redmine.org/redmine/branches/3.3-stable@17438 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'test/unit')
-rw-r--r-- | test/unit/query_test.rb | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/test/unit/query_test.rb b/test/unit/query_test.rb index 9e4c76417..54b96ea40 100644 --- a/test/unit/query_test.rb +++ b/test/unit/query_test.rb @@ -746,6 +746,38 @@ class QueryTest < ActiveSupport::TestCase User.current = nil end + def test_filter_on_watched_issues_with_view_issue_watchers_permission + User.current = User.find(1) + User.current.admin = true + assert User.current.allowed_to?(:view_issue_watchers, Project.find(1)) + + Issue.find(1).add_watcher User.current + Issue.find(3).add_watcher User.find(3) + query = IssueQuery.new(:name => '_', :filters => { 'watcher_id' => {:operator => '=', :values => ['me', '3']}}) + result = find_issues_with_query(query) + assert_includes result, Issue.find(1) + assert_includes result, Issue.find(3) + ensure + User.current.reload + User.current = nil + end + + def test_filter_on_watched_issues_without_view_issue_watchers_permission + User.current = User.find(1) + User.current.admin = false + assert !User.current.allowed_to?(:view_issue_watchers, Project.find(1)) + + Issue.find(1).add_watcher User.current + Issue.find(3).add_watcher User.find(3) + query = IssueQuery.new(:name => '_', :filters => { 'watcher_id' => {:operator => '=', :values => ['me', '3']}}) + result = find_issues_with_query(query) + assert_includes result, Issue.find(1) + assert_not_includes result, Issue.find(3) + ensure + User.current.reload + User.current = nil + end + def test_filter_on_custom_field_should_ignore_projects_with_field_disabled field = IssueCustomField.generate!(:trackers => Tracker.all, :project_ids => [1, 3, 4], :is_for_all => false, :is_filter => true) Issue.generate!(:project_id => 3, :tracker_id => 2, :custom_field_values => {field.id.to_s => 'Foo'}) |