Fixed #24537 -- Ignored field order in RenameModel detection

Thanks to David Sanders for the report and test and Simon Charette for
the review.
This commit is contained in:
Markus Holtermann 2015-03-28 18:57:51 +01:00
parent ba1665ed75
commit c7ec3c07e7
2 changed files with 32 additions and 1 deletions

View File

@ -76,7 +76,7 @@ class MigrationAutodetector(object):
change during renames) change during renames)
""" """
fields_def = [] fields_def = []
for name, field in fields: for name, field in sorted(fields):
deconstruction = self.deep_deconstruct(field) deconstruction = self.deep_deconstruct(field)
if field.remote_field and field.remote_field.model: if field.remote_field and field.remote_field.model:
del deconstruction[2]['to'] del deconstruction[2]['to']

View File

@ -657,6 +657,37 @@ class AutodetectorTests(TestCase):
self.assertOperationTypes(changes, 'otherapp', 0, ["RenameField"]) self.assertOperationTypes(changes, 'otherapp', 0, ["RenameField"])
self.assertOperationAttributes(changes, 'otherapp', 0, 0, old_name="author", new_name="writer") self.assertOperationAttributes(changes, 'otherapp', 0, 0, old_name="author", new_name="writer")
def test_rename_model_with_fks_in_different_position(self):
"""
#24537 - Tests that the order of fields in a model does not influence
the RenameModel detection.
"""
before = self.make_project_state([
ModelState("testapp", "EntityA", [
("id", models.AutoField(primary_key=True)),
]),
ModelState("testapp", "EntityB", [
("id", models.AutoField(primary_key=True)),
("some_label", models.CharField(max_length=255)),
("entity_a", models.ForeignKey("testapp.EntityA")),
]),
])
after = self.make_project_state([
ModelState("testapp", "EntityA", [
("id", models.AutoField(primary_key=True)),
]),
ModelState("testapp", "RenamedEntityB", [
("id", models.AutoField(primary_key=True)),
("entity_a", models.ForeignKey("testapp.EntityA")),
("some_label", models.CharField(max_length=255)),
]),
])
autodetector = MigrationAutodetector(before, after, MigrationQuestioner({"ask_rename_model": True}))
changes = autodetector._detect_changes()
self.assertNumberMigrations(changes, "testapp", 1)
self.assertOperationTypes(changes, "testapp", 0, ["RenameModel"])
self.assertOperationAttributes(changes, "testapp", 0, 0, old_name="EntityB", new_name="RenamedEntityB")
def test_fk_dependency(self): def test_fk_dependency(self):
"""Tests that having a ForeignKey automatically adds a dependency.""" """Tests that having a ForeignKey automatically adds a dependency."""
# Make state # Make state