diff options
author | Michael Koziarski <michael@koziarski.com> | 2007-10-08 06:21:38 +0000 |
---|---|---|
committer | Michael Koziarski <michael@koziarski.com> | 2007-10-08 06:21:38 +0000 |
commit | 3122d321fd5d05d549274487e5a52f3a73bc6f43 (patch) | |
tree | 11d92375dd5ac760b3ef75148836794f30ab2592 | |
parent | 4eaa8ba5bec9001e97349e7dfd565c7215085834 (diff) | |
download | rails-3122d321fd5d05d549274487e5a52f3a73bc6f43.tar.gz rails-3122d321fd5d05d549274487e5a52f3a73bc6f43.tar.bz2 rails-3122d321fd5d05d549274487e5a52f3a73bc6f43.zip |
Make sure AR::Base#clone handles attr changes made in after_initialize hooks. Closes #7191 [weyus]
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@7802 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
-rwxr-xr-x | activerecord/lib/active_record/base.rb | 6 | ||||
-rwxr-xr-x | activerecord/test/base_test.rb | 4 | ||||
-rwxr-xr-x | activerecord/test/fixtures/topic.rb | 8 |
3 files changed, 14 insertions, 4 deletions
diff --git a/activerecord/lib/active_record/base.rb b/activerecord/lib/active_record/base.rb index 8b562e2ffb..8d98796af1 100755 --- a/activerecord/lib/active_record/base.rb +++ b/activerecord/lib/active_record/base.rb @@ -1751,9 +1751,9 @@ module ActiveRecord #:nodoc: def clone attrs = self.attributes_before_type_cast attrs.delete(self.class.primary_key) - self.class.new do |record| - record.send :instance_variable_set, '@attributes', attrs - end + record = self.class.new + record.send :instance_variable_set, '@attributes', attrs + record end # Updates a single attribute and saves the record. This is especially useful for boolean flags on existing records. diff --git a/activerecord/test/base_test.rb b/activerecord/test/base_test.rb index 650d87f91f..5e20cbe127 100755 --- a/activerecord/test/base_test.rb +++ b/activerecord/test/base_test.rb @@ -1008,6 +1008,10 @@ class BasicsTest < Test::Unit::TestCase cloned_topic.title["a"] = "c" assert_equal "b", topic.title["a"] + #test if attributes set as part of after_initialize are cloned correctly + assert_equal topic.author_email_address, cloned_topic.author_email_address + + # test if saved clone object differs from original cloned_topic.save assert !cloned_topic.new_record? assert cloned_topic.id != topic.id diff --git a/activerecord/test/fixtures/topic.rb b/activerecord/test/fixtures/topic.rb index dd71d6bf2b..b2541c8640 100755 --- a/activerecord/test/fixtures/topic.rb +++ b/activerecord/test/fixtures/topic.rb @@ -28,4 +28,10 @@ class Topic < ActiveRecord::Base def destroy_children self.class.delete_all "parent_id = #{id}" end -end + + def after_initialize + if self.new_record? + self.author_email_address = 'test@test.com' + end + end +end
\ No newline at end of file |