aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test
diff options
context:
space:
mode:
authorAaron Patterson <aaron.patterson@gmail.com>2012-05-01 10:41:45 -0700
committerAaron Patterson <aaron.patterson@gmail.com>2012-05-01 10:41:45 -0700
commitb2a24a15785e94078bae87946ffa43bc59bccfec (patch)
treedc0ba06f14226a8611164697705218dfeb9757b0 /activerecord/test
parent5722915fa7e172a5632b76023539f024e5711049 (diff)
parent13823a4cf35e99582c9b634a94c362d565b7841c (diff)
downloadrails-b2a24a15785e94078bae87946ffa43bc59bccfec.tar.gz
rails-b2a24a15785e94078bae87946ffa43bc59bccfec.tar.bz2
rails-b2a24a15785e94078bae87946ffa43bc59bccfec.zip
Merge pull request #6092 from jsanders/issue_4001_error_typecasting_non_integer_castable
Don't type cast values that don't respond to to_i to 1
Diffstat (limited to 'activerecord/test')
-rw-r--r--activerecord/test/cases/column_test.rb24
1 files changed, 24 insertions, 0 deletions
diff --git a/activerecord/test/cases/column_test.rb b/activerecord/test/cases/column_test.rb
index ccc57cb876..4fcf8a33a4 100644
--- a/activerecord/test/cases/column_test.rb
+++ b/activerecord/test/cases/column_test.rb
@@ -24,6 +24,30 @@ module ActiveRecord
assert !column.type_cast('off')
assert !column.type_cast('OFF')
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_nil column.type_cast(nil)
+ end
+
+ def test_type_cast_non_integer_to_integer
+ column = Column.new("field", nil, "integer")
+ assert_raises(NoMethodError) do
+ column.type_cast([])
+ end
+ assert_raises(NoMethodError) do
+ column.type_cast(true)
+ end
+ assert_raises(NoMethodError) do
+ column.type_cast(false)
+ end
+ end
end
end
end