aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test
diff options
context:
space:
mode:
authorsgrif <sean@thoughtbot.com>2013-05-17 18:23:57 -0600
committerSean Griffin <sean@thoughtbot.com>2013-07-28 13:12:20 -0600
commit92a603387c084f13a36bbf3844d89029bb73a753 (patch)
tree54a433006d02fec85e44730e00b09f84d98c91d1 /activerecord/test
parent953b577f4378df06234d7e7ff409baa4d55890e8 (diff)
downloadrails-92a603387c084f13a36bbf3844d89029bb73a753.tar.gz
rails-92a603387c084f13a36bbf3844d89029bb73a753.tar.bz2
rails-92a603387c084f13a36bbf3844d89029bb73a753.zip
Add ability to specify how a class is converted to Arel predicate
This adds the ability for rails apps or gems to have granular control over how a domain object is converted to sql. One simple use case would be to add support for Regexp. Another simple case would be something like the following: class DateRange < Struct.new(:start, :end) def include?(date) (start..end).cover?(date) end end class DateRangePredicate def call(attribute, range) attribute.in(range.start..range.end) end end ActiveRecord::PredicateBuilder.register_handler(DateRange, DateRangePredicate.new) More complex cases might include taking a currency object and converting it from EUR to USD before performing the query. By moving the existing handlers to this format, we were also able to nicely refactor a rather nasty method in PredicateBuilder.
Diffstat (limited to 'activerecord/test')
-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