aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test
diff options
context:
space:
mode:
authorbenedikt <benedikt@synatic.net>2011-06-09 13:10:20 +0200
committerJon Leighton <j@jonathanleighton.com>2011-06-12 18:19:21 +0100
commitfa8dfad7654baa831c8de515118008b3382df515 (patch)
tree56ea9c703cb58a49f6aa2e54dab2632a27a0922c /activerecord/test
parent1fa059cd017c134499835593ba29620c4cd7358c (diff)
downloadrails-fa8dfad7654baa831c8de515118008b3382df515.tar.gz
rails-fa8dfad7654baa831c8de515118008b3382df515.tar.bz2
rails-fa8dfad7654baa831c8de515118008b3382df515.zip
Don't wrap operations on collection associations in transactions when they are not needed, so the connection adapter does not send empty BEGIN COMMIT transactions blocks to the database.
Diffstat (limited to 'activerecord/test')
-rw-r--r--activerecord/test/cases/associations/has_many_associations_test.rb45
1 files changed, 45 insertions, 0 deletions
diff --git a/activerecord/test/cases/associations/has_many_associations_test.rb b/activerecord/test/cases/associations/has_many_associations_test.rb
index 49999630b6..79b56d81df 100644
--- a/activerecord/test/cases/associations/has_many_associations_test.rb
+++ b/activerecord/test/cases/associations/has_many_associations_test.rb
@@ -537,6 +537,18 @@ class HasManyAssociationsTest < ActiveRecord::TestCase
assert_equal 3, companies(:first_firm).clients_of_firm(true).size
end
+ def test_transactions_when_adding_to_persisted
+ force_signal37_to_load_all_clients_of_firm
+ Client.expects(:transaction)
+ companies(:first_firm).clients_of_firm.concat(Client.new("name" => "Natural Company"))
+ end
+
+ def test_transactions_when_adding_to_new_record
+ Client.expects(:transaction).never
+ firm = Firm.new
+ firm.clients_of_firm.concat(Client.new("name" => "Natural Company"))
+ end
+
def test_new_aliased_to_build
company = companies(:first_firm)
new_client = assert_no_queries { company.clients_of_firm.new("name" => "Another Client") }
@@ -778,6 +790,21 @@ class HasManyAssociationsTest < ActiveRecord::TestCase
assert_equal 0, companies(:first_firm).clients_of_firm(true).size
end
+ def test_transaction_when_deleting_persisted
+ force_signal37_to_load_all_clients_of_firm
+ client = companies(:first_firm).clients_of_firm.create("name" => "Another Client")
+ Client.expects(:transaction)
+ companies(:first_firm).clients_of_firm.delete(client)
+ end
+
+ def test_transaction_when_deleting_new_record
+ client = Client.new("name" => "New Client")
+ firm = Firm.new
+ firm.clients_of_firm << client
+ Client.expects(:transaction).never
+ firm.clients_of_firm.delete(client)
+ end
+
def test_clearing_an_association_collection
firm = companies(:first_firm)
client_id = firm.clients_of_firm.first.id
@@ -1111,6 +1138,24 @@ class HasManyAssociationsTest < ActiveRecord::TestCase
assert_equal orig_accounts, firm.accounts
end
+ def test_transactions_when_replacing_on_persisted
+ firm = Firm.find(:first, :order => "id")
+ firm.clients = [companies(:first_client)]
+ assert firm.save, "Could not save firm"
+ firm.reload
+
+ Client.expects(:transaction)
+ firm.clients_of_firm = [Client.new("name" => "Natural Company")]
+ end
+
+ def test_transactions_when_replacing_on_new_record
+ firm = Firm.new
+ firm.clients_of_firm << Client.new("name" => "Natural Company")
+
+ Client.expects(:transaction).never
+ firm.clients_of_firm = [Client.new("name" => "New Client")]
+ end
+
def test_get_ids
assert_equal [companies(:first_client).id, companies(:second_client).id], companies(:first_firm).client_ids
end