summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2012-07-05 13:51:56 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2012-07-05 13:51:56 +0000
commit196f96fff1d93ba55453166192cb242da048a742 (patch)
tree718bcea4969e41e7e0b80c5d2a51d12617876d43
parent1d7c0eb7c02d22f65ed1e4443abcf92b5bd7a899 (diff)
downloadredmine-196f96fff1d93ba55453166192cb242da048a742.tar.gz
redmine-196f96fff1d93ba55453166192cb242da048a742.zip
Adds Private filter to the issue list (#8577).
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@9920 e93f8b46-1217-0410-a6f0-8f06a7374b81
-rw-r--r--app/models/query.rb14
-rw-r--r--test/unit/query_test.rb30
2 files changed, 43 insertions, 1 deletions
diff --git a/app/models/query.rb b/app/models/query.rb
index 42309e01a..cd3a10f0a 100644
--- a/app/models/query.rb
+++ b/app/models/query.rb
@@ -302,7 +302,12 @@ class Query < ActiveRecord::Base
end
add_custom_fields_filters(IssueCustomField.find(:all, :conditions => {:is_filter => true, :is_for_all => true}))
end
-
+
+ if User.current.allowed_to?(:set_issues_private, nil, :global => true) ||
+ User.current.allowed_to?(:set_own_issues_private, nil, :global => true)
+ @available_filters["is_private"] = { :type => :list, :order => 15, :values => [[l(:general_text_yes), "1"], [l(:general_text_no), "0"]] }
+ end
+
Tracker.disabled_core_fields(trackers).each {|field|
@available_filters.delete field
}
@@ -704,6 +709,13 @@ class Query < ActiveRecord::Base
end
end
+ def sql_for_is_private_field(field, operator, value)
+ op = (operator == "=" ? 'IN' : 'NOT IN')
+ va = value.map {|v| v == '0' ? connection.quoted_false : connection.quoted_true}.uniq.join(',')
+
+ "#{Issue.table_name}.is_private #{op} (#{va})"
+ end
+
private
def sql_for_custom_field(field, operator, value, custom_field_id)
diff --git a/test/unit/query_test.rb b/test/unit/query_test.rb
index 61f7a4b01..522d8d0a3 100644
--- a/test/unit/query_test.rb
+++ b/test/unit/query_test.rb
@@ -258,6 +258,36 @@ class QueryTest < ActiveSupport::TestCase
assert issues.map(&:id).include?(3)
end
+ def test_operator_is_on_is_private_field
+ # is_private filter only available for those who can set issues private
+ User.current = User.find(2)
+
+ query = Query.new(:name => '_')
+ assert query.available_filters.key?('is_private')
+
+ query.add_filter("is_private", '=', ['1'])
+ issues = find_issues_with_query(query)
+ assert issues.any?
+ assert_nil issues.detect {|issue| !issue.is_private?}
+ ensure
+ User.current = nil
+ end
+
+ def test_operator_is_not_on_is_private_field
+ # is_private filter only available for those who can set issues private
+ User.current = User.find(2)
+
+ query = Query.new(:name => '_')
+ assert query.available_filters.key?('is_private')
+
+ query.add_filter("is_private", '!', ['1'])
+ issues = find_issues_with_query(query)
+ assert issues.any?
+ assert_nil issues.detect {|issue| issue.is_private?}
+ ensure
+ User.current = nil
+ end
+
def test_operator_greater_than
query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('done_ratio', '>=', ['40'])