mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Prompt about renames rather than doing them automatically
This commit is contained in:
		| @@ -74,6 +74,7 @@ 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: | ||||||
|  |                         if self.questioner.ask_rename(model_name, removed_field_name, field_name, field): | ||||||
|                             self.add_to_migration( |                             self.add_to_migration( | ||||||
|                                 app_label, |                                 app_label, | ||||||
|                                 operations.RenameField( |                                 operations.RenameField( | ||||||
| @@ -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__)) | ||||||
|   | |||||||
| @@ -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) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user