aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record/associations/association.rb
diff options
context:
space:
mode:
authorlarrylv <larrylv1990@gmail.com>2013-03-04 17:38:22 +0800
committerlarrylv <larrylv1990@gmail.com>2013-03-05 12:43:05 +0800
commit939b896a06c0cff661076d0ca3fbe8c1d5552e83 (patch)
treefeec62302e70bfaf86c85e3537456487d94352a2 /activerecord/lib/active_record/associations/association.rb
parent927e649bc9dc5740285e4b4e9899421c2bbfefbe (diff)
downloadrails-939b896a06c0cff661076d0ca3fbe8c1d5552e83.tar.gz
rails-939b896a06c0cff661076d0ca3fbe8c1d5552e83.tar.bz2
rails-939b896a06c0cff661076d0ca3fbe8c1d5552e83.zip
Fix issue #7526. Reload the target if it's stale.
* This has been fixed at master via `365b8b6`, but not at 3-2-stable branch. * @stale_state should be nil when a model isn't saved. via `0f3901e`. * set @stale_state to nil when reset the target.
Diffstat (limited to 'activerecord/lib/active_record/associations/association.rb')
-rw-r--r--activerecord/lib/active_record/associations/association.rb7
1 files changed, 4 insertions, 3 deletions
diff --git a/activerecord/lib/active_record/associations/association.rb b/activerecord/lib/active_record/associations/association.rb
index ab0d888b16..861df46e3c 100644
--- a/activerecord/lib/active_record/associations/association.rb
+++ b/activerecord/lib/active_record/associations/association.rb
@@ -46,6 +46,7 @@ module ActiveRecord
@loaded = false
IdentityMap.remove(target) if IdentityMap.enabled? && target
@target = nil
+ @stale_state = nil
end
# Reloads the \target and returns +self+ on success.
@@ -134,15 +135,15 @@ module ActiveRecord
# ActiveRecord::RecordNotFound is rescued within the method, and it is
# not reraised. The proxy is \reset and +nil+ is the return value.
def load_target
- if find_target?
+ if (@stale_state && stale_target?) || find_target?
begin
if IdentityMap.enabled? && association_class && association_class.respond_to?(:base_class)
@target = IdentityMap.get(association_class, owner[reflection.foreign_key])
+ else
+ @target = find_target
end
rescue NameError
nil
- ensure
- @target ||= find_target
end
end
loaded! unless loaded?