diff options
author | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2013-04-23 07:44:44 -0700 |
---|---|---|
committer | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2013-04-23 07:44:44 -0700 |
commit | 5af29cbde8c10f081bd8216338d0cdb661e23fb3 (patch) | |
tree | 7361d1a049c7f3921d29e866e39a347ecb798187 | |
parent | 1bd92ed6b00e7938cfe9a8e01275170c49e9893d (diff) | |
parent | 746a9992f0a842ded7a15cc5ce0afd0fa00f2ada (diff) | |
download | rails-5af29cbde8c10f081bd8216338d0cdb661e23fb3.tar.gz rails-5af29cbde8c10f081bd8216338d0cdb661e23fb3.tar.bz2 rails-5af29cbde8c10f081bd8216338d0cdb661e23fb3.zip |
Merge pull request #10317 from arabonradar/ar_having_values_bug_fix
ActiveRecord having clause bug fix
-rw-r--r-- | activerecord/lib/active_record/relation/query_methods.rb | 1 | ||||
-rw-r--r-- | activerecord/test/cases/relations_test.rb | 8 |
2 files changed, 8 insertions, 1 deletions
diff --git a/activerecord/lib/active_record/relation/query_methods.rb b/activerecord/lib/active_record/relation/query_methods.rb index 6ee3711052..9fcd2d06c5 100644 --- a/activerecord/lib/active_record/relation/query_methods.rb +++ b/activerecord/lib/active_record/relation/query_methods.rb @@ -551,7 +551,6 @@ module ActiveRecord # Order.having('SUM(price) > 30').group('user_id') def having(opts, *rest) opts.blank? ? self : spawn.having!(opts, *rest) - spawn.having!(opts, *rest) end def having!(opts, *rest) # :nodoc: diff --git a/activerecord/test/cases/relations_test.rb b/activerecord/test/cases/relations_test.rb index 9008c2785e..cf6af4e8f4 100644 --- a/activerecord/test/cases/relations_test.rb +++ b/activerecord/test/cases/relations_test.rb @@ -1299,6 +1299,14 @@ class RelationTest < ActiveRecord::TestCase assert_equal ['Foo', 'Foo'], query.uniq(true).uniq(false).map(&:name) end + def test_doesnt_add_having_values_if_options_are_blank + scope = Post.having('') + assert_equal [], scope.having_values + + scope = Post.having([]) + assert_equal [], scope.having_values + end + def test_references_triggers_eager_loading scope = Post.includes(:comments) assert !scope.eager_loading? |