aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record
diff options
context:
space:
mode:
authorPrathamesh Sonpatki <csonpatki@gmail.com>2016-02-17 11:47:37 +0530
committerPrathamesh Sonpatki <csonpatki@gmail.com>2016-02-17 11:50:29 +0530
commite254665ac0eea72bdc3997c5fda9d02300ed0717 (patch)
tree74dd3bed8124f4ab8afa25c0db5db038188c1574 /activerecord/lib/active_record
parentbb4a85da1011fecf4da6fe5b7ed73d3ba9e2e7f3 (diff)
downloadrails-e254665ac0eea72bdc3997c5fda9d02300ed0717.tar.gz
rails-e254665ac0eea72bdc3997c5fda9d02300ed0717.tar.bz2
rails-e254665ac0eea72bdc3997c5fda9d02300ed0717.zip
Show proper error message when a non-relation object is passed to AR::Relation#or
- Previously it used to show error message <"undefined method `limit_value' for {:title=>\"Rails\"}:Hash"> - Now it shows following error message. >> Post.where.not(name: 'DHH').or(name: 'Tenderlove') ArgumentError: You have passed Hash object to #or. Pass an ActiveRecord::Relation object instead. - Fixes #23714.
Diffstat (limited to 'activerecord/lib/active_record')
-rw-r--r--activerecord/lib/active_record/relation/query_methods.rb4
1 files changed, 4 insertions, 0 deletions
diff --git a/activerecord/lib/active_record/relation/query_methods.rb b/activerecord/lib/active_record/relation/query_methods.rb
index 91d486e902..4533f3263f 100644
--- a/activerecord/lib/active_record/relation/query_methods.rb
+++ b/activerecord/lib/active_record/relation/query_methods.rb
@@ -655,6 +655,10 @@ module ActiveRecord
# # SELECT `posts`.* FROM `posts` WHERE (('id = 1' OR 'author_id = 3'))
#
def or(other)
+ unless other.is_a? Relation
+ raise ArgumentError, "You have passed #{other.class.name} object to #or. Pass an ActiveRecord::Relation object instead."
+ end
+
spawn.or!(other)
end