mirror of
				https://github.com/django/django.git
				synced 2025-10-25 14:46:09 +00:00 
			
		
		
		
	Sorted conflicting migrations by names.
This commit is contained in:
		
				
					committed by
					
						 Mariusz Felisiak
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						parent
						
							52a0a03671
						
					
				
				
					commit
					04e4f80c1f
				
			| @@ -317,7 +317,7 @@ class MigrationLoader: | ||||
|             if app_label in seen_apps: | ||||
|                 conflicting_apps.add(app_label) | ||||
|             seen_apps.setdefault(app_label, set()).add(migration_name) | ||||
|         return {app_label: seen_apps[app_label] for app_label in conflicting_apps} | ||||
|         return {app_label: sorted(seen_apps[app_label]) for app_label in conflicting_apps} | ||||
|  | ||||
|     def project_state(self, nodes=None, at_end=True): | ||||
|         """ | ||||
|   | ||||
| @@ -247,7 +247,13 @@ class MigrateTests(MigrationTestBase): | ||||
|         """ | ||||
|         migrate exits if it detects a conflict. | ||||
|         """ | ||||
|         with self.assertRaisesMessage(CommandError, "Conflicting migrations detected"): | ||||
|         msg = ( | ||||
|             "Conflicting migrations detected; multiple leaf nodes in the " | ||||
|             "migration graph: (0002_conflicting_second, 0002_second in " | ||||
|             "migrations).\n" | ||||
|             "To fix them run 'python manage.py makemigrations --merge'" | ||||
|         ) | ||||
|         with self.assertRaisesMessage(CommandError, msg): | ||||
|             call_command("migrate", "migrations") | ||||
|  | ||||
|     @override_settings(MIGRATION_MODULES={ | ||||
| @@ -1066,16 +1072,13 @@ class MakeMigrationsTests(MigrationTestBase): | ||||
|         with self.temporary_migration_module(module="migrations.test_migrations_conflict"): | ||||
|             with self.assertRaises(CommandError) as context: | ||||
|                 call_command("makemigrations") | ||||
|         exception_message = str(context.exception) | ||||
|         self.assertIn( | ||||
|             'Conflicting migrations detected; multiple leaf nodes ' | ||||
|             'in the migration graph:', | ||||
|             exception_message | ||||
|         self.assertEqual( | ||||
|             str(context.exception), | ||||
|             "Conflicting migrations detected; multiple leaf nodes in the " | ||||
|             "migration graph: (0002_conflicting_second, 0002_second in " | ||||
|             "migrations).\n" | ||||
|             "To fix them run 'python manage.py makemigrations --merge'" | ||||
|         ) | ||||
|         self.assertIn('0002_second', exception_message) | ||||
|         self.assertIn('0002_conflicting_second', exception_message) | ||||
|         self.assertIn('in migrations', exception_message) | ||||
|         self.assertIn("To fix them run 'python manage.py makemigrations --merge'", exception_message) | ||||
|  | ||||
|     def test_makemigrations_merge_no_conflict(self): | ||||
|         """ | ||||
| @@ -1488,20 +1491,16 @@ class MakeMigrationsTests(MigrationTestBase): | ||||
|                     "makemigrations", "conflicting_app_with_dependencies", | ||||
|                     merge=True, interactive=True, stdout=out | ||||
|                 ) | ||||
|             val = out.getvalue().lower() | ||||
|             self.assertIn('merging conflicting_app_with_dependencies\n', val) | ||||
|             self.assertIn( | ||||
|             self.assertEqual( | ||||
|                 out.getvalue().lower(), | ||||
|                 'merging conflicting_app_with_dependencies\n' | ||||
|                 '  branch 0002_conflicting_second\n' | ||||
|                 '    - create model something\n', | ||||
|                 val | ||||
|             ) | ||||
|             self.assertIn( | ||||
|                 '    - create model something\n' | ||||
|                 '  branch 0002_second\n' | ||||
|                 '    - delete model tribble\n' | ||||
|                 '    - remove field silly_field from author\n' | ||||
|                 '    - add field rating to author\n' | ||||
|                 '    - create model book\n', | ||||
|                 val | ||||
|                 '    - create model book\n' | ||||
|             ) | ||||
|  | ||||
|     def test_makemigrations_with_custom_name(self): | ||||
|   | ||||
		Reference in New Issue
	
	Block a user