aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test/cases
diff options
context:
space:
mode:
authorGuillermo Iguaran <guilleiguaran@gmail.com>2017-05-29 13:35:15 -0500
committerGitHub <noreply@github.com>2017-05-29 13:35:15 -0500
commite7a33a5ed74cc0987544396f0742110fa5a5e228 (patch)
tree15e6fd99ae5764d7926710bf04a96080f6016cd4 /activerecord/test/cases
parent1c275d812f35f53f93cd96184a4f319983766cc5 (diff)
parentde387ea482bd72bab9e81db47cf7a5991f25117c (diff)
downloadrails-e7a33a5ed74cc0987544396f0742110fa5a5e228.tar.gz
rails-e7a33a5ed74cc0987544396f0742110fa5a5e228.tar.bz2
rails-e7a33a5ed74cc0987544396f0742110fa5a5e228.zip
Merge pull request #29248 from yawboakye/rename-should-rename-table-pkey
`rename_table` should rename primary key index name
Diffstat (limited to 'activerecord/test/cases')
-rw-r--r--activerecord/test/cases/migration/rename_table_test.rb23
1 files changed, 23 insertions, 0 deletions
diff --git a/activerecord/test/cases/migration/rename_table_test.rb b/activerecord/test/cases/migration/rename_table_test.rb
index 7bcabd0cc6..5da3ad33a3 100644
--- a/activerecord/test/cases/migration/rename_table_test.rb
+++ b/activerecord/test/cases/migration/rename_table_test.rb
@@ -79,10 +79,33 @@ module ActiveRecord
assert_equal ConnectionAdapters::PostgreSQL::Name.new("public", "octopi_#{pk}_seq"), seq
end
+ def test_renaming_table_renames_primary_key
+ connection.create_table :cats, id: :uuid, default: "uuid_generate_v4()"
+ rename_table :cats, :felines
+
+ assert connection.table_exists? :felines
+ refute connection.table_exists? :cats
+
+ primary_key_name = connection.select_values(<<-SQL.strip_heredoc, "SCHEMA")[0]
+ SELECT c.relname
+ FROM pg_class c
+ JOIN pg_index i
+ ON c.oid = i.indexrelid
+ WHERE i.indisprimary
+ AND i.indrelid = 'felines'::regclass
+ SQL
+
+ assert_equal "felines_pkey", primary_key_name
+ ensure
+ connection.drop_table :cats, if_exists: true
+ connection.drop_table :felines, if_exists: true
+ end
+
def test_renaming_table_doesnt_attempt_to_rename_non_existent_sequences
connection.create_table :cats, id: :uuid, default: "uuid_generate_v4()"
assert_nothing_raised { rename_table :cats, :felines }
assert connection.table_exists? :felines
+ refute connection.table_exists? :cats
ensure
connection.drop_table :cats, if_exists: true
connection.drop_table :felines, if_exists: true