mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Refs #29897 -- Moved autodetector swappable dependency resolution to a method.
This commit is contained in:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						parent
						
							f1855fd885
						
					
				
				
					commit
					82353ef940
				
			| @@ -237,6 +237,17 @@ class MigrationAutodetector: | ||||
|                     ) | ||||
|                     self.through_users[through_key] = (app_label, old_model_name, field_name) | ||||
|  | ||||
|     @staticmethod | ||||
|     def _resolve_dependency(dependency): | ||||
|         """ | ||||
|         Return the resolved dependency and a boolean denoting whether or not | ||||
|         it was swappable. | ||||
|         """ | ||||
|         if dependency[0] != '__setting__': | ||||
|             return dependency, False | ||||
|         resolved_app_label, resolved_object_name = getattr(settings, dependency[1]).split('.') | ||||
|         return (resolved_app_label, resolved_object_name.lower()) + dependency[2:], True | ||||
|  | ||||
|     def _build_migration_list(self, graph=None): | ||||
|         """ | ||||
|         Chop the lists of operations up into migrations with dependencies on | ||||
| @@ -265,15 +276,12 @@ class MigrationAutodetector: | ||||
|                     deps_satisfied = True | ||||
|                     operation_dependencies = set() | ||||
|                     for dep in operation._auto_deps: | ||||
|                         is_swappable_dep = dep[0] == '__setting__' | ||||
|                         if is_swappable_dep: | ||||
|                             # We need to temporarily resolve the swappable dependency to prevent | ||||
|                             # circular references. While keeping the dependency checks on the | ||||
|                             # resolved model we still add the swappable dependencies. | ||||
|                             # See #23322 | ||||
|                             resolved_app_label, resolved_object_name = getattr(settings, dep[1]).split('.') | ||||
|                         # Temporarily resolve the swappable dependency to | ||||
|                         # prevent circular references. While keeping the | ||||
|                         # dependency checks on the resolved model, add the | ||||
|                         # swappable dependencies. | ||||
|                         original_dep = dep | ||||
|                             dep = (resolved_app_label, resolved_object_name.lower(), dep[2], dep[3]) | ||||
|                         dep, is_swappable_dep = self._resolve_dependency(dep) | ||||
|                         if dep[0] != app_label: | ||||
|                             # External app dependency. See if it's not yet | ||||
|                             # satisfied. | ||||
|   | ||||
		Reference in New Issue
	
	Block a user