summaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorGo MAEDA <maeda@farend.jp>2018-07-08 07:26:11 +0000
committerGo MAEDA <maeda@farend.jp>2018-07-08 07:26:11 +0000
commit53f6578b5ac4d89359fbc8edc97a07d308977a79 (patch)
tree932ca948a3dac6d9febce5912fd4a69132d52c67 /test
parentc999dacf0c54b3b948074b87247a68f68555d6e6 (diff)
downloadredmine-53f6578b5ac4d89359fbc8edc97a07d308977a79.tar.gz
redmine-53f6578b5ac4d89359fbc8edc97a07d308977a79.zip
Merged r17436 from trunk to 3.4-stable (#29133).
git-svn-id: http://svn.redmine.org/redmine/branches/3.4-stable@17437 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'test')
-rw-r--r--test/unit/query_test.rb32
1 files changed, 32 insertions, 0 deletions
diff --git a/test/unit/query_test.rb b/test/unit/query_test.rb
index bb5effdef..dfa2ace6d 100644
--- a/test/unit/query_test.rb
+++ b/test/unit/query_test.rb
@@ -876,6 +876,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'})