diff options
author | Yves Senn <yves.senn@gmail.com> | 2013-02-23 15:32:18 +0100 |
---|---|---|
committer | Yves Senn <yves.senn@gmail.com> | 2013-02-23 15:40:07 +0100 |
commit | 2d4e3fecc28c40eef461c1242ebf17384d6e38fb (patch) | |
tree | 8ed041c86f9499c97bfb0259390629be2b21ebba /activerecord | |
parent | cad397ea2bdeec77792201b9f10cedae6b62163b (diff) | |
download | rails-2d4e3fecc28c40eef461c1242ebf17384d6e38fb.tar.gz rails-2d4e3fecc28c40eef461c1242ebf17384d6e38fb.tar.bz2 rails-2d4e3fecc28c40eef461c1242ebf17384d6e38fb.zip |
forwardport #9388 rename/remove column preserves custom PK.
Diffstat (limited to 'activerecord')
-rw-r--r-- | activerecord/test/cases/migration/rename_column_test.rb | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/activerecord/test/cases/migration/rename_column_test.rb b/activerecord/test/cases/migration/rename_column_test.rb index 88bea2211d..05e93986ef 100644 --- a/activerecord/test/cases/migration/rename_column_test.rb +++ b/activerecord/test/cases/migration/rename_column_test.rb @@ -128,7 +128,7 @@ module ActiveRecord assert_equal 1, connection.indexes('test_models').size remove_column("test_models", "hat_size") - # Every database and/or database adapter has their own behavior + # Every database and/or database adapter has their own behavior # if it drops the multi-column index when any of the indexed columns dropped by remove_column. if current_adapter?(:PostgreSQLAdapter, :OracleAdapter) assert_equal [], connection.indexes('test_models').map(&:name) @@ -245,6 +245,20 @@ module ActiveRecord def test_remove_column_no_second_parameter_raises_exception assert_raise(ArgumentError) { connection.remove_column("funny") } end + + def test_removing_and_renaming_column_preserves_custom_primary_key + connection.create_table "my_table", primary_key: "my_table_id", force: true do |t| + t.integer "col_one" + t.string "col_two", limit: 128, null: false + end + + remove_column("my_table", "col_two") + rename_column("my_table", "col_one", "col_three") + + assert_equal 'my_table_id', connection.primary_key('my_table') + ensure + connection.drop_table(:my_table) rescue nil + end end end end |