aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSean Griffin <sean@seantheprogrammer.com>2016-11-15 13:25:51 -0500
committerGitHub <noreply@github.com>2016-11-15 13:25:51 -0500
commit6e692e6e5bb90fbaf1524429139daa9bd1c4f990 (patch)
treef139b8e8dce590499be4d45fa0ccac22f37d93bd
parent3a558aa2bc8ce3834ee79ff3346bcf5d7debbbd0 (diff)
parent7c1b14f04158102f68610128ae230941e85263a3 (diff)
downloadrails-6e692e6e5bb90fbaf1524429139daa9bd1c4f990.tar.gz
rails-6e692e6e5bb90fbaf1524429139daa9bd1c4f990.tar.bz2
rails-6e692e6e5bb90fbaf1524429139daa9bd1c4f990.zip
Merge pull request #27054 from kamipo/null_relation_calculate
Refactor `NullRelation#calculate`
-rw-r--r--activerecord/lib/active_record/null_relation.rb9
1 files changed, 4 insertions, 5 deletions
diff --git a/activerecord/lib/active_record/null_relation.rb b/activerecord/lib/active_record/null_relation.rb
index 254550c378..2bb7ed6d5e 100644
--- a/activerecord/lib/active_record/null_relation.rb
+++ b/activerecord/lib/active_record/null_relation.rb
@@ -41,12 +41,11 @@ module ActiveRecord
end
def calculate(operation, _column_name)
- if [:count, :sum].include? operation
+ case operation
+ when :count, :sum
group_values.any? ? Hash.new : 0
- elsif [:average, :minimum, :maximum].include?(operation) && group_values.any?
- Hash.new
- else
- nil
+ when :average, :minimum, :maximum
+ group_values.any? ? Hash.new : nil
end
end