##// END OF EJS Templates
Merged r11850 from trunk (#14051)....
Jean-Philippe Lang -
r11642:cc23ab9652b6
parent child
Show More
@@ -577,8 +577,11 class Query < ActiveRecord::Base
577 customized_class = queried_class.reflect_on_association(assoc.to_sym).klass.base_class rescue nil
577 customized_class = queried_class.reflect_on_association(assoc.to_sym).klass.base_class rescue nil
578 raise "Unknown #{queried_class.name} association #{assoc}" unless customized_class
578 raise "Unknown #{queried_class.name} association #{assoc}" unless customized_class
579 end
579 end
580 "#{queried_table_name}.#{customized_key} #{not_in} IN (SELECT #{customized_class.table_name}.id FROM #{customized_class.table_name} LEFT OUTER JOIN #{db_table} ON #{db_table}.customized_type='#{customized_class}' AND #{db_table}.customized_id=#{customized_class.table_name}.id AND #{db_table}.custom_field_id=#{custom_field_id} WHERE " +
580 where = sql_for_field(field, operator, value, db_table, db_field, true)
581 sql_for_field(field, operator, value, db_table, db_field, true) + ')'
581 if operator =~ /[<>]/
582 where = "(#{where}) AND #{db_table}.#{db_field} <> ''"
583 end
584 "#{queried_table_name}.#{customized_key} #{not_in} IN (SELECT #{customized_class.table_name}.id FROM #{customized_class.table_name} LEFT OUTER JOIN #{db_table} ON #{db_table}.customized_type='#{customized_class}' AND #{db_table}.customized_id=#{customized_class.table_name}.id AND #{db_table}.custom_field_id=#{custom_field_id} WHERE #{where})"
582 end
585 end
583
586
584 # Helper method to generate the WHERE sql for a +field+, +operator+ and a +value+
587 # Helper method to generate the WHERE sql for a +field+, +operator+ and a +value+
@@ -337,6 +337,20 class QueryTest < ActiveSupport::TestCase
337 find_issues_with_query(query)
337 find_issues_with_query(query)
338 end
338 end
339
339
340 def test_operator_lesser_than_on_date_custom_field
341 f = IssueCustomField.create!(:name => 'filter', :field_format => 'date', :is_filter => true, :is_for_all => true)
342 CustomValue.create!(:custom_field => f, :customized => Issue.find(1), :value => '2013-04-11')
343 CustomValue.create!(:custom_field => f, :customized => Issue.find(2), :value => '2013-05-14')
344 CustomValue.create!(:custom_field => f, :customized => Issue.find(3), :value => '')
345
346 query = IssueQuery.new(:project => Project.find(1), :name => '_')
347 query.add_filter("cf_#{f.id}", '<=', ['2013-05-01'])
348 issue_ids = find_issues_with_query(query).map(&:id)
349 assert_include 1, issue_ids
350 assert_not_include 2, issue_ids
351 assert_not_include 3, issue_ids
352 end
353
340 def test_operator_between
354 def test_operator_between
341 query = IssueQuery.new(:project => Project.find(1), :name => '_')
355 query = IssueQuery.new(:project => Project.find(1), :name => '_')
342 query.add_filter('done_ratio', '><', ['30', '40'])
356 query.add_filter('done_ratio', '><', ['30', '40'])
General Comments 0
You need to be logged in to leave comments. Login now