Prevent unexpected nil in custom value validation.
git-svn-id: http://redmine.rubyforge.org/svn/trunk@1101 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
parent
7a1e928b8d
commit
e13f49d919
|
@ -27,19 +27,24 @@ class CustomValue < ActiveRecord::Base
|
||||||
|
|
||||||
protected
|
protected
|
||||||
def validate
|
def validate
|
||||||
errors.add(:value, :activerecord_error_blank) and return if custom_field.is_required? and value.blank?
|
if value.blank?
|
||||||
errors.add(:value, :activerecord_error_invalid) unless custom_field.regexp.blank? or value =~ Regexp.new(custom_field.regexp)
|
errors.add(:value, :activerecord_error_blank) if custom_field.is_required? and value.blank?
|
||||||
errors.add(:value, :activerecord_error_too_short) if custom_field.min_length > 0 and value.length < custom_field.min_length and value.length > 0
|
else
|
||||||
errors.add(:value, :activerecord_error_too_long) if custom_field.max_length > 0 and value.length > custom_field.max_length
|
errors.add(:value, :activerecord_error_invalid) unless custom_field.regexp.blank? or value =~ Regexp.new(custom_field.regexp)
|
||||||
case custom_field.field_format
|
errors.add(:value, :activerecord_error_too_short) if custom_field.min_length > 0 and value.length < custom_field.min_length
|
||||||
when 'int'
|
errors.add(:value, :activerecord_error_too_long) if custom_field.max_length > 0 and value.length > custom_field.max_length
|
||||||
errors.add(:value, :activerecord_error_not_a_number) unless value.blank? || value =~ /^[+-]?\d+$/
|
|
||||||
when 'float'
|
# Format specific validations
|
||||||
begin; !value.blank? && Kernel.Float(value); rescue; errors.add(:value, :activerecord_error_invalid) end
|
case custom_field.field_format
|
||||||
when 'date'
|
when 'int'
|
||||||
errors.add(:value, :activerecord_error_not_a_date) unless value =~ /^\d{4}-\d{2}-\d{2}$/ or value.blank?
|
errors.add(:value, :activerecord_error_not_a_number) unless value =~ /^[+-]?\d+$/
|
||||||
when 'list'
|
when 'float'
|
||||||
errors.add(:value, :activerecord_error_inclusion) unless custom_field.possible_values.include?(value) or value.blank?
|
begin; Kernel.Float(value); rescue; errors.add(:value, :activerecord_error_invalid) end
|
||||||
|
when 'date'
|
||||||
|
errors.add(:value, :activerecord_error_not_a_date) unless value =~ /^\d{4}-\d{2}-\d{2}$/
|
||||||
|
when 'list'
|
||||||
|
errors.add(:value, :activerecord_error_inclusion) unless custom_field.possible_values.include?(value)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -20,7 +20,79 @@ require File.dirname(__FILE__) + '/../test_helper'
|
||||||
class CustomValueTest < Test::Unit::TestCase
|
class CustomValueTest < Test::Unit::TestCase
|
||||||
fixtures :custom_fields
|
fixtures :custom_fields
|
||||||
|
|
||||||
def test_float_field
|
def test_string_field_validation_with_blank_value
|
||||||
|
f = CustomField.new(:field_format => 'string')
|
||||||
|
v = CustomValue.new(:custom_field => f)
|
||||||
|
|
||||||
|
v.value = nil
|
||||||
|
assert v.valid?
|
||||||
|
v.value = ''
|
||||||
|
assert v.valid?
|
||||||
|
|
||||||
|
f.is_required = true
|
||||||
|
v.value = nil
|
||||||
|
assert !v.valid?
|
||||||
|
v.value = ''
|
||||||
|
assert !v.valid?
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_string_field_validation_with_min_and_max_lengths
|
||||||
|
f = CustomField.new(:field_format => 'string', :min_length => 2, :max_length => 5)
|
||||||
|
v = CustomValue.new(:custom_field => f, :value => '')
|
||||||
|
assert v.valid?
|
||||||
|
v.value = 'a'
|
||||||
|
assert !v.valid?
|
||||||
|
v.value = 'a' * 2
|
||||||
|
assert v.valid?
|
||||||
|
v.value = 'a' * 6
|
||||||
|
assert !v.valid?
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_string_field_validation_with_regexp
|
||||||
|
f = CustomField.new(:field_format => 'string', :regexp => '^[A-Z0-9]*$')
|
||||||
|
v = CustomValue.new(:custom_field => f, :value => '')
|
||||||
|
assert v.valid?
|
||||||
|
v.value = 'abc'
|
||||||
|
assert !v.valid?
|
||||||
|
v.value = 'ABC'
|
||||||
|
assert v.valid?
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_date_field_validation
|
||||||
|
f = CustomField.new(:field_format => 'date')
|
||||||
|
v = CustomValue.new(:custom_field => f, :value => '')
|
||||||
|
assert v.valid?
|
||||||
|
v.value = 'abc'
|
||||||
|
assert !v.valid?
|
||||||
|
v.value = '1975-07-14'
|
||||||
|
assert v.valid?
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_list_field_validation
|
||||||
|
f = CustomField.new(:field_format => 'list', :possible_values => ['value1', 'value2'])
|
||||||
|
v = CustomValue.new(:custom_field => f, :value => '')
|
||||||
|
assert v.valid?
|
||||||
|
v.value = 'abc'
|
||||||
|
assert !v.valid?
|
||||||
|
v.value = 'value2'
|
||||||
|
assert v.valid?
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_int_field_validation
|
||||||
|
f = CustomField.new(:field_format => 'int')
|
||||||
|
v = CustomValue.new(:custom_field => f, :value => '')
|
||||||
|
assert v.valid?
|
||||||
|
v.value = 'abc'
|
||||||
|
assert !v.valid?
|
||||||
|
v.value = '123'
|
||||||
|
assert v.valid?
|
||||||
|
v.value = '+123'
|
||||||
|
assert v.valid?
|
||||||
|
v.value = '-123'
|
||||||
|
assert v.valid?
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_float_field_validation
|
||||||
v = CustomValue.new(:customized => User.find(:first), :custom_field => UserCustomField.find_by_name('Money'))
|
v = CustomValue.new(:customized => User.find(:first), :custom_field => UserCustomField.find_by_name('Money'))
|
||||||
v.value = '11.2'
|
v.value = '11.2'
|
||||||
assert v.save
|
assert v.save
|
||||||
|
|
Loading…
Reference in New Issue