Ensure that save on parent object fails for invalid has_one association. Closes #10518. [Pratik]

git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@9232 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
This commit is contained in:
Pratik Naik
2008-04-06 02:32:51 +00:00
parent 9bc75fd007
commit 7ddc8f2e1b
3 changed files with 27 additions and 0 deletions

View File

@@ -1,5 +1,7 @@
*SVN*
* Ensure that save on parent object fails for invalid has_one association. Closes #10518. [Pratik]
* Remove duplicate code from associations. [Pratik]
* Refactor HasManyThroughAssociation to inherit from HasManyAssociation. Association callbacks and <association>_ids= now work with hm:t. #11516 [rubyruy]

View File

@@ -784,6 +784,7 @@ module ActiveRecord
end
after_save method_name
add_single_associated_save_callbacks(reflection.name)
association_accessor_methods(reflection, HasOneAssociation)
association_constructor_method(:build, reflection, HasOneAssociation)
association_constructor_method(:create, reflection, HasOneAssociation)
@@ -1141,6 +1142,18 @@ module ActiveRecord
end
end
def add_single_associated_save_callbacks(association_name)
method_name = "validate_associated_records_for_#{association_name}".to_sym
define_method(method_name) do
association = instance_variable_get("@#{association_name}")
if !association.nil?
errors.add "#{association_name}" unless association.target.nil? || association.valid?
end
end
validate method_name
end
def add_multiple_associated_save_callbacks(association_name)
method_name = "validate_associated_records_for_#{association_name}".to_sym
ivar = "@#{association_name}"

View File

@@ -433,6 +433,18 @@ class HasOneAssociationsTest < ActiveRecord::TestCase
assert_equal a, firm.account
assert_equal a, firm.account(true)
end
def test_save_fails_for_invalid_has_one
firm = Firm.find(:first)
assert firm.valid?
firm.account = Account.new
assert !firm.account.valid?
assert !firm.valid?
assert !firm.save
assert_equal "is invalid", firm.errors.on("account")
end
def test_assignment_before_either_saved
firm = Firm.new("name" => "GlobalMegaCorp")