aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test
diff options
context:
space:
mode:
authorCarlos Antonio da Silva <carlosantoniodasilva@gmail.com>2012-11-01 13:14:58 -0200
committerCarlos Antonio da Silva <carlosantoniodasilva@gmail.com>2012-11-01 13:50:56 -0200
commitd37d40b2d702e9ff1461a3571f7f4d7ec52c2a2a (patch)
tree7fb38ee09914b73ca04a5d975e633df586976480 /activerecord/test
parentf32f150e45f3dc3ccbd0adc1c91e6144b3cf1384 (diff)
downloadrails-d37d40b2d702e9ff1461a3571f7f4d7ec52c2a2a.tar.gz
rails-d37d40b2d702e9ff1461a3571f7f4d7ec52c2a2a.tar.bz2
rails-d37d40b2d702e9ff1461a3571f7f4d7ec52c2a2a.zip
Fix issue with collection associations and first(n)/last(n)
When calling first(n) or last(n) in a collection, Active Record was improperly trying to set the inverse of instance in case that option existed. This change was introduced by fdf4eae506fa9895e831f569bed3c4aa6a999a22. In such cases we don't need to do that "manually", since the way collection will be loaded will already handle that, so we just skip setting the inverse association when any argument is given to first(n)/last(n). The test included ensures that these scenarios will have the inverse of instance set properly. Fixes #8087, Closes #8094.
Diffstat (limited to 'activerecord/test')
-rw-r--r--activerecord/test/cases/associations/inverse_associations_test.rb12
1 files changed, 12 insertions, 0 deletions
diff --git a/activerecord/test/cases/associations/inverse_associations_test.rb b/activerecord/test/cases/associations/inverse_associations_test.rb
index e03d7916f1..533192ea0e 100644
--- a/activerecord/test/cases/associations/inverse_associations_test.rb
+++ b/activerecord/test/cases/associations/inverse_associations_test.rb
@@ -265,6 +265,18 @@ class InverseHasManyTests < ActiveRecord::TestCase
assert man.interests.last.man.equal? man
end
+ def test_parent_instance_should_be_shared_with_first_n_and_last_n_children
+ man = Man.first
+
+ interests = man.interests.first(2)
+ assert interests[0].man.equal? man
+ assert interests[1].man.equal? man
+
+ interests = man.interests.last(2)
+ assert interests[0].man.equal? man
+ assert interests[1].man.equal? man
+ end
+
def test_trying_to_use_inverses_that_dont_exist_should_raise_an_error
assert_raise(ActiveRecord::InverseOfAssociationNotFoundError) { Man.find(:first).secret_interests }
end