##// END OF EJS Templates
When copying issues, let the status be changed to default or left unchanged....
When copying issues, let the status be changed to default or left unchanged. git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@9404 e93f8b46-1217-0410-a6f0-8f06a7374b81

File last commit:

r8627:2808adf99f44
r9270:09375960d69d
Show More
query_test.rb
973 lines | 36.5 KiB | text/x-ruby | RubyLexer
Jean-Philippe Lang
Extract visibility condition from project statement and use visible scopes instead....
r5322 # Redmine - project management software
# Copyright (C) 2006-2011 Jean-Philippe Lang
Jean-Philippe Lang
Fixed: queries with multiple custom fields return no result....
r662 #
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650 #
Jean-Philippe Lang
Fixed: queries with multiple custom fields return no result....
r662 # This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650 #
Jean-Philippe Lang
Fixed: queries with multiple custom fields return no result....
r662 # You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
Jean-Baptiste Barth
Use absolute paths in test/**/* requires for Ruby 1.9.2 compatibility. #4050...
r4395 require File.expand_path('../../test_helper', __FILE__)
Jean-Philippe Lang
Fixed: queries with multiple custom fields return no result....
r662
Eric Davis
Upgraded to Rails 2.3.4 (#3597)...
r2773 class QueryTest < ActiveSupport::TestCase
Toshi MARUYAMA
add new lines in fixtures at unit query test...
r7303 fixtures :projects, :enabled_modules, :users, :members,
:member_roles, :roles, :trackers, :issue_statuses,
:issue_categories, :enumerations, :issues,
:watchers, :custom_fields, :custom_values, :versions,
Toshi MARUYAMA
add missing "projects_trackers" fixture at unit query test in running on empty database...
r7304 :queries,
:projects_trackers
Jean-Philippe Lang
Fixed: queries with multiple custom fields return no result....
r662
Jean-Philippe Lang
Add filters on cross-project issue list for custom fields marked as 'For all projects'....
r1562 def test_custom_fields_for_all_projects_should_be_available_in_global_queries
query = Query.new(:project => nil, :name => '_')
assert query.available_filters.has_key?('cf_1')
assert !query.available_filters.has_key?('cf_3')
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Adds filter for system shared versions on the cross project issue list (#4792)....
r3295 def test_system_shared_versions_should_be_available_in_global_queries
Version.find(2).update_attribute :sharing, 'system'
query = Query.new(:project => nil, :name => '_')
assert query.available_filters.has_key?('fixed_version_id')
assert query.available_filters['fixed_version_id'][:values].detect {|v| v.last == '2'}
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Baptiste Barth
Added project filter when viewing all issues. #5084...
r3813 def test_project_filter_in_global_queries
query = Query.new(:project => nil, :name => '_')
project_filter = query.available_filters["project_id"]
assert_not_nil project_filter
project_ids = project_filter[:values].map{|p| p[1]}
assert project_ids.include?("1") #public project
assert !project_ids.include?("2") #private project user cannot see
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Adds estimated hours to issue filters (#1678)....
r1687 def find_issues_with_query(query)
Issue.find :all,
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650 :include => [ :assigned_to, :status, :tracker, :project, :priority ],
Jean-Philippe Lang
Adds estimated hours to issue filters (#1678)....
r1687 :conditions => query.statement
end
Jean-Philippe Lang
Version sharing (#465) + optional inclusion of subprojects in the roadmap view (#2666)....
r3009
Eric Davis
Added a "Member of Group" to the issues filter. #5869...
r3963 def assert_find_issues_with_query_is_successful(query)
assert_nothing_raised do
find_issues_with_query(query)
end
end
def assert_query_statement_includes(query, condition)
assert query.statement.include?(condition), "Query statement condition not found in: #{query.statement}"
end
Jean-Philippe Lang
Fixed: Issue filter by assigned_to_role is not project specific (#9540)....
r7727
def assert_query_result(expected, query)
assert_nothing_raised do
assert_equal expected.map(&:id).sort, query.issues.map(&:id).sort
assert_equal expected.size, query.issue_count
end
end
Eric Davis
Added a "Member of Group" to the issues filter. #5869...
r3963
Jean-Philippe Lang
Version sharing (#465) + optional inclusion of subprojects in the roadmap view (#2666)....
r3009 def test_query_should_allow_shared_versions_for_a_project_query
subproject_version = Version.find(4)
query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('fixed_version_id', '=', [subproject_version.id.to_s])
assert query.statement.include?("#{Issue.table_name}.fixed_version_id IN ('4')")
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Fixed: queries with multiple custom fields return no result....
r662 def test_query_with_multiple_custom_fields
query = Query.find(1)
assert query.valid?
Jean-Philippe Lang
Fixes custom field filters behaviour (#1078)....
r1347 assert query.statement.include?("#{CustomValue.table_name}.value IN ('MySQL')")
Jean-Philippe Lang
Adds estimated hours to issue filters (#1678)....
r1687 issues = find_issues_with_query(query)
Jean-Philippe Lang
Fixed: queries with multiple custom fields return no result....
r662 assert_equal 1, issues.length
assert_equal Issue.find(3), issues.first
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Fixed: Search for target version of "none" fails with postgres 8.3 (#1134)....
r1364 def test_operator_none
query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('fixed_version_id', '!*', [''])
query.add_filter('cf_1', '!*', [''])
assert query.statement.include?("#{Issue.table_name}.fixed_version_id IS NULL")
assert query.statement.include?("#{CustomValue.table_name}.value IS NULL OR #{CustomValue.table_name}.value = ''")
Jean-Philippe Lang
Adds estimated hours to issue filters (#1678)....
r1687 find_issues_with_query(query)
Jean-Philippe Lang
Fixed: Search for target version of "none" fails with postgres 8.3 (#1134)....
r1364 end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Adds estimated hours to issue filters (#1678)....
r1687 def test_operator_none_for_integer
query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('estimated_hours', '!*', [''])
issues = find_issues_with_query(query)
assert !issues.empty?
assert issues.all? {|i| !i.estimated_hours}
end
Jean-Philippe Lang
Adds a way to filter issues with or without start date (#9607)....
r7721 def test_operator_none_for_date
query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('start_date', '!*', [''])
issues = find_issues_with_query(query)
assert !issues.empty?
assert issues.all? {|i| i.start_date.nil?}
end
Jean-Philippe Lang
Fixed: Search for target version of "none" fails with postgres 8.3 (#1134)....
r1364 def test_operator_all
query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('fixed_version_id', '*', [''])
query.add_filter('cf_1', '*', [''])
assert query.statement.include?("#{Issue.table_name}.fixed_version_id IS NOT NULL")
assert query.statement.include?("#{CustomValue.table_name}.value IS NOT NULL AND #{CustomValue.table_name}.value <> ''")
Jean-Philippe Lang
Adds estimated hours to issue filters (#1678)....
r1687 find_issues_with_query(query)
Jean-Philippe Lang
Fixed: Search for target version of "none" fails with postgres 8.3 (#1134)....
r1364 end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Adds a way to filter issues with or without start date (#9607)....
r7721 def test_operator_all_for_date
query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('start_date', '*', [''])
issues = find_issues_with_query(query)
assert !issues.empty?
assert issues.all? {|i| i.start_date.present?}
end
Jean-Philippe Lang
Reject non numeric values for numeric fields....
r6108 def test_numeric_filter_should_not_accept_non_numeric_values
query = Query.new(:name => '_')
query.add_filter('estimated_hours', '=', ['a'])
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Reject non numeric values for numeric fields....
r6108 assert query.has_filter?('estimated_hours')
assert !query.valid?
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Fixes filters on float values....
r6107 def test_operator_is_on_float
Issue.update_all("estimated_hours = 171.2", "id=2")
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Fixes filters on float values....
r6107 query = Query.new(:name => '_')
query.add_filter('estimated_hours', '=', ['171.20'])
issues = find_issues_with_query(query)
assert_equal 1, issues.size
assert_equal 2, issues.first.id
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Fixed: error when filtering by numeric custom field with postgresql (#9719)....
r7978 def test_operator_is_on_integer_custom_field
f = IssueCustomField.create!(:name => 'filter', :field_format => 'int', :is_for_all => true, :is_filter => true)
CustomValue.create!(:custom_field => f, :customized => Issue.find(1), :value => '7')
CustomValue.create!(:custom_field => f, :customized => Issue.find(2), :value => '12')
CustomValue.create!(:custom_field => f, :customized => Issue.find(3), :value => '')
query = Query.new(:name => '_')
query.add_filter("cf_#{f.id}", '=', ['12'])
issues = find_issues_with_query(query)
assert_equal 1, issues.size
assert_equal 2, issues.first.id
end
def test_operator_is_on_float_custom_field
f = IssueCustomField.create!(:name => 'filter', :field_format => 'float', :is_filter => true, :is_for_all => true)
CustomValue.create!(:custom_field => f, :customized => Issue.find(1), :value => '7.3')
CustomValue.create!(:custom_field => f, :customized => Issue.find(2), :value => '12.7')
CustomValue.create!(:custom_field => f, :customized => Issue.find(3), :value => '')
query = Query.new(:name => '_')
query.add_filter("cf_#{f.id}", '=', ['12.7'])
issues = find_issues_with_query(query)
assert_equal 1, issues.size
assert_equal 2, issues.first.id
end
Jean-Philippe Lang
Adds support for multiselect custom fields (#1189)....
r8601 def test_operator_is_on_multi_list_custom_field
f = IssueCustomField.create!(:name => 'filter', :field_format => 'list', :is_filter => true, :is_for_all => true,
:possible_values => ['value1', 'value2', 'value3'], :multiple => true)
CustomValue.create!(:custom_field => f, :customized => Issue.find(1), :value => 'value1')
CustomValue.create!(:custom_field => f, :customized => Issue.find(1), :value => 'value2')
CustomValue.create!(:custom_field => f, :customized => Issue.find(3), :value => 'value1')
query = Query.new(:name => '_')
query.add_filter("cf_#{f.id}", '=', ['value1'])
issues = find_issues_with_query(query)
assert_equal [1, 3], issues.map(&:id).sort
query = Query.new(:name => '_')
query.add_filter("cf_#{f.id}", '=', ['value2'])
issues = find_issues_with_query(query)
assert_equal [1], issues.map(&:id).sort
end
def test_operator_is_not_on_multi_list_custom_field
f = IssueCustomField.create!(:name => 'filter', :field_format => 'list', :is_filter => true, :is_for_all => true,
:possible_values => ['value1', 'value2', 'value3'], :multiple => true)
CustomValue.create!(:custom_field => f, :customized => Issue.find(1), :value => 'value1')
CustomValue.create!(:custom_field => f, :customized => Issue.find(1), :value => 'value2')
CustomValue.create!(:custom_field => f, :customized => Issue.find(3), :value => 'value1')
query = Query.new(:name => '_')
query.add_filter("cf_#{f.id}", '!', ['value1'])
issues = find_issues_with_query(query)
assert !issues.map(&:id).include?(1)
assert !issues.map(&:id).include?(3)
query = Query.new(:name => '_')
query.add_filter("cf_#{f.id}", '!', ['value2'])
issues = find_issues_with_query(query)
assert !issues.map(&:id).include?(1)
assert issues.map(&:id).include?(3)
end
Jean-Philippe Lang
Fixed: Search for target version of "none" fails with postgres 8.3 (#1134)....
r1364 def test_operator_greater_than
query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('done_ratio', '>=', ['40'])
Jean-Philippe Lang
Fixes filters on float values....
r6107 assert query.statement.include?("#{Issue.table_name}.done_ratio >= 40.0")
find_issues_with_query(query)
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Fixes filters on float values....
r6107 def test_operator_greater_than_a_float
query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('estimated_hours', '>=', ['40.5'])
assert query.statement.include?("#{Issue.table_name}.estimated_hours >= 40.5")
Jean-Philippe Lang
Adds estimated hours to issue filters (#1678)....
r1687 find_issues_with_query(query)
Jean-Philippe Lang
Fixed: Search for target version of "none" fails with postgres 8.3 (#1134)....
r1364 end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Fixed: error when filtering by numeric custom field with postgresql (#9719)....
r7978 def test_operator_greater_than_on_int_custom_field
Jean-Philippe Lang
Fixes "less than", "greater than" filters on custom fields with postgres (#6180)....
r6096 f = IssueCustomField.create!(:name => 'filter', :field_format => 'int', :is_filter => true, :is_for_all => true)
Jean-Philippe Lang
Fixed: error when filtering by numeric custom field with postgresql (#9719)....
r7978 CustomValue.create!(:custom_field => f, :customized => Issue.find(1), :value => '7')
CustomValue.create!(:custom_field => f, :customized => Issue.find(2), :value => '12')
CustomValue.create!(:custom_field => f, :customized => Issue.find(3), :value => '')
Jean-Philippe Lang
Fixes "less than", "greater than" filters on custom fields with postgres (#6180)....
r6096 query = Query.new(:project => Project.find(1), :name => '_')
Jean-Philippe Lang
Fixed: error when filtering by numeric custom field with postgresql (#9719)....
r7978 query.add_filter("cf_#{f.id}", '>=', ['8'])
issues = find_issues_with_query(query)
assert_equal 1, issues.size
assert_equal 2, issues.first.id
Jean-Philippe Lang
Fixes "less than", "greater than" filters on custom fields with postgres (#6180)....
r6096 end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Fixes "less than", "greater than" filters on custom fields with postgres (#6180)....
r6096 def test_operator_lesser_than
query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('done_ratio', '<=', ['30'])
Jean-Philippe Lang
Fixes filters on float values....
r6107 assert query.statement.include?("#{Issue.table_name}.done_ratio <= 30.0")
Jean-Philippe Lang
Fixes "less than", "greater than" filters on custom fields with postgres (#6180)....
r6096 find_issues_with_query(query)
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Fixes "less than", "greater than" filters on custom fields with postgres (#6180)....
r6096 def test_operator_lesser_than_on_custom_field
f = IssueCustomField.create!(:name => 'filter', :field_format => 'int', :is_filter => true, :is_for_all => true)
query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter("cf_#{f.id}", '<=', ['30'])
Jean-Philippe Lang
Fixes filters on float values....
r6107 assert query.statement.include?("CAST(custom_values.value AS decimal(60,3)) <= 30.0")
Jean-Philippe Lang
Fixes "less than", "greater than" filters on custom fields with postgres (#6180)....
r6096 find_issues_with_query(query)
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Adds "between" operator for numeric filters (#6180)....
r6097 def test_operator_between
query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('done_ratio', '><', ['30', '40'])
Jean-Philippe Lang
Fixes filters on float values....
r6107 assert_include "#{Issue.table_name}.done_ratio BETWEEN 30.0 AND 40.0", query.statement
Jean-Philippe Lang
Adds "between" operator for numeric filters (#6180)....
r6097 find_issues_with_query(query)
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Adds "between" operator for numeric filters (#6180)....
r6097 def test_operator_between_on_custom_field
f = IssueCustomField.create!(:name => 'filter', :field_format => 'int', :is_filter => true, :is_for_all => true)
query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter("cf_#{f.id}", '><', ['30', '40'])
Jean-Philippe Lang
Fixes filters on float values....
r6107 assert_include "CAST(custom_values.value AS decimal(60,3)) BETWEEN 30.0 AND 40.0", query.statement
Jean-Philippe Lang
Adds "between" operator for numeric filters (#6180)....
r6097 find_issues_with_query(query)
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Validate date filters values....
r6144 def test_date_filter_should_not_accept_non_date_values
query = Query.new(:name => '_')
query.add_filter('created_on', '=', ['a'])
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Validate date filters values....
r6144 assert query.has_filter?('created_on')
assert !query.valid?
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
More accurate date validation....
r6145 def test_date_filter_should_not_accept_invalid_date_values
query = Query.new(:name => '_')
query.add_filter('created_on', '=', ['2011-01-34'])
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
More accurate date validation....
r6145 assert query.has_filter?('created_on')
assert !query.valid?
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Validate date filters values....
r6144 def test_relative_date_filter_should_not_accept_non_integer_values
query = Query.new(:name => '_')
query.add_filter('created_on', '>t-', ['a'])
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Validate date filters values....
r6144 assert query.has_filter?('created_on')
assert !query.valid?
end
Jean-Philippe Lang
Fixed: Search for target version of "none" fails with postgres 8.3 (#1134)....
r1364
Jean-Philippe Lang
Adds date based filters (#4729) and date range filter (#6954)....
r6106 def test_operator_date_equals
query = Query.new(:name => '_')
query.add_filter('due_date', '=', ['2011-07-10'])
assert_match /issues\.due_date > '2011-07-09 23:59:59(\.9+)?' AND issues\.due_date <= '2011-07-10 23:59:59(\.9+)?/, query.statement
find_issues_with_query(query)
end
def test_operator_date_lesser_than
query = Query.new(:name => '_')
query.add_filter('due_date', '<=', ['2011-07-10'])
assert_match /issues\.due_date <= '2011-07-10 23:59:59(\.9+)?/, query.statement
find_issues_with_query(query)
end
def test_operator_date_greater_than
query = Query.new(:name => '_')
query.add_filter('due_date', '>=', ['2011-07-10'])
assert_match /issues\.due_date > '2011-07-09 23:59:59(\.9+)?'/, query.statement
find_issues_with_query(query)
end
def test_operator_date_between
query = Query.new(:name => '_')
query.add_filter('due_date', '><', ['2011-06-23', '2011-07-10'])
assert_match /issues\.due_date > '2011-06-22 23:59:59(\.9+)?' AND issues\.due_date <= '2011-07-10 23:59:59(\.9+)?/, query.statement
find_issues_with_query(query)
end
Jean-Philippe Lang
Fixed: Search for target version of "none" fails with postgres 8.3 (#1134)....
r1364 def test_operator_in_more_than
Jean-Philippe Lang
Fixed date filters accuracy with SQLite (#2221)....
r2052 Issue.find(7).update_attribute(:due_date, (Date.today + 15))
Jean-Philippe Lang
Fixed: Search for target version of "none" fails with postgres 8.3 (#1134)....
r1364 query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('due_date', '>t+', ['15'])
Jean-Philippe Lang
Fixed date filters accuracy with SQLite (#2221)....
r2052 issues = find_issues_with_query(query)
assert !issues.empty?
issues.each {|issue| assert(issue.due_date >= (Date.today + 15))}
Jean-Philippe Lang
Fixed: Search for target version of "none" fails with postgres 8.3 (#1134)....
r1364 end
def test_operator_in_less_than
query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('due_date', '<t+', ['15'])
Jean-Philippe Lang
Fixed date filters accuracy with SQLite (#2221)....
r2052 issues = find_issues_with_query(query)
assert !issues.empty?
issues.each {|issue| assert(issue.due_date >= Date.today && issue.due_date <= (Date.today + 15))}
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Fixed date filters accuracy with SQLite (#2221)....
r2052 def test_operator_less_than_ago
Issue.find(7).update_attribute(:due_date, (Date.today - 3))
query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('due_date', '>t-', ['3'])
issues = find_issues_with_query(query)
assert !issues.empty?
issues.each {|issue| assert(issue.due_date >= (Date.today - 3) && issue.due_date <= Date.today)}
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Fixed date filters accuracy with SQLite (#2221)....
r2052 def test_operator_more_than_ago
Issue.find(7).update_attribute(:due_date, (Date.today - 10))
query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('due_date', '<t-', ['10'])
assert query.statement.include?("#{Issue.table_name}.due_date <=")
issues = find_issues_with_query(query)
assert !issues.empty?
issues.each {|issue| assert(issue.due_date <= (Date.today - 10))}
end
def test_operator_in
Issue.find(7).update_attribute(:due_date, (Date.today + 2))
query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('due_date', 't+', ['2'])
issues = find_issues_with_query(query)
assert !issues.empty?
issues.each {|issue| assert_equal((Date.today + 2), issue.due_date)}
end
def test_operator_ago
Issue.find(7).update_attribute(:due_date, (Date.today - 3))
query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('due_date', 't-', ['3'])
issues = find_issues_with_query(query)
assert !issues.empty?
issues.each {|issue| assert_equal((Date.today - 3), issue.due_date)}
Jean-Philippe Lang
Fixed: Search for target version of "none" fails with postgres 8.3 (#1134)....
r1364 end
def test_operator_today
query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('due_date', 't', [''])
Jean-Philippe Lang
Fixed date filters accuracy with SQLite (#2221)....
r2052 issues = find_issues_with_query(query)
assert !issues.empty?
issues.each {|issue| assert_equal Date.today, issue.due_date}
Jean-Philippe Lang
Fixed: Search for target version of "none" fails with postgres 8.3 (#1134)....
r1364 end
def test_operator_this_week_on_date
query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('due_date', 'w', [''])
Jean-Philippe Lang
Adds estimated hours to issue filters (#1678)....
r1687 find_issues_with_query(query)
Jean-Philippe Lang
Fixed: Search for target version of "none" fails with postgres 8.3 (#1134)....
r1364 end
def test_operator_this_week_on_datetime
query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('created_on', 'w', [''])
Jean-Philippe Lang
Adds estimated hours to issue filters (#1678)....
r1687 find_issues_with_query(query)
Jean-Philippe Lang
Fixed: Search for target version of "none" fails with postgres 8.3 (#1134)....
r1364 end
def test_operator_contains
query = Query.new(:project => Project.find(1), :name => '_')
Jean-Philippe Lang
Fixed: case sensitivity in issue subject filtering (#3536)....
r2696 query.add_filter('subject', '~', ['uNable'])
assert query.statement.include?("LOWER(#{Issue.table_name}.subject) LIKE '%unable%'")
result = find_issues_with_query(query)
assert result.empty?
result.each {|issue| assert issue.subject.downcase.include?('unable') }
Jean-Philippe Lang
Fixed: Search for target version of "none" fails with postgres 8.3 (#1134)....
r1364 end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Makes 'This week' filter work with any starting day of week (#7097)....
r5476 def test_range_for_this_week_with_week_starting_on_monday
I18n.locale = :fr
assert_equal '1', I18n.t(:general_first_day_of_week)
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Makes 'This week' filter work with any starting day of week (#7097)....
r5476 Date.stubs(:today).returns(Date.parse('2011-04-29'))
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Makes 'This week' filter work with any starting day of week (#7097)....
r5476 query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('due_date', 'w', [''])
Jean-Philippe Lang
Fixes an assertion for postgresql (#7097)....
r5483 assert query.statement.match(/issues\.due_date > '2011-04-24 23:59:59(\.9+)?' AND issues\.due_date <= '2011-05-01 23:59:59(\.9+)?/), "range not found in #{query.statement}"
Jean-Philippe Lang
Makes 'This week' filter work with any starting day of week (#7097)....
r5476 I18n.locale = :en
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Makes 'This week' filter work with any starting day of week (#7097)....
r5476 def test_range_for_this_week_with_week_starting_on_sunday
I18n.locale = :en
assert_equal '7', I18n.t(:general_first_day_of_week)
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Makes 'This week' filter work with any starting day of week (#7097)....
r5476 Date.stubs(:today).returns(Date.parse('2011-04-29'))
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Makes 'This week' filter work with any starting day of week (#7097)....
r5476 query = Query.new(:project => Project.find(1), :name => '_')
query.add_filter('due_date', 'w', [''])
Jean-Philippe Lang
Fixes an assertion for postgresql (#7097)....
r5483 assert query.statement.match(/issues\.due_date > '2011-04-23 23:59:59(\.9+)?' AND issues\.due_date <= '2011-04-30 23:59:59(\.9+)?/), "range not found in #{query.statement}"
Jean-Philippe Lang
Makes 'This week' filter work with any starting day of week (#7097)....
r5476 end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Fixed: Search for target version of "none" fails with postgres 8.3 (#1134)....
r1364 def test_operator_does_not_contains
query = Query.new(:project => Project.find(1), :name => '_')
Jean-Philippe Lang
Fixed: case sensitivity in issue subject filtering (#3536)....
r2696 query.add_filter('subject', '!~', ['uNable'])
assert query.statement.include?("LOWER(#{Issue.table_name}.subject) NOT LIKE '%unable%'")
Jean-Philippe Lang
Adds estimated hours to issue filters (#1678)....
r1687 find_issues_with_query(query)
Jean-Philippe Lang
Fixed: Search for target version of "none" fails with postgres 8.3 (#1134)....
r1364 end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Include issues asigned to user's groups when using "assigned to me" filter (#2964)....
r6212 def test_filter_assigned_to_me
user = User.find(2)
group = Group.find(10)
User.current = user
i1 = Issue.generate!(:project_id => 1, :tracker_id => 1, :assigned_to => user)
i2 = Issue.generate!(:project_id => 1, :tracker_id => 1, :assigned_to => group)
i3 = Issue.generate!(:project_id => 1, :tracker_id => 1, :assigned_to => Group.find(11))
group.users << user
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Include issues asigned to user's groups when using "assigned to me" filter (#2964)....
r6212 query = Query.new(:name => '_', :filters => { 'assigned_to_id' => {:operator => '=', :values => ['me']}})
result = query.issues
assert_equal Issue.visible.all(:conditions => {:assigned_to_id => ([2] + user.reload.group_ids)}).sort_by(&:id), result.sort_by(&:id)
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Include issues asigned to user's groups when using "assigned to me" filter (#2964)....
r6212 assert result.include?(i1)
assert result.include?(i2)
assert !result.include?(i3)
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Adds "me" to user custom fields filters (#9923)....
r8518 def test_user_custom_field_filtered_on_me
User.current = User.find(2)
cf = IssueCustomField.create!(:field_format => 'user', :is_for_all => true, :is_filter => true, :name => 'User custom field', :tracker_ids => [1])
issue1 = Issue.create!(:project_id => 1, :tracker_id => 1, :custom_field_values => {cf.id.to_s => '2'}, :subject => 'Test', :author_id => 1)
issue2 = Issue.generate!(:project_id => 1, :tracker_id => 1, :custom_field_values => {cf.id.to_s => '3'})
query = Query.new(:name => '_', :project => Project.find(1))
filter = query.available_filters["cf_#{cf.id}"]
assert_not_nil filter
assert_include 'me', filter[:values].map{|v| v[1]}
query.filters = { "cf_#{cf.id}" => {:operator => '=', :values => ['me']}}
result = query.issues
assert_equal 1, result.size
Jean-Philippe Lang
Fixed wrong assertion....
r8520 assert_equal issue1, result.first
Jean-Philippe Lang
Adds "me" to user custom fields filters (#9923)....
r8518 end
Jean-Philippe Lang
Adds "my projects" filter on the cross-project issue list....
r8517 def test_filter_my_projects
User.current = User.find(2)
query = Query.new(:name => '_')
filter = query.available_filters['project_id']
assert_not_nil filter
assert_include 'mine', filter[:values].map{|v| v[1]}
query.filters = { 'project_id' => {:operator => '=', :values => ['mine']}}
result = query.issues
assert_nil result.detect {|issue| !User.current.member_of?(issue.project)}
end
Jean-Philippe Lang
Adds ability to filter watched issues (#846)....
r2395 def test_filter_watched_issues
User.current = User.find(1)
query = Query.new(:name => '_', :filters => { 'watcher_id' => {:operator => '=', :values => ['me']}})
result = find_issues_with_query(query)
assert_not_nil result
assert !result.empty?
assert_equal Issue.visible.watched_by(User.current).sort_by(&:id), result.sort_by(&:id)
User.current = nil
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Adds ability to filter watched issues (#846)....
r2395 def test_filter_unwatched_issues
User.current = User.find(1)
query = Query.new(:name => '_', :filters => { 'watcher_id' => {:operator => '!', :values => ['me']}})
result = find_issues_with_query(query)
assert_not_nil result
assert !result.empty?
assert_equal((Issue.visible - Issue.watched_by(User.current)).sort_by(&:id).size, result.sort_by(&:id).size)
User.current = nil
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Extract visibility condition from project statement and use visible scopes instead....
r5322 def test_statement_should_be_nil_with_no_filters
q = Query.new(:name => '_')
q.filters = {}
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Extract visibility condition from project statement and use visible scopes instead....
r5322 assert q.valid?
assert_nil q.statement
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Added the ability to customize columns of a saved query....
r771 def test_default_columns
q = Query.new
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650 assert !q.columns.empty?
Jean-Philippe Lang
Added the ability to customize columns of a saved query....
r771 end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Added the ability to customize columns of a saved query....
r771 def test_set_column_names
q = Query.new
q.column_names = ['tracker', :subject, '', 'unknonw_column']
assert_equal [:tracker, :subject], q.columns.collect {|c| c.name}
c = q.columns.first
assert q.has_column?(c)
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Makes spent time column available on the issue list (#971)....
r7953 def test_query_should_preload_spent_hours
q = Query.new(:name => '_', :column_names => [:subject, :spent_hours])
assert q.has_column?(:spent_hours)
issues = q.issues
assert_not_nil issues.first.instance_variable_get("@spent_hours")
end
Jean-Philippe Lang
Allow issue grouping by custom field (#2679)....
r2957 def test_groupable_columns_should_include_custom_fields
q = Query.new
Jean-Philippe Lang
Adds support for multiselect custom fields (#1189)....
r8601 column = q.groupable_columns.detect {|c| c.name == :cf_1}
assert_not_nil column
assert_kind_of QueryCustomFieldColumn, column
end
def test_groupable_columns_should_not_include_multi_custom_fields
field = CustomField.find(1)
field.update_attribute :multiple, true
q = Query.new
column = q.groupable_columns.detect {|c| c.name == :cf_1}
assert_nil column
Jean-Philippe Lang
Allow issue grouping by custom field (#2679)....
r2957 end
Jean-Philippe Lang
Fixed: 500 error on issue query grouped by a custom field that was deleted (#7144)....
r4439
def test_grouped_with_valid_column
q = Query.new(:group_by => 'status')
assert q.grouped?
assert_not_nil q.group_by_column
assert_equal :status, q.group_by_column.name
assert_not_nil q.group_by_statement
assert_equal 'status', q.group_by_statement
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Fixed: 500 error on issue query grouped by a custom field that was deleted (#7144)....
r4439 def test_grouped_with_invalid_column
q = Query.new(:group_by => 'foo')
assert !q.grouped?
assert_nil q.group_by_column
assert_nil q.group_by_statement
end
Jean-Philippe Lang
Sort the issue list by author/assignee according to user display format (#9669)....
r7818
def test_sortable_columns_should_sort_assignees_according_to_user_format_setting
with_settings :user_format => 'lastname_coma_firstname' do
q = Query.new
assert q.sortable_columns.has_key?('assigned_to')
assert_equal %w(users.lastname users.firstname users.id), q.sortable_columns['assigned_to']
end
end
def test_sortable_columns_should_sort_authors_according_to_user_format_setting
with_settings :user_format => 'lastname_coma_firstname' do
q = Query.new
assert q.sortable_columns.has_key?('author')
assert_equal %w(authors.lastname authors.firstname authors.id), q.sortable_columns['author']
end
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Adds support for multiselect custom fields (#1189)....
r8601 def test_sortable_columns_should_include_custom_field
q = Query.new
assert q.sortable_columns['cf_1']
end
def test_sortable_columns_should_not_include_multi_custom_field
field = CustomField.find(1)
field.update_attribute :multiple, true
q = Query.new
assert !q.sortable_columns['cf_1']
end
Jean-Philippe Lang
Ability to save "sort order" in custom queries (#2899)....
r2504 def test_default_sort
q = Query.new
assert_equal [], q.sort_criteria
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Ability to save "sort order" in custom queries (#2899)....
r2504 def test_set_sort_criteria_with_hash
q = Query.new
q.sort_criteria = {'0' => ['priority', 'desc'], '2' => ['tracker']}
assert_equal [['priority', 'desc'], ['tracker', 'asc']], q.sort_criteria
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Ability to save "sort order" in custom queries (#2899)....
r2504 def test_set_sort_criteria_with_array
q = Query.new
q.sort_criteria = [['priority', 'desc'], 'tracker']
assert_equal [['priority', 'desc'], ['tracker', 'asc']], q.sort_criteria
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Ability to save "sort order" in custom queries (#2899)....
r2504 def test_create_query_with_sort
q = Query.new(:name => 'Sorted')
q.sort_criteria = [['priority', 'desc'], 'tracker']
assert q.save
q.reload
assert_equal [['priority', 'desc'], ['tracker', 'asc']], q.sort_criteria
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Ability to sort the issue list by text, list, date and boolean custom fields (#1139)....
r2255 def test_sort_by_string_custom_field_asc
q = Query.new
c = q.available_columns.find {|col| col.is_a?(QueryCustomFieldColumn) && col.custom_field.field_format == 'string' }
assert c
assert c.sortable
issues = Issue.find :all,
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650 :include => [ :assigned_to, :status, :tracker, :project, :priority ],
Jean-Philippe Lang
Ability to sort the issue list by text, list, date and boolean custom fields (#1139)....
r2255 :conditions => q.statement,
:order => "#{c.sortable} ASC"
values = issues.collect {|i| i.custom_value_for(c.custom_field).to_s}
Jean-Philippe Lang
Ability to sort the issue list by text, int and float custom fields (#1139)....
r2256 assert !values.empty?
Jean-Philippe Lang
Ability to sort the issue list by text, list, date and boolean custom fields (#1139)....
r2255 assert_equal values.sort, values
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Ability to sort the issue list by text, list, date and boolean custom fields (#1139)....
r2255 def test_sort_by_string_custom_field_desc
q = Query.new
c = q.available_columns.find {|col| col.is_a?(QueryCustomFieldColumn) && col.custom_field.field_format == 'string' }
assert c
assert c.sortable
issues = Issue.find :all,
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650 :include => [ :assigned_to, :status, :tracker, :project, :priority ],
Jean-Philippe Lang
Ability to sort the issue list by text, list, date and boolean custom fields (#1139)....
r2255 :conditions => q.statement,
:order => "#{c.sortable} DESC"
values = issues.collect {|i| i.custom_value_for(c.custom_field).to_s}
Jean-Philippe Lang
Ability to sort the issue list by text, int and float custom fields (#1139)....
r2256 assert !values.empty?
Jean-Philippe Lang
Ability to sort the issue list by text, list, date and boolean custom fields (#1139)....
r2255 assert_equal values.sort.reverse, values
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Ability to sort the issue list by text, int and float custom fields (#1139)....
r2256 def test_sort_by_float_custom_field_asc
q = Query.new
c = q.available_columns.find {|col| col.is_a?(QueryCustomFieldColumn) && col.custom_field.field_format == 'float' }
assert c
assert c.sortable
issues = Issue.find :all,
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650 :include => [ :assigned_to, :status, :tracker, :project, :priority ],
Jean-Philippe Lang
Ability to sort the issue list by text, int and float custom fields (#1139)....
r2256 :conditions => q.statement,
:order => "#{c.sortable} ASC"
values = issues.collect {|i| begin; Kernel.Float(i.custom_value_for(c.custom_field).to_s); rescue; nil; end}.compact
assert !values.empty?
assert_equal values.sort, values
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Rescue invalid query statement error with an error message....
r2990 def test_invalid_query_should_raise_query_statement_invalid_error
q = Query.new
assert_raise Query::StatementInvalid do
q.issues(:conditions => "foo = 1")
end
end
Jean-Philippe Lang
Fixed: pagination do not show total visible issue count (#8633)....
r6194
def test_issue_count
q = Query.new(:name => '_')
issue_count = q.issue_count
assert_equal q.issues.size, issue_count
end
def test_issue_count_with_archived_issues
p = Project.generate!( :status => Project::STATUS_ARCHIVED )
i = Issue.generate!( :project => p, :tracker => p.trackers.first )
assert !i.visible?
test_issue_count
end
Jean-Philippe Lang
Fixed: "None" category issue count is empty while grouping by category (#4308)....
r2998 def test_issue_count_by_association_group
q = Query.new(:name => '_', :group_by => 'assigned_to')
count_by_group = q.issue_count_by_group
assert_kind_of Hash, count_by_group
assert_equal %w(NilClass User), count_by_group.keys.collect {|k| k.class.name}.uniq.sort
assert_equal %w(Fixnum), count_by_group.values.collect {|k| k.class.name}.uniq
assert count_by_group.has_key?(User.find(3))
end
def test_issue_count_by_list_custom_field_group
q = Query.new(:name => '_', :group_by => 'cf_1')
count_by_group = q.issue_count_by_group
assert_kind_of Hash, count_by_group
assert_equal %w(NilClass String), count_by_group.keys.collect {|k| k.class.name}.uniq.sort
assert_equal %w(Fixnum), count_by_group.values.collect {|k| k.class.name}.uniq
assert count_by_group.has_key?('MySQL')
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Fixed: "None" category issue count is empty while grouping by category (#4308)....
r2998 def test_issue_count_by_date_custom_field_group
q = Query.new(:name => '_', :group_by => 'cf_8')
count_by_group = q.issue_count_by_group
assert_kind_of Hash, count_by_group
assert_equal %w(Date NilClass), count_by_group.keys.collect {|k| k.class.name}.uniq.sort
assert_equal %w(Fixnum), count_by_group.values.collect {|k| k.class.name}.uniq
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Adds previous/next links to issue (#2850)....
r8368 def test_issue_ids
q = Query.new(:name => '_')
order = "issues.subject, issues.id"
issues = q.issues(:order => order)
Jean-Philippe Lang
Makes .find_ids return integers....
r8370 assert_equal issues.map(&:id), q.issue_ids(:order => order)
Jean-Philippe Lang
Adds previous/next links to issue (#2850)....
r8368 end
Jean-Philippe Lang
Prevents NoMethodError on @available_filters.has_key? in query.rb (#1178)....
r1440 def test_label_for
q = Query.new
Jean-Philippe Lang
Do not add errors on attributes on fake attributes....
r8268 assert_equal 'Assignee', q.label_for('assigned_to_id')
Jean-Philippe Lang
Prevents NoMethodError on @available_filters.has_key? in query.rb (#1178)....
r1440 end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Queries can be marked as 'For all projects'. Such queries will be available on all projects and on the global issue list (#897, closes #671)....
r1296 def test_editable_by
admin = User.find(1)
manager = User.find(2)
developer = User.find(3)
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Queries can be marked as 'For all projects'. Such queries will be available on all projects and on the global issue list (#897, closes #671)....
r1296 # Public query on project 1
q = Query.find(1)
assert q.editable_by?(admin)
assert q.editable_by?(manager)
assert !q.editable_by?(developer)
# Private query on project 1
q = Query.find(2)
assert q.editable_by?(admin)
assert !q.editable_by?(manager)
assert q.editable_by?(developer)
# Private query for all projects
q = Query.find(3)
assert q.editable_by?(admin)
assert !q.editable_by?(manager)
assert q.editable_by?(developer)
# Public query for all projects
q = Query.find(4)
assert q.editable_by?(admin)
assert !q.editable_by?(manager)
assert !q.editable_by?(developer)
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Makes custom queries available through the REST API (#5737)....
r6066 def test_visible_scope
query_ids = Query.visible(User.anonymous).map(&:id)
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Makes custom queries available through the REST API (#5737)....
r6066 assert query_ids.include?(1), 'public query on public project was not visible'
assert query_ids.include?(4), 'public query for all projects was not visible'
assert !query_ids.include?(2), 'private query on public project was visible'
assert !query_ids.include?(3), 'private query for all projects was visible'
assert !query_ids.include?(7), 'public query on private project was visible'
end
Jean-Baptiste Barth
Fixed: assigned_to and author filters in cross project issues view should be based on user's project visibility. #5760...
r3802
context "#available_filters" do
Eric Davis
Added a "Member of Group" to the issues filter. #5869...
r3963 setup do
@query = Query.new(:name => "_")
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Baptiste Barth
Fixed: assigned_to and author filters in cross project issues view should be based on user's project visibility. #5760...
r3802 should "include users of visible projects in cross-project view" do
Eric Davis
Added a "Member of Group" to the issues filter. #5869...
r3963 users = @query.available_filters["assigned_to_id"]
Jean-Baptiste Barth
Fixed: assigned_to and author filters in cross project issues view should be based on user's project visibility. #5760...
r3802 assert_not_nil users
assert users[:values].map{|u|u[1]}.include?("3")
end
Eric Davis
Added a "Member of Group" to the issues filter. #5869...
r3963
Jean-Philippe Lang
Adds members of subprojects in assignee and author filters (#10126)....
r8627 should "include users of subprojects" do
user1 = User.generate_with_protected!
user2 = User.generate_with_protected!
project = Project.find(1)
Member.create!(:principal => user1, :project => project.children.visible.first, :role_ids => [1])
@query.project = project
users = @query.available_filters["assigned_to_id"]
assert_not_nil users
assert users[:values].map{|u|u[1]}.include?(user1.id.to_s)
assert !users[:values].map{|u|u[1]}.include?(user2.id.to_s)
end
Jean-Philippe Lang
Prevents n SQL queries (n = project count) on cross-project issues list....
r4436 should "include visible projects in cross-project view" do
projects = @query.available_filters["project_id"]
assert_not_nil projects
assert projects[:values].map{|u|u[1]}.include?("1")
end
Eric Davis
Added a "Member of Group" to the issues filter. #5869...
r3963 context "'member_of_group' filter" do
should "be present" do
assert @query.available_filters.keys.include?("member_of_group")
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Eric Davis
Added a "Member of Group" to the issues filter. #5869...
r3963 should "be an optional list" do
assert_equal :list_optional, @query.available_filters["member_of_group"][:type]
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Eric Davis
Added a "Member of Group" to the issues filter. #5869...
r3963 should "have a list of the groups as values" do
Group.destroy_all # No fixtures
group1 = Group.generate!.reload
group2 = Group.generate!.reload
expected_group_list = [
Eric Davis
Remember the selected "Member of Role" and "Member of Group" options. #6467...
r4146 [group1.name, group1.id.to_s],
[group2.name, group2.id.to_s]
Eric Davis
Added a "Member of Group" to the issues filter. #5869...
r3963 ]
Eric Davis
Fix failing test....
r3992 assert_equal expected_group_list.sort, @query.available_filters["member_of_group"][:values].sort
Eric Davis
Added a "Member of Group" to the issues filter. #5869...
r3963 end
end
Eric Davis
Added a "Member of Role" to the issues filters. #5869...
r3964
context "'assigned_to_role' filter" do
should "be present" do
assert @query.available_filters.keys.include?("assigned_to_role")
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Eric Davis
Added a "Member of Role" to the issues filters. #5869...
r3964 should "be an optional list" do
assert_equal :list_optional, @query.available_filters["assigned_to_role"][:type]
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Eric Davis
Added a "Member of Role" to the issues filters. #5869...
r3964 should "have a list of the Roles as values" do
Eric Davis
Remember the selected "Member of Role" and "Member of Group" options. #6467...
r4146 assert @query.available_filters["assigned_to_role"][:values].include?(['Manager','1'])
assert @query.available_filters["assigned_to_role"][:values].include?(['Developer','2'])
assert @query.available_filters["assigned_to_role"][:values].include?(['Reporter','3'])
Eric Davis
Added a "Member of Role" to the issues filters. #5869...
r3964 end
should "not include the built in Roles as values" do
Eric Davis
Remember the selected "Member of Role" and "Member of Group" options. #6467...
r4146 assert ! @query.available_filters["assigned_to_role"][:values].include?(['Non member','4'])
assert ! @query.available_filters["assigned_to_role"][:values].include?(['Anonymous','5'])
Eric Davis
Added a "Member of Role" to the issues filters. #5869...
r3964 end
end
Jean-Baptiste Barth
Fixed: assigned_to and author filters in cross project issues view should be based on user's project visibility. #5760...
r3802 end
Eric Davis
Added a "Member of Group" to the issues filter. #5869...
r3963
context "#statement" do
context "with 'member_of_group' filter" do
setup do
Group.destroy_all # No fixtures
@user_in_group = User.generate!
@second_user_in_group = User.generate!
@user_in_group2 = User.generate!
@user_not_in_group = User.generate!
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Eric Davis
Added a "Member of Group" to the issues filter. #5869...
r3963 @group = Group.generate!.reload
@group.users << @user_in_group
@group.users << @second_user_in_group
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Eric Davis
Added a "Member of Group" to the issues filter. #5869...
r3963 @group2 = Group.generate!.reload
@group2.users << @user_in_group2
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Eric Davis
Added a "Member of Group" to the issues filter. #5869...
r3963 end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Eric Davis
Added a "Member of Group" to the issues filter. #5869...
r3963 should "search assigned to for users in the group" do
@query = Query.new(:name => '_')
@query.add_filter('member_of_group', '=', [@group.id.to_s])
assert_query_statement_includes @query, "#{Issue.table_name}.assigned_to_id IN ('#{@user_in_group.id}','#{@second_user_in_group.id}')"
assert_find_issues_with_query_is_successful @query
end
should "search not assigned to any group member (none)" do
@query = Query.new(:name => '_')
@query.add_filter('member_of_group', '!*', [''])
# Users not in a group
assert_query_statement_includes @query, "#{Issue.table_name}.assigned_to_id IS NULL OR #{Issue.table_name}.assigned_to_id NOT IN ('#{@user_in_group.id}','#{@second_user_in_group.id}','#{@user_in_group2.id}')"
assert_find_issues_with_query_is_successful @query
end
should "search assigned to any group member (all)" do
@query = Query.new(:name => '_')
@query.add_filter('member_of_group', '*', [''])
# Only users in a group
assert_query_statement_includes @query, "#{Issue.table_name}.assigned_to_id IN ('#{@user_in_group.id}','#{@second_user_in_group.id}','#{@user_in_group2.id}')"
assert_find_issues_with_query_is_successful @query
Jean-Philippe Lang
Fixed: SQL error when filtering issues with an empty group or role (#7656)....
r4768 end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Fixed: SQL error when filtering issues with an empty group or role (#7656)....
r4768 should "return an empty set with = empty group" do
@empty_group = Group.generate!
@query = Query.new(:name => '_')
@query.add_filter('member_of_group', '=', [@empty_group.id.to_s])
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Fixed: SQL error when filtering issues with an empty group or role (#7656)....
r4768 assert_equal [], find_issues_with_query(@query)
end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Fixed: SQL error when filtering issues with an empty group or role (#7656)....
r4768 should "return issues with ! empty group" do
@empty_group = Group.generate!
@query = Query.new(:name => '_')
@query.add_filter('member_of_group', '!', [@empty_group.id.to_s])
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Fixed: SQL error when filtering issues with an empty group or role (#7656)....
r4768 assert_find_issues_with_query_is_successful @query
Eric Davis
Added a "Member of Group" to the issues filter. #5869...
r3963 end
end
Eric Davis
Added a "Member of Role" to the issues filters. #5869...
r3964
context "with 'assigned_to_role' filter" do
setup do
Jean-Philippe Lang
Fixed: Issue filter by assigned_to_role is not project specific (#9540)....
r7727 @manager_role = Role.find_by_name('Manager')
@developer_role = Role.find_by_name('Developer')
Eric Davis
Added a "Member of Role" to the issues filters. #5869...
r3964
@project = Project.generate!
@manager = User.generate!
@developer = User.generate!
@boss = User.generate!
Jean-Philippe Lang
Fixed: Issue filter by assigned_to_role is not project specific (#9540)....
r7727 @guest = User.generate!
Eric Davis
Added a "Member of Role" to the issues filters. #5869...
r3964 User.add_to_project(@manager, @project, @manager_role)
User.add_to_project(@developer, @project, @developer_role)
User.add_to_project(@boss, @project, [@manager_role, @developer_role])
Jean-Philippe Lang
Fixed: Issue filter by assigned_to_role is not project specific (#9540)....
r7727
@issue1 = Issue.generate_for_project!(@project, :assigned_to_id => @manager.id)
@issue2 = Issue.generate_for_project!(@project, :assigned_to_id => @developer.id)
@issue3 = Issue.generate_for_project!(@project, :assigned_to_id => @boss.id)
@issue4 = Issue.generate_for_project!(@project, :assigned_to_id => @guest.id)
@issue5 = Issue.generate_for_project!(@project)
Eric Davis
Added a "Member of Role" to the issues filters. #5869...
r3964 end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Eric Davis
Added a "Member of Role" to the issues filters. #5869...
r3964 should "search assigned to for users with the Role" do
Jean-Philippe Lang
Fixed: Issue filter by assigned_to_role is not project specific (#9540)....
r7727 @query = Query.new(:name => '_', :project => @project)
Eric Davis
Added a "Member of Role" to the issues filters. #5869...
r3964 @query.add_filter('assigned_to_role', '=', [@manager_role.id.to_s])
Jean-Philippe Lang
Fixed: Issue filter by assigned_to_role is not project specific (#9540)....
r7727 assert_query_result [@issue1, @issue3], @query
end
should "search assigned to for users with the Role on the issue project" do
other_project = Project.generate!
User.add_to_project(@developer, other_project, @manager_role)
@query = Query.new(:name => '_', :project => @project)
@query.add_filter('assigned_to_role', '=', [@manager_role.id.to_s])
assert_query_result [@issue1, @issue3], @query
end
should "return an empty set with empty role" do
@empty_role = Role.generate!
@query = Query.new(:name => '_', :project => @project)
@query.add_filter('assigned_to_role', '=', [@empty_role.id.to_s])
assert_query_result [], @query
end
should "search assigned to for users without the Role" do
@query = Query.new(:name => '_', :project => @project)
@query.add_filter('assigned_to_role', '!', [@manager_role.id.to_s])
assert_query_result [@issue2, @issue4, @issue5], @query
Eric Davis
Added a "Member of Role" to the issues filters. #5869...
r3964 end
should "search assigned to for users not assigned to any Role (none)" do
Jean-Philippe Lang
Fixed: Issue filter by assigned_to_role is not project specific (#9540)....
r7727 @query = Query.new(:name => '_', :project => @project)
Eric Davis
Added a "Member of Role" to the issues filters. #5869...
r3964 @query.add_filter('assigned_to_role', '!*', [''])
Jean-Philippe Lang
Fixed: Issue filter by assigned_to_role is not project specific (#9540)....
r7727 assert_query_result [@issue4, @issue5], @query
Eric Davis
Added a "Member of Role" to the issues filters. #5869...
r3964 end
should "search assigned to for users assigned to any Role (all)" do
Jean-Philippe Lang
Fixed: Issue filter by assigned_to_role is not project specific (#9540)....
r7727 @query = Query.new(:name => '_', :project => @project)
Eric Davis
Added a "Member of Role" to the issues filters. #5869...
r3964 @query.add_filter('assigned_to_role', '*', [''])
Jean-Philippe Lang
Fixed: Issue filter by assigned_to_role is not project specific (#9540)....
r7727 assert_query_result [@issue1, @issue2, @issue3], @query
Jean-Philippe Lang
Fixed: SQL error when filtering issues with an empty group or role (#7656)....
r4768 end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Fixed: SQL error when filtering issues with an empty group or role (#7656)....
r4768 should "return issues with ! empty role" do
@empty_role = Role.generate!
Jean-Philippe Lang
Fixed: Issue filter by assigned_to_role is not project specific (#9540)....
r7727 @query = Query.new(:name => '_', :project => @project)
@query.add_filter('assigned_to_role', '!', [@empty_role.id.to_s])
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Fixed: Issue filter by assigned_to_role is not project specific (#9540)....
r7727 assert_query_result [@issue1, @issue2, @issue3, @issue4, @issue5], @query
Jean-Philippe Lang
Fixed: SQL error when filtering issues with an empty group or role (#7656)....
r4768 end
Eric Davis
Added a "Member of Role" to the issues filters. #5869...
r3964 end
Eric Davis
Added a "Member of Group" to the issues filter. #5869...
r3963 end
Toshi MARUYAMA
remove trailing white-spaces from test/unit/query_test.rb....
r6650
Jean-Philippe Lang
Fixed: queries with multiple custom fields return no result....
r662 end