From 36b8073ff553e8939d78ca2371ffdec7eb8f8071 Mon Sep 17 00:00:00 2001 From: Michael Koziarski Date: Fri, 4 Apr 2008 14:37:22 +0000 Subject: Make HABTM#create behave the same as << with after_add callbacks. Closes #11374 [freels] git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@9224 5ecf4fe2-1ee6-0310-87b1-e25e094e27de --- activerecord/test/cases/associations/callbacks_test.rb | 15 +++++++++++++++ 1 file changed, 15 insertions(+) (limited to 'activerecord/test') diff --git a/activerecord/test/cases/associations/callbacks_test.rb b/activerecord/test/cases/associations/callbacks_test.rb index 17188e0b79..91b1af125e 100644 --- a/activerecord/test/cases/associations/callbacks_test.rb +++ b/activerecord/test/cases/associations/callbacks_test.rb @@ -94,6 +94,21 @@ class AssociationCallbacksTest < ActiveRecord::TestCase "after_adding#{david.id}"], ar.developers_log end + def test_has_and_belongs_to_many_after_add_called_after_save + ar = projects(:active_record) + assert ar.developers_log.empty? + alice = Developer.new(:name => 'alice') + ar.developers_with_callbacks << alice + assert_equal"after_adding#{alice.id}", ar.developers_log.last + + bob = ar.developers_with_callbacks.create(:name => 'bob') + assert_equal "after_adding#{bob.id}", ar.developers_log.last + + ar.developers_with_callbacks.build(:name => 'charlie') + assert_equal "after_adding", ar.developers_log.last + end + + def test_has_and_belongs_to_many_remove_callback david = developers(:david) jamis = developers(:jamis) -- cgit v1.2.3