mirror of
https://github.com/django/django.git
synced 2025-10-24 14:16:09 +00:00
Fixed #22975: Don't call rename SQL if not needed
This commit is contained in:
@@ -367,6 +367,8 @@ class BaseDatabaseSchemaEditor(object):
|
|||||||
"""
|
"""
|
||||||
Renames the table a model points to.
|
Renames the table a model points to.
|
||||||
"""
|
"""
|
||||||
|
if old_db_table == new_db_table:
|
||||||
|
return
|
||||||
self.execute(self.sql_rename_table % {
|
self.execute(self.sql_rename_table % {
|
||||||
"old_table": self.quote_name(old_db_table),
|
"old_table": self.quote_name(old_db_table),
|
||||||
"new_table": self.quote_name(new_db_table),
|
"new_table": self.quote_name(new_db_table),
|
||||||
|
@@ -769,6 +769,26 @@ class OperationTests(OperationTestBase):
|
|||||||
self.assertTableExists("test_almota_pony")
|
self.assertTableExists("test_almota_pony")
|
||||||
self.assertTableNotExists("test_almota_pony_2")
|
self.assertTableNotExists("test_almota_pony_2")
|
||||||
|
|
||||||
|
def test_alter_model_table_noop(self):
|
||||||
|
"""
|
||||||
|
Tests the AlterModelTable operation if the table name is not changed.
|
||||||
|
"""
|
||||||
|
project_state = self.set_up_test_model("test_almota")
|
||||||
|
# Test the state alteration
|
||||||
|
operation = migrations.AlterModelTable("Pony", "test_almota_pony")
|
||||||
|
new_state = project_state.clone()
|
||||||
|
operation.state_forwards("test_almota", new_state)
|
||||||
|
self.assertEqual(new_state.models["test_almota", "pony"].options["db_table"], "test_almota_pony")
|
||||||
|
# Test the database alteration
|
||||||
|
self.assertTableExists("test_almota_pony")
|
||||||
|
with connection.schema_editor() as editor:
|
||||||
|
operation.database_forwards("test_almota", editor, project_state, new_state)
|
||||||
|
self.assertTableExists("test_almota_pony")
|
||||||
|
# And test reversal
|
||||||
|
with connection.schema_editor() as editor:
|
||||||
|
operation.database_backwards("test_almota", editor, new_state, project_state)
|
||||||
|
self.assertTableExists("test_almota_pony")
|
||||||
|
|
||||||
def test_alter_field(self):
|
def test_alter_field(self):
|
||||||
"""
|
"""
|
||||||
Tests the AlterField operation.
|
Tests the AlterField operation.
|
||||||
|
Reference in New Issue
Block a user