diff options
author | Yves Senn <yves.senn@gmail.com> | 2013-12-27 11:15:19 -0800 |
---|---|---|
committer | Yves Senn <yves.senn@gmail.com> | 2013-12-27 11:15:19 -0800 |
commit | 4fd3204a048b0c2dea0620e96f989a305f052629 (patch) | |
tree | 16ad7e04910731f7089227dde19301caf5878f72 /activerecord/test | |
parent | b33555d3ef26dbe07472c9e1d23f3a6e49a35059 (diff) | |
parent | b7bf025374324c2b73b3ab270cd4153f18a942b0 (diff) | |
download | rails-4fd3204a048b0c2dea0620e96f989a305f052629.tar.gz rails-4fd3204a048b0c2dea0620e96f989a305f052629.tar.bz2 rails-4fd3204a048b0c2dea0620e96f989a305f052629.zip |
Merge pull request #13474 from jdelStrother/becomes
Copy changed_attributes across to newly become'd records
Diffstat (limited to 'activerecord/test')
-rw-r--r-- | activerecord/test/cases/persistence_test.rb | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/activerecord/test/cases/persistence_test.rb b/activerecord/test/cases/persistence_test.rb index 6cd3e2154e..6f1e518f45 100644 --- a/activerecord/test/cases/persistence_test.rb +++ b/activerecord/test/cases/persistence_test.rb @@ -152,6 +152,20 @@ class PersistenceTest < ActiveRecord::TestCase assert_equal original_errors, client.errors end + def test_dupd_becomes_persists_changes_from_the_original + original = topics(:first) + copy = original.dup.becomes(Reply) + copy.save! + assert_equal "The First Topic", Topic.find(copy.id).title + end + + def test_becomes_includes_changed_attributes + company = Company.new(name: "37signals") + client = company.becomes(Client) + assert_equal "37signals", client.name + assert_equal %w{name}, client.changed + end + def test_delete_many original_count = Topic.count Topic.delete(deleting = [1, 2]) |