aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord
diff options
context:
space:
mode:
authorKen Collins <ken@metaskills.net>2011-02-03 15:07:03 -0500
committerSantiago Pastorino <santiago@wyeworks.com>2011-02-03 20:00:51 -0200
commit95d5d9b6c48c08f1fba0c77ecbc97b62b2603824 (patch)
treedac3893d280838cf33ba9ac22e687501490fe803 /activerecord
parent092a4e296de5b69f06edac2fe0993e2a30e33555 (diff)
downloadrails-95d5d9b6c48c08f1fba0c77ecbc97b62b2603824.tar.gz
rails-95d5d9b6c48c08f1fba0c77ecbc97b62b2603824.tar.bz2
rails-95d5d9b6c48c08f1fba0c77ecbc97b62b2603824.zip
The type_cast_calculated_value method will trust DB types before casting to a BigDecimal.
[#6365 state:committed] Signed-off-by: Santiago Pastorino <santiago@wyeworks.com>
Diffstat (limited to 'activerecord')
-rw-r--r--activerecord/lib/active_record/relation/calculations.rb2
-rw-r--r--activerecord/test/cases/calculations_test.rb6
2 files changed, 7 insertions, 1 deletions
diff --git a/activerecord/lib/active_record/relation/calculations.rb b/activerecord/lib/active_record/relation/calculations.rb
index b75a65e3ca..abc4c54109 100644
--- a/activerecord/lib/active_record/relation/calculations.rb
+++ b/activerecord/lib/active_record/relation/calculations.rb
@@ -285,7 +285,7 @@ module ActiveRecord
case operation
when 'count' then value.to_i
when 'sum' then type_cast_using_column(value || '0', column)
- when 'average' then value.try(:to_d)
+ when 'average' then value.respond_to?(:to_d) ? value.to_d : value
else type_cast_using_column(value, column)
end
end
diff --git a/activerecord/test/cases/calculations_test.rb b/activerecord/test/cases/calculations_test.rb
index 644c9cb528..3121f1615d 100644
--- a/activerecord/test/cases/calculations_test.rb
+++ b/activerecord/test/cases/calculations_test.rb
@@ -28,6 +28,12 @@ class CalculationsTest < ActiveRecord::TestCase
assert_equal 3.5, value
end
+ def test_should_return_integer_average_if_db_returns_such
+ Account.connection.stubs :select_value => 3
+ value = Account.average(:id)
+ assert_equal 3, value
+ end
+
def test_should_return_nil_as_average
assert_nil NumericData.average(:bank_balance)
end