diff options
author | Godfrey Chan <godfreykfc@gmail.com> | 2014-03-11 07:25:36 -0700 |
---|---|---|
committer | Godfrey Chan <godfreykfc@gmail.com> | 2014-03-11 07:25:36 -0700 |
commit | ccaf0ed791d69567f91a659c9efc7d3bb5bc8b3b (patch) | |
tree | e7822c7234bf04a8157130937995f43d56a24e4f /activerecord | |
parent | 6868265fe36e280e0b1ce96f3d378d0e0e14dc90 (diff) | |
parent | e5f15a83656f6d005dab40a30fb9f7fa2cf65d77 (diff) | |
download | rails-ccaf0ed791d69567f91a659c9efc7d3bb5bc8b3b.tar.gz rails-ccaf0ed791d69567f91a659c9efc7d3bb5bc8b3b.tar.bz2 rails-ccaf0ed791d69567f91a659c9efc7d3bb5bc8b3b.zip |
Merge pull request #14345 from arthurnn/revert_14052
Fixes STI when 2+ levels deep.
Diffstat (limited to 'activerecord')
-rw-r--r-- | activerecord/lib/active_record/attribute_methods.rb | 6 | ||||
-rw-r--r-- | activerecord/test/cases/attribute_methods_test.rb | 13 |
2 files changed, 16 insertions, 3 deletions
diff --git a/activerecord/lib/active_record/attribute_methods.rb b/activerecord/lib/active_record/attribute_methods.rb index 57ceec2fc5..ea48a13ea8 100644 --- a/activerecord/lib/active_record/attribute_methods.rb +++ b/activerecord/lib/active_record/attribute_methods.rb @@ -105,9 +105,9 @@ module ActiveRecord super else # If B < A and A defines its own attribute method, then we don't want to overwrite that. - defined = method_defined_within?(method_name, superclass) && - superclass.instance_method(method_name).owner != superclass.generated_attribute_methods - defined || super + defined = method_defined_within?(method_name, superclass, superclass.generated_attribute_methods) + base_defined = Base.method_defined?(method_name) || Base.private_method_defined?(method_name) + defined && !base_defined || super end end diff --git a/activerecord/test/cases/attribute_methods_test.rb b/activerecord/test/cases/attribute_methods_test.rb index 1a1e442df0..173081cb28 100644 --- a/activerecord/test/cases/attribute_methods_test.rb +++ b/activerecord/test/cases/attribute_methods_test.rb @@ -746,6 +746,19 @@ class AttributeMethodsTest < ActiveRecord::TestCase assert "unknown attribute: hello", error.message end + def test_methods_override_in_multi_level_subclass + klass = Class.new(Developer) do + def name + "dev:#{read_attribute(:name)}" + end + end + + 2.times { klass = Class.new klass } + dev = klass.new(name: 'arthurnn') + dev.save! + assert_equal 'dev:arthurnn', dev.reload.name + end + def test_global_methods_are_overwritten klass = Class.new(ActiveRecord::Base) do self.table_name = 'computers' |