aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test/cases/adapters
diff options
context:
space:
mode:
authorYves Senn <yves.senn@gmail.com>2013-02-23 14:00:02 +0100
committerYves Senn <yves.senn@gmail.com>2013-02-23 15:23:28 +0100
commit8f6fa345e5c865acefa063c3e2cd62553fa9f2eb (patch)
tree6eeef63a41866e2571ccf4f5157d2abadd5e4e50 /activerecord/test/cases/adapters
parent0c1558d32fe7f3198ef598ce552ea89a04ab7793 (diff)
downloadrails-8f6fa345e5c865acefa063c3e2cd62553fa9f2eb.tar.gz
rails-8f6fa345e5c865acefa063c3e2cd62553fa9f2eb.tar.bz2
rails-8f6fa345e5c865acefa063c3e2cd62553fa9f2eb.zip
Sqlite preserves primary keys when copying/altering tables.
Backport #2312. Fixes #9367. I also added a test-case to make sure that renaming or removing a column preserves the primary key.
Diffstat (limited to 'activerecord/test/cases/adapters')
-rw-r--r--activerecord/test/cases/adapters/sqlite3/copy_table_test.rb8
1 files changed, 8 insertions, 0 deletions
diff --git a/activerecord/test/cases/adapters/sqlite3/copy_table_test.rb b/activerecord/test/cases/adapters/sqlite3/copy_table_test.rb
index 575b4806c1..74288a98d1 100644
--- a/activerecord/test/cases/adapters/sqlite3/copy_table_test.rb
+++ b/activerecord/test/cases/adapters/sqlite3/copy_table_test.rb
@@ -57,6 +57,14 @@ class CopyTableTest < ActiveRecord::TestCase
end
end
+ def test_copy_table_with_unconventional_primary_key
+ test_copy_table('owners', 'owners_unconventional') do |from, to, options|
+ original_pk = @connection.primary_key('owners')
+ copied_pk = @connection.primary_key('owners_unconventional')
+ assert_equal original_pk, copied_pk
+ end
+ end
+
protected
def copy_table(from, to, options = {})
@connection.copy_table(from, to, {:temporary => true}.merge(options))