diff options
author | Jon Leighton <j@jonathanleighton.com> | 2011-07-06 00:49:05 -0700 |
---|---|---|
committer | Jon Leighton <j@jonathanleighton.com> | 2011-07-06 00:49:05 -0700 |
commit | 2c72830cd97d3746dc02db71441e888678f10a86 (patch) | |
tree | c8e51594f2f5698cc01ddd929054f1e3c5a1f32b /activerecord | |
parent | a990b1223b88e5424addb5c5c3b1836423a77515 (diff) | |
parent | e7bec4e435d05eb517f515a4661186ce8d088238 (diff) | |
download | rails-2c72830cd97d3746dc02db71441e888678f10a86.tar.gz rails-2c72830cd97d3746dc02db71441e888678f10a86.tar.bz2 rails-2c72830cd97d3746dc02db71441e888678f10a86.zip |
Merge pull request #1979 from bogdan/association_sum_array_compatibility
Fixed AR::Relation#sum compatibility with Array#sum
Diffstat (limited to 'activerecord')
-rw-r--r-- | activerecord/lib/active_record/relation/calculations.rb | 8 | ||||
-rw-r--r-- | activerecord/test/cases/calculations_test.rb | 4 |
2 files changed, 10 insertions, 2 deletions
diff --git a/activerecord/lib/active_record/relation/calculations.rb b/activerecord/lib/active_record/relation/calculations.rb index 9c5f603c01..0ac821b2d7 100644 --- a/activerecord/lib/active_record/relation/calculations.rb +++ b/activerecord/lib/active_record/relation/calculations.rb @@ -89,8 +89,12 @@ module ActiveRecord # +calculate+ for examples with options. # # Person.sum('age') # => 4562 - def sum(column_name, options = {}) - calculate(:sum, column_name, options) + def sum(*args) + if block_given? + self.to_a.sum(*args) {|*block_args| yield(*block_args)} + else + calculate(:sum, *args) + end end # This calculates aggregate values in the given column. Methods for count, sum, average, diff --git a/activerecord/test/cases/calculations_test.rb b/activerecord/test/cases/calculations_test.rb index 56f6d795b6..224b3f3d1f 100644 --- a/activerecord/test/cases/calculations_test.rb +++ b/activerecord/test/cases/calculations_test.rb @@ -397,6 +397,10 @@ class CalculationsTest < ActiveRecord::TestCase Account.sum(:credit_limit, :from => 'accounts', :conditions => "credit_limit > 50") end + def test_sum_array_compatibility + assert_equal Account.sum(:credit_limit), Account.sum(&:credit_limit) + end + def test_average_with_from_option assert_equal Account.average(:credit_limit), Account.average(:credit_limit, :from => 'accounts') assert_equal Account.average(:credit_limit, :conditions => "credit_limit > 50"), |