aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test/models
diff options
context:
space:
mode:
authorCarlos Antonio da Silva <carlosantoniodasilva@gmail.com>2012-05-02 23:09:40 -0300
committerCarlos Antonio da Silva <carlosantoniodasilva@gmail.com>2012-05-02 23:23:35 -0300
commit5d26c8f00a11e40660be7516a13512ed522863ed (patch)
treeb8954479f19d5a9ad3fdb44d4f0d0f7ce11a5d54 /activerecord/test/models
parent36720af42995c8bac06ea7187e2c5768f89c2783 (diff)
downloadrails-5d26c8f00a11e40660be7516a13512ed522863ed.tar.gz
rails-5d26c8f00a11e40660be7516a13512ed522863ed.tar.bz2
rails-5d26c8f00a11e40660be7516a13512ed522863ed.zip
Fix issue with private kernel methods and collection associations. Closes #2508
Change CollectionProxy#method_missing to use scoped.public_send, to avoid a problem described in issue #2508 when trying to use class methods with names like "open", that clash with private kernel methods. Also changed the dynamic matcher instantiator to send straight to scoped, to avoid another roundtrip to method_missing.
Diffstat (limited to 'activerecord/test/models')
-rw-r--r--activerecord/test/models/company.rb5
1 files changed, 5 insertions, 0 deletions
diff --git a/activerecord/test/models/company.rb b/activerecord/test/models/company.rb
index fbdfaa2c29..7b993d5a2c 100644
--- a/activerecord/test/models/company.rb
+++ b/activerecord/test/models/company.rb
@@ -198,6 +198,11 @@ class Account < ActiveRecord::Base
@destroyed_account_ids ||= Hash.new { |h,k| h[k] = [] }
end
+ # Test private kernel method through collection proxy using has_many.
+ def self.open
+ where('firm_name = ?', '37signals')
+ end
+
before_destroy do |account|
if account.firm
Account.destroyed_account_ids[account.firm.id] << account.id