aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test/cases
diff options
context:
space:
mode:
authorRafael Mendonça França <rafaelmfranca@gmail.com>2013-07-29 19:32:28 -0700
committerRafael Mendonça França <rafaelmfranca@gmail.com>2013-07-29 19:32:28 -0700
commit43187f9cdc631f9ee8ec68025d81113acdf8eeef (patch)
tree16b0df9d1dbe7cf100f0a886855181ea16bf2c56 /activerecord/test/cases
parentfbaae891ac5361a03aaea07bc95bc11b3c6e11fd (diff)
parent92a603387c084f13a36bbf3844d89029bb73a753 (diff)
downloadrails-43187f9cdc631f9ee8ec68025d81113acdf8eeef.tar.gz
rails-43187f9cdc631f9ee8ec68025d81113acdf8eeef.tar.bz2
rails-43187f9cdc631f9ee8ec68025d81113acdf8eeef.zip
Merge pull request #10673 from sgrif/master
Add ability to specify how a class is converted to Arel predicate when passed to where
Diffstat (limited to 'activerecord/test/cases')
-rw-r--r--activerecord/test/cases/relation/predicate_builder_test.rb14
1 files changed, 14 insertions, 0 deletions
diff --git a/activerecord/test/cases/relation/predicate_builder_test.rb b/activerecord/test/cases/relation/predicate_builder_test.rb
new file mode 100644
index 0000000000..1c87f5c12e
--- /dev/null
+++ b/activerecord/test/cases/relation/predicate_builder_test.rb
@@ -0,0 +1,14 @@
+require "cases/helper"
+require 'models/topic'
+
+module ActiveRecord
+ class PredicateBuilderTest < ActiveRecord::TestCase
+ def test_registering_new_handlers
+ PredicateBuilder.register_handler(Regexp, proc do |column, value|
+ Arel::Nodes::InfixOperation.new('~', column, value.source)
+ end)
+
+ assert_match %r{["`]topics["`].["`]title["`] ~ 'rails'}, Topic.where(title: /rails/).to_sql
+ end
+ end
+end