diff --git a/django/db/migrations/state.py b/django/db/migrations/state.py index c865f139d7..560d0014c8 100644 --- a/django/db/migrations/state.py +++ b/django/db/migrations/state.py @@ -43,7 +43,7 @@ def get_related_models_recursive(model): def _related_models(m): return [ 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__() if issubclass(subclass, models.Model) diff --git a/tests/migrations/test_state.py b/tests/migrations/test_state.py index 7a959c53eb..0189d35d82 100644 --- a/tests/migrations/test_state.py +++ b/tests/migrations/test_state.py @@ -1,4 +1,5 @@ from django.apps.registry import Apps +from django.contrib.contenttypes.fields import GenericForeignKey from django.db import models from django.db.migrations.exceptions import InvalidBasesError from django.db.migrations.operations import ( @@ -1049,6 +1050,12 @@ class RelatedModelsTests(SimpleTestCase): self.assertRelated(S, [A, B, T]) 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): A = self.create_model("A", abstract=True) B = self.create_model("B", bases=(A,))