diff options
author | Krzysztof Jurewicz <krzysztof.jurewicz@gmail.com> | 2013-02-13 03:40:24 +0100 |
---|---|---|
committer | Krzysztof Jurewicz <krzysztof.jurewicz@gmail.com> | 2013-03-18 21:01:04 +0100 |
commit | 72de8946515725b8827939d90698e2a082a5eae1 (patch) | |
tree | db867944b0aee3059da5815a90c711bc1248415e /activerecord | |
parent | c4a7c31581c8386198317a2385f9c7d462c18497 (diff) | |
download | rails-72de8946515725b8827939d90698e2a082a5eae1.tar.gz rails-72de8946515725b8827939d90698e2a082a5eae1.tar.bz2 rails-72de8946515725b8827939d90698e2a082a5eae1.zip |
Use define_method when method name contains weird characters.
Diffstat (limited to 'activerecord')
-rw-r--r-- | activerecord/lib/active_record/relation/delegation.rb | 8 | ||||
-rw-r--r-- | activerecord/test/cases/named_scope_test.rb | 14 |
2 files changed, 17 insertions, 5 deletions
diff --git a/activerecord/lib/active_record/relation/delegation.rb b/activerecord/lib/active_record/relation/delegation.rb index 00a506c3a7..1b6239eb38 100644 --- a/activerecord/lib/active_record/relation/delegation.rb +++ b/activerecord/lib/active_record/relation/delegation.rb @@ -37,11 +37,9 @@ module ActiveRecord end RUBY else - module_eval <<-RUBY, __FILE__, __LINE__ + 1 - def #{method}(*args, &block) - scoping { @klass.send(#{method.inspect}, *args, &block) } - end - RUBY + define_method method do |*args, &block| + scoping { @klass.send(method, *args, &block) } + end end end end diff --git a/activerecord/test/cases/named_scope_test.rb b/activerecord/test/cases/named_scope_test.rb index b593270352..42361cfbcb 100644 --- a/activerecord/test/cases/named_scope_test.rb +++ b/activerecord/test/cases/named_scope_test.rb @@ -271,6 +271,20 @@ class NamedScopeTest < ActiveRecord::TestCase assert_equal 'lifo', topic.author_name end + # Method delegation for scope names which look like /\A[a-zA-Z_]\w*[!?]?\z/ + # has been done by evaluating a string with a plain def statement. For scope + # names which contain spaces this approach doesn't work. + def test_spaces_in_scope_names + klass = Class.new(ActiveRecord::Base) do + self.table_name = "topics" + scope :"title containing space", -> { where("title LIKE '% %'") } + scope :approved, -> { where(:approved => true) } + end + assert_equal klass.send(:"title containing space"), klass.where("title LIKE '% %'") + assert_equal klass.approved.send(:"title containing space"), klass.approved.where("title LIKE '% %'") + end + end + def test_find_all_should_behave_like_select assert_equal Topic.base.to_a.select(&:approved), Topic.base.to_a.find_all(&:approved) end |