mirror of
https://github.com/github/rails.git
synced 2026-01-09 14:48:01 -05:00
Merge pull request #10901 from armstrjare/fix_query_null_foreign_key_on_new_record_collection_ids_reader
Fixes CollectionAssociation#ids_reader returning incorrect ids for new records
This commit is contained in:
@@ -4,6 +4,12 @@
|
||||
|
||||
*Yves Senn*
|
||||
|
||||
* Prevent query with NULL foreign key value on CollectionAssociation#ids_reader
|
||||
for non-persisted records. Fixes bug where Company.new.contract_ids would
|
||||
incorrectly load all non-associated Contracts.
|
||||
|
||||
*Jared Armstrong*
|
||||
|
||||
* Fix the `:primary_key` option for `has_many` associations.
|
||||
Fixes #10693.
|
||||
|
||||
|
||||
@@ -43,7 +43,7 @@ module ActiveRecord
|
||||
|
||||
# Implements the ids reader method, e.g. foo.item_ids for Foo.has_many :items
|
||||
def ids_reader
|
||||
if loaded? || options[:finder_sql]
|
||||
if owner.new_record? || loaded? || options[:finder_sql]
|
||||
load_target.map do |record|
|
||||
record.send(reflection.association_primary_key)
|
||||
end
|
||||
|
||||
@@ -1311,6 +1311,33 @@ class HasManyAssociationsTest < ActiveRecord::TestCase
|
||||
assert !company.clients.loaded?
|
||||
end
|
||||
|
||||
def test_get_ids_for_association_on_new_record_does_not_try_to_find_records
|
||||
Company.columns # Load schema information so we don't query below
|
||||
Contract.columns # if running just this test.
|
||||
|
||||
company = Company.new
|
||||
assert_queries(0) do
|
||||
company.contract_ids
|
||||
end
|
||||
|
||||
assert_equal [], company.contract_ids
|
||||
end
|
||||
|
||||
def test_set_ids_for_association_on_new_record_applies_association_correctly
|
||||
contract_a = Contract.create!
|
||||
contract_b = Contract.create!
|
||||
another_contract = Contract.create!
|
||||
company = Company.new(:name => "Some Company")
|
||||
|
||||
company.contract_ids = [contract_a.id, contract_b.id]
|
||||
assert_equal [contract_a.id, contract_b.id], company.contract_ids
|
||||
assert_equal [contract_a, contract_b], company.contracts
|
||||
|
||||
company.save!
|
||||
assert_equal company, contract_a.reload.company
|
||||
assert_equal company, contract_b.reload.company
|
||||
end
|
||||
|
||||
def test_get_ids_ignores_include_option
|
||||
assert_equal [readers(:michael_welcome).id], posts(:welcome).readers_with_person_ids
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user