aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSven Bohm <bohms@msu.edu>2011-11-21 13:14:16 -0500
committerSven Bohm <bohms@msu.edu>2011-11-21 13:14:16 -0500
commit06c23c4c7ff842f7c6237f3ac43fc9d19509a947 (patch)
treeeafdf9417c6eef3a63b82558fbaec2d715e4cc0d
parent5d704fa152c2f2846b66973cf5572e3120a72792 (diff)
downloadrails-06c23c4c7ff842f7c6237f3ac43fc9d19509a947.tar.gz
rails-06c23c4c7ff842f7c6237f3ac43fc9d19509a947.tar.bz2
rails-06c23c4c7ff842f7c6237f3ac43fc9d19509a947.zip
postgresql adapter handles quoting of not a number (NaN) and Infinity
-rw-r--r--activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb9
-rw-r--r--activerecord/test/cases/adapters/postgresql/quoting_test.rb12
2 files changed, 19 insertions, 2 deletions
diff --git a/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb b/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb
index 2f01fbb829..0b102d787a 100644
--- a/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb
+++ b/activerecord/lib/active_record/connection_adapters/postgresql_adapter.rb
@@ -415,8 +415,13 @@ module ActiveRecord
case value
when Float
- return super unless value.infinite? && column.type == :datetime
- "'#{value.to_s.downcase}'"
+ if value.infinite? && column.type == :datetime
+ "'#{value.to_s.downcase}'"
+ elsif value.infinite? || value.nan?
+ "'#{value.to_s}'"
+ else
+ super
+ end
when Numeric
return super unless column.sql_type == 'money'
# Not truly string input, so doesn't require (or allow) escape string syntax.
diff --git a/activerecord/test/cases/adapters/postgresql/quoting_test.rb b/activerecord/test/cases/adapters/postgresql/quoting_test.rb
index 172055f15c..f8a605b67c 100644
--- a/activerecord/test/cases/adapters/postgresql/quoting_test.rb
+++ b/activerecord/test/cases/adapters/postgresql/quoting_test.rb
@@ -19,6 +19,18 @@ module ActiveRecord
assert_equal 'f', @conn.type_cast(false, nil)
assert_equal 'f', @conn.type_cast(false, c)
end
+
+ def test_quote_float_nan
+ nan = 0.0/0
+ c = Column.new(nil, 1, 'float')
+ assert_equal "'NaN'", @conn.quote(nan, c)
+ end
+
+ def test_quote_float_infinity
+ infinity = 1.0/0
+ c = Column.new(nil, 1, 'float')
+ assert_equal "'Infinity'", @conn.quote(infinity, c)
+ end
end
end
end