@@ -170,6 +170,10 class Query < ActiveRecord::Base | |||||
170 |
|
170 | |||
171 | def validate |
|
171 | def validate | |
172 | filters.each_key do |field| |
|
172 | filters.each_key do |field| | |
|
173 | if type_for(field) == :integer && values_for(field) | |||
|
174 | errors.add label_for(field), :invalid if values_for(field).detect {|v| v.present? && !v.match(/^\d+(\.\d+)?$/) } | |||
|
175 | end | |||
|
176 | ||||
173 | errors.add label_for(field), :blank unless |
|
177 | errors.add label_for(field), :blank unless | |
174 | # filter requires one or more values |
|
178 | # filter requires one or more values | |
175 | (values_for(field) and !values_for(field).first.blank?) or |
|
179 | (values_for(field) and !values_for(field).first.blank?) or | |
@@ -278,11 +282,7 class Query < ActiveRecord::Base | |||||
278 | # allowed_values = values & ([""] + (filter_options[:values] || []).collect {|val| val[1]}) |
|
282 | # allowed_values = values & ([""] + (filter_options[:values] || []).collect {|val| val[1]}) | |
279 | # filters[field] = {:operator => operator, :values => allowed_values } if (allowed_values.first and !allowed_values.first.empty?) or ["o", "c", "!*", "*", "t"].include? operator |
|
283 | # filters[field] = {:operator => operator, :values => allowed_values } if (allowed_values.first and !allowed_values.first.empty?) or ["o", "c", "!*", "*", "t"].include? operator | |
280 | #end |
|
284 | #end | |
281 | values ||= [''] |
|
285 | filters[field] = {:operator => operator, :values => (values || [''])} | |
282 | if filter_options[:type] == :integer |
|
|||
283 | values = values.select {|v| v.blank? || v.match(/^\d+(\.\d+)?$/) } |
|
|||
284 | end |
|
|||
285 | filters[field] = {:operator => operator, :values => values } |
|
|||
286 | end |
|
286 | end | |
287 | end |
|
287 | end | |
288 |
|
288 |
@@ -106,7 +106,6 class QueryTest < ActiveSupport::TestCase | |||||
106 | query.add_filter('estimated_hours', '=', ['a']) |
|
106 | query.add_filter('estimated_hours', '=', ['a']) | |
107 |
|
107 | |||
108 | assert query.has_filter?('estimated_hours') |
|
108 | assert query.has_filter?('estimated_hours') | |
109 | assert query.values_for('estimated_hours').empty? |
|
|||
110 | assert !query.valid? |
|
109 | assert !query.valid? | |
111 | end |
|
110 | end | |
112 |
|
111 |
General Comments 0
You need to be logged in to leave comments.
Login now