mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
Reloading an instance refreshes its aggregations as well as its associations. References #3024.
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@3242 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
This commit is contained in:
parent
e466fc45ca
commit
d496db1388
5 changed files with 32 additions and 0 deletions
|
@ -1,5 +1,7 @@
|
|||
*SVN*
|
||||
|
||||
* Reloading an instance refreshes its aggregations as well as its associations. #3024 [François Beausolei]
|
||||
|
||||
* Fixed that using :include together with :conditions array in Base.find would cause NoMethodError #2887 [Paul Hammmond]
|
||||
|
||||
* PostgreSQL: more robust sequence name discovery. #3087 [Rick Olson]
|
||||
|
|
|
@ -4,6 +4,12 @@ module ActiveRecord
|
|||
base.extend(ClassMethods)
|
||||
end
|
||||
|
||||
def clear_aggregation_cache #:nodoc:
|
||||
self.class.reflect_on_all_aggregations.to_a.each do |assoc|
|
||||
instance_variable_set "@#{assoc.name}", nil
|
||||
end unless self.new_record?
|
||||
end
|
||||
|
||||
# Active Record implements aggregation through a macro-like class method called +composed_of+ for representing attributes
|
||||
# as value objects. It expresses relationships like "Account [is] composed of Money [among other things]" or "Person [is]
|
||||
# composed of [an] address". Each call to the macro adds a description of how the value objects are created from the
|
||||
|
|
|
@ -1309,6 +1309,7 @@ module ActiveRecord #:nodoc:
|
|||
|
||||
# Reloads the attributes of this object from the database.
|
||||
def reload
|
||||
clear_aggregation_cache
|
||||
clear_association_cache
|
||||
@attributes.update(self.class.find(self.id).instance_variable_get('@attributes'))
|
||||
self
|
||||
|
|
|
@ -44,4 +44,23 @@ class AggregationsTest < Test::Unit::TestCase
|
|||
assert_equal "39", customers(:david).gps_location.latitude
|
||||
assert_equal "-110", customers(:david).gps_location.longitude
|
||||
end
|
||||
|
||||
def test_reloaded_instance_refreshes_aggregations
|
||||
assert_equal "35.544623640962634", customers(:david).gps_location.latitude
|
||||
assert_equal "-105.9309951055148", customers(:david).gps_location.longitude
|
||||
|
||||
Customer.update_all("gps_location = '24x113'")
|
||||
customers(:david).reload
|
||||
assert_equal '24x113', customers(:david)['gps_location']
|
||||
|
||||
assert_equal GpsLocation.new('24x113'), customers(:david).gps_location
|
||||
end
|
||||
|
||||
def test_gps_equality
|
||||
assert GpsLocation.new('39x110') == GpsLocation.new('39x110')
|
||||
end
|
||||
|
||||
def test_gps_inequality
|
||||
assert GpsLocation.new('39x110') != GpsLocation.new('39x111')
|
||||
end
|
||||
end
|
||||
|
|
4
activerecord/test/fixtures/customer.rb
vendored
4
activerecord/test/fixtures/customer.rb
vendored
|
@ -44,4 +44,8 @@ class GpsLocation
|
|||
def longitude
|
||||
gps_location.split("x").last
|
||||
end
|
||||
|
||||
def ==(other)
|
||||
self.latitude == other.latitude && self.longitude == other.longitude
|
||||
end
|
||||
end
|
Loading…
Reference in a new issue