mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	[1.8.x] Fixed #25040 -- Fixed migrations state crash with GenericForeignKey
Backport of 60f795c060 from master
			
			
This commit is contained in:
		
				
					committed by
					
						 Tim Graham
						Tim Graham
					
				
			
			
				
	
			
			
			
						parent
						
							0e3a8c22df
						
					
				
				
					commit
					181528726e
				
			| @@ -45,7 +45,7 @@ def get_related_models_recursive(model): | |||||||
|     def _related_models(m): |     def _related_models(m): | ||||||
|         return [ |         return [ | ||||||
|             f.related_model for f in m._meta.get_fields(include_parents=True, include_hidden=True) |             f.related_model for f in m._meta.get_fields(include_parents=True, include_hidden=True) | ||||||
|             if f.is_relation and not isinstance(f.related_model, six.string_types) |             if f.is_relation and f.related_model is not None and not isinstance(f.related_model, six.string_types) | ||||||
|         ] + [ |         ] + [ | ||||||
|             subclass for subclass in m.__subclasses__() |             subclass for subclass in m.__subclasses__() | ||||||
|             if issubclass(subclass, models.Model) |             if issubclass(subclass, models.Model) | ||||||
|   | |||||||
| @@ -11,3 +11,5 @@ Bugfixes | |||||||
|  |  | ||||||
| * Fixed ``AssertionError`` in some delete queries with a model containing a | * Fixed ``AssertionError`` in some delete queries with a model containing a | ||||||
|   field that is both a foreign and primary key (:ticket:`24951`). |   field that is both a foreign and primary key (:ticket:`24951`). | ||||||
|  |  | ||||||
|  | * Fixed a migrations crash with ``GenericForeignKey`` (:ticket:`25040`). | ||||||
|   | |||||||
| @@ -1,4 +1,5 @@ | |||||||
| from django.apps.registry import Apps | from django.apps.registry import Apps | ||||||
|  | from django.contrib.contenttypes.fields import GenericForeignKey | ||||||
| from django.db import models | from django.db import models | ||||||
| from django.db.migrations.operations import ( | from django.db.migrations.operations import ( | ||||||
|     AddField, AlterField, DeleteModel, RemoveField, |     AddField, AlterField, DeleteModel, RemoveField, | ||||||
| @@ -976,6 +977,12 @@ class RelatedModelsTests(SimpleTestCase): | |||||||
|         self.assertRelated(S, [A, B, T]) |         self.assertRelated(S, [A, B, T]) | ||||||
|         self.assertRelated(T, [A, B, S]) |         self.assertRelated(T, [A, B, S]) | ||||||
|  |  | ||||||
|  |     def test_generic_fk(self): | ||||||
|  |         A = self.create_model("A", foreign_keys=[models.ForeignKey('B'), GenericForeignKey()]) | ||||||
|  |         B = self.create_model("B", foreign_keys=[models.ForeignKey('C')]) | ||||||
|  |         self.assertRelated(A, [B]) | ||||||
|  |         self.assertRelated(B, [A]) | ||||||
|  |  | ||||||
|     def test_abstract_base(self): |     def test_abstract_base(self): | ||||||
|         A = self.create_model("A", abstract=True) |         A = self.create_model("A", abstract=True) | ||||||
|         B = self.create_model("B", bases=(A,)) |         B = self.create_model("B", bases=(A,)) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user