mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
0a57f34601
This is both faster and more correct, added tests to make sure this is not reverted again.
115 lines
4.2 KiB
Ruby
115 lines
4.2 KiB
Ruby
require "cases/helper"
|
|
require 'models/company'
|
|
|
|
module ActiveRecord
|
|
module ConnectionAdapters
|
|
class ColumnTest < ActiveRecord::TestCase
|
|
def test_type_cast_boolean
|
|
column = Column.new("field", nil, "boolean")
|
|
assert column.type_cast('').nil?
|
|
assert column.type_cast(nil).nil?
|
|
|
|
assert column.type_cast(true)
|
|
assert column.type_cast(1)
|
|
assert column.type_cast('1')
|
|
assert column.type_cast('t')
|
|
assert column.type_cast('T')
|
|
assert column.type_cast('true')
|
|
assert column.type_cast('TRUE')
|
|
assert column.type_cast('on')
|
|
assert column.type_cast('ON')
|
|
|
|
# explicitly check for false vs nil
|
|
assert_equal false, column.type_cast(false)
|
|
assert_equal false, column.type_cast(0)
|
|
assert_equal false, column.type_cast('0')
|
|
assert_equal false, column.type_cast('f')
|
|
assert_equal false, column.type_cast('F')
|
|
assert_equal false, column.type_cast('false')
|
|
assert_equal false, column.type_cast('FALSE')
|
|
assert_equal false, column.type_cast('off')
|
|
assert_equal false, column.type_cast('OFF')
|
|
assert_equal false, column.type_cast(' ')
|
|
assert_equal false, column.type_cast("\u3000\r\n")
|
|
assert_equal false, column.type_cast("\u0000")
|
|
assert_equal false, column.type_cast('SOMETHING RANDOM')
|
|
end
|
|
|
|
def test_type_cast_integer
|
|
column = Column.new("field", nil, "integer")
|
|
assert_equal 1, column.type_cast(1)
|
|
assert_equal 1, column.type_cast('1')
|
|
assert_equal 1, column.type_cast('1ignore')
|
|
assert_equal 0, column.type_cast('bad1')
|
|
assert_equal 0, column.type_cast('bad')
|
|
assert_equal 1, column.type_cast(1.7)
|
|
assert_equal 0, column.type_cast(false)
|
|
assert_equal 1, column.type_cast(true)
|
|
assert_nil column.type_cast(nil)
|
|
end
|
|
|
|
def test_type_cast_non_integer_to_integer
|
|
column = Column.new("field", nil, "integer")
|
|
assert_nil column.type_cast([1,2])
|
|
assert_nil column.type_cast({1 => 2})
|
|
assert_nil column.type_cast((1..2))
|
|
end
|
|
|
|
def test_type_cast_activerecord_to_integer
|
|
column = Column.new("field", nil, "integer")
|
|
firm = Firm.create(:name => 'Apple')
|
|
assert_nil column.type_cast(firm)
|
|
end
|
|
|
|
def test_type_cast_object_without_to_i_to_integer
|
|
column = Column.new("field", nil, "integer")
|
|
assert_nil column.type_cast(Object.new)
|
|
end
|
|
|
|
def test_type_cast_nan_and_infinity_to_integer
|
|
column = Column.new("field", nil, "integer")
|
|
assert_nil column.type_cast(Float::NAN)
|
|
assert_nil column.type_cast(1.0/0.0)
|
|
end
|
|
|
|
def test_type_cast_time
|
|
column = Column.new("field", nil, "time")
|
|
assert_equal nil, column.type_cast(nil)
|
|
assert_equal nil, column.type_cast('')
|
|
assert_equal nil, column.type_cast('ABC')
|
|
|
|
time_string = Time.now.utc.strftime("%T")
|
|
assert_equal time_string, column.type_cast(time_string).strftime("%T")
|
|
end
|
|
|
|
def test_type_cast_datetime_and_timestamp
|
|
[Column.new("field", nil, "datetime"), Column.new("field", nil, "timestamp")].each do |column|
|
|
assert_equal nil, column.type_cast(nil)
|
|
assert_equal nil, column.type_cast('')
|
|
assert_equal nil, column.type_cast(' ')
|
|
assert_equal nil, column.type_cast('ABC')
|
|
|
|
datetime_string = Time.now.utc.strftime("%FT%T")
|
|
assert_equal datetime_string, column.type_cast(datetime_string).strftime("%FT%T")
|
|
end
|
|
end
|
|
|
|
def test_type_cast_date
|
|
column = Column.new("field", nil, "date")
|
|
assert_equal nil, column.type_cast(nil)
|
|
assert_equal nil, column.type_cast('')
|
|
assert_equal nil, column.type_cast(' ')
|
|
assert_equal nil, column.type_cast('ABC')
|
|
|
|
date_string = Time.now.utc.strftime("%F")
|
|
assert_equal date_string, column.type_cast(date_string).strftime("%F")
|
|
end
|
|
|
|
def test_type_cast_duration_to_integer
|
|
column = Column.new("field", nil, "integer")
|
|
assert_equal 1800, column.type_cast(30.minutes)
|
|
assert_equal 7200, column.type_cast(2.hours)
|
|
end
|
|
end
|
|
end
|
|
end
|