diff options
author | Sean Griffin <sean@thoughtbot.com> | 2014-12-26 15:55:06 -0700 |
---|---|---|
committer | Sean Griffin <sean@thoughtbot.com> | 2014-12-26 15:57:18 -0700 |
commit | 6d4a19cd503b39bdbefae7c1c527b24ad2e3a36a (patch) | |
tree | bf002556781adf62fcec341cce7dd8662555a047 | |
parent | eac4658bb2b4f27ab0219b4986b711801583c39f (diff) | |
download | rails-6d4a19cd503b39bdbefae7c1c527b24ad2e3a36a.tar.gz rails-6d4a19cd503b39bdbefae7c1c527b24ad2e3a36a.tar.bz2 rails-6d4a19cd503b39bdbefae7c1c527b24ad2e3a36a.zip |
Eagerly cast array values passed to the predicate builder
Part of a larger refactoring to remove type casting from Arel.
/cc @mrgilman
[Sean Griffin & Melanie Gilman]
-rw-r--r-- | activerecord/lib/active_record/relation/predicate_builder/array_handler.rb | 7 | ||||
-rw-r--r-- | activerecord/test/cases/relation/where_chain_test.rb | 8 |
2 files changed, 12 insertions, 3 deletions
diff --git a/activerecord/lib/active_record/relation/predicate_builder/array_handler.rb b/activerecord/lib/active_record/relation/predicate_builder/array_handler.rb index 4b5f5773a0..7c90563d96 100644 --- a/activerecord/lib/active_record/relation/predicate_builder/array_handler.rb +++ b/activerecord/lib/active_record/relation/predicate_builder/array_handler.rb @@ -19,7 +19,12 @@ module ActiveRecord case values.length when 0 then NullPredicate when 1 then predicate_builder.build(attribute, values.first) - else attribute.in(values) + else + attribute_name = attribute.name + casted_values = values.map do |v| + predicate_builder.type_cast_for_database(attribute_name, v) + end + attribute.in(casted_values) end unless nils.empty? diff --git a/activerecord/test/cases/relation/where_chain_test.rb b/activerecord/test/cases/relation/where_chain_test.rb index 3a02e8230d..f9d3badceb 100644 --- a/activerecord/test/cases/relation/where_chain_test.rb +++ b/activerecord/test/cases/relation/where_chain_test.rb @@ -36,7 +36,8 @@ module ActiveRecord end def test_not_in - expected = Post.arel_table[@name].not_in(%w[hello goodbye]) + values = %w[hello goodbye].map { |v| Arel::Nodes::Quoted.new(v) } + expected = Post.arel_table[@name].not_in(values) relation = Post.where.not(title: %w[hello goodbye]) assert_equal([expected], relation.where_values) end @@ -90,7 +91,10 @@ module ActiveRecord def test_chaining_multiple relation = Post.where.not(author_id: [1, 2]).where.not(title: 'ruby on rails') - expected = Post.arel_table['author_id'].not_in([1, 2]) + expected = Post.arel_table['author_id'].not_in([ + Arel::Nodes::Quoted.new(1), + Arel::Nodes::Quoted.new(2), + ]) assert_equal(expected, relation.where_values[0]) value = relation.where_values[1] |