1
0
mirror of https://github.com/django/django.git synced 2025-10-25 14:46:09 +00:00

Prompt about renames rather than doing them automatically

This commit is contained in:
Andrew Godwin
2013-06-21 15:32:15 +01:00
parent 92a10f5552
commit cca40703df
2 changed files with 21 additions and 12 deletions

View File

@@ -74,18 +74,19 @@ class MigrationAutodetector(object):
found_rename = False found_rename = False
for removed_field_name in (old_field_names - new_field_names): for removed_field_name in (old_field_names - new_field_names):
if old_model_state.get_field_by_name(removed_field_name).deconstruct()[1:] == field_dec: if old_model_state.get_field_by_name(removed_field_name).deconstruct()[1:] == field_dec:
self.add_to_migration( if self.questioner.ask_rename(model_name, removed_field_name, field_name, field):
app_label, self.add_to_migration(
operations.RenameField( app_label,
model_name = model_name, operations.RenameField(
old_name = removed_field_name, model_name = model_name,
new_name = field_name, old_name = removed_field_name,
new_name = field_name,
)
) )
) old_field_names.remove(removed_field_name)
old_field_names.remove(removed_field_name) new_field_names.remove(field_name)
new_field_names.remove(field_name) found_rename = True
found_rename = True break
break
if found_rename: if found_rename:
continue continue
# You can't just add NOT NULL fields with no default # You can't just add NOT NULL fields with no default
@@ -257,6 +258,10 @@ class MigrationQuestioner(object):
# None means quit # None means quit
return None return None
def ask_rename(self, model_name, old_name, new_name, field_instance):
"Was this field really renamed?"
return self.defaults.get("ask_rename", False)
class InteractiveMigrationQuestioner(MigrationQuestioner): class InteractiveMigrationQuestioner(MigrationQuestioner):
@@ -323,3 +328,7 @@ class InteractiveMigrationQuestioner(MigrationQuestioner):
print("Invalid input: %s" % e) print("Invalid input: %s" % e)
else: else:
break break
def ask_rename(self, model_name, old_name, new_name, field_instance):
"Was this field really renamed?"
return self._boolean_input("Did you rename %s.%s to %s.%s (a %s)?" % (model_name, old_name, model_name, new_name, field_instance.__class__.__name__))

View File

@@ -155,7 +155,7 @@ class AutodetectorTests(TestCase):
# Make state # Make state
before = self.make_project_state([self.author_name]) before = self.make_project_state([self.author_name])
after = self.make_project_state([self.author_name_renamed]) after = self.make_project_state([self.author_name_renamed])
autodetector = MigrationAutodetector(before, after) autodetector = MigrationAutodetector(before, after, MigrationQuestioner({"ask_rename": True}))
changes = autodetector.changes() changes = autodetector.changes()
# Right number of migrations? # Right number of migrations?
self.assertEqual(len(changes['testapp']), 1) self.assertEqual(len(changes['testapp']), 1)