Merge pull request #6284 from acapilleri/dup_validation

clean the erros if an object that includes validation  is duped.
This commit is contained in:
Carlos Antonio da Silva 2012-05-15 05:20:57 -07:00
commit 3d1b078a5b
2 changed files with 21 additions and 0 deletions

@ -177,6 +177,12 @@ def inherited(base)
super
end
end
# Clean the +Errors+ object if instance is duped
def initialize_dup(other) # :nodoc:
@errors = nil
super
end
# Returns the +Errors+ object that holds all information about attribute error messages.
def errors

@ -344,4 +344,19 @@ def test_does_not_modify_options_argument
Topic.validates :title, options
assert_equal({ :presence => true }, options)
end
def test_dup_validity_is_independent
Topic.validates_presence_of :title
topic = Topic.new("title" => "Litterature")
topic.valid?
duped = topic.dup
duped.title = nil
assert duped.invalid?
topic.title = nil
duped.title = 'Mathematics'
assert topic.invalid?
assert duped.valid?
end
end