Opened 4 years ago
Closed 4 years ago
#32893 closed Bug (fixed)
Missing import statement in generated migration (NameError: name 'models' is not defined)
Reported by: | Jaap Joris Vens | Owned by: | Abhyudai |
---|---|---|---|
Component: | Migrations | Version: | dev |
Severity: | Normal | Keywords: | migrations writer missing import |
Cc: | Triage Stage: | Ready for checkin | |
Has patch: | yes | Needs documentation: | no |
Needs tests: | no | Patch needs improvement: | no |
Easy pickings: | no | UI/UX: | no |
Description
I found a bug in Django's latest release: 3.2.4.
Given the following contents of models.py
:
from django.db import models class MyField(models.TextField): pass class MyBaseModel(models.Model): class Meta: abstract = True class MyMixin: pass class MyModel(MyMixin, MyBaseModel): name = MyField(primary_key=True)
The makemigrations
command will generate the following migration file:
# Generated by Django 3.2.4 on 2021-06-30 19:13 import app.models from django.db import migrations class Migration(migrations.Migration): initial = True dependencies = [ ] operations = [ migrations.CreateModel( name='MyModel', fields=[ ('name', app.models.MyField(primary_key=True, serialize=False)), ], options={ 'abstract': False, }, bases=(app.models.MyMixin, models.Model), ), ]
Which will then fail with the following error:
File "/home/jj/django_example/app/migrations/0001_initial.py", line 7, in <module> class Migration(migrations.Migration): File "/home/jj/django_example/app/migrations/0001_initial.py", line 23, in Migration bases=(app.models.MyMixin, models.Model), NameError: name 'models' is not defined
Expected behavior: Django generates a migration file that is valid Python.
Actual behavior: Django generates a migration file that is missing an import statement.
I think this is a bug of the module django.db.migrations.writer
, but I'm not sure. I will be happy to assist with debugging.
Thanks for your attention,
Jaap Joris
Change History (5)
comment:1 by , 4 years ago
Easy pickings: | unset |
---|---|
Owner: | changed from | to
Status: | new → assigned |
Triage Stage: | Unreviewed → Accepted |
Version: | 3.2 → dev |
comment:2 by , 4 years ago
MyBaseModel
is not necessary to reproduce this issue, it's due to the fact that MyModel
doesn't have fields from django.db.models
and has custom bases
. It looks like an issue with special casing of models.Model
in TypeSerializer
. Proposed patch
diff --git a/django/db/migrations/serializer.py b/django/db/migrations/serializer.py index e19c881cda..6e78462e95 100644 --- a/django/db/migrations/serializer.py +++ b/django/db/migrations/serializer.py @@ -273,7 +273,7 @@ class TupleSerializer(BaseSequenceSerializer): class TypeSerializer(BaseSerializer): def serialize(self): special_cases = [ - (models.Model, "models.Model", []), + (models.Model, "models.Model", ['from django.db import models']), (type(None), 'type(None)', []), ] for case, string, imports in special_cases:
comment:4 by , 4 years ago
Triage Stage: | Accepted → Ready for checkin |
---|
I could reproduce the issue with
3.2.4
,2.2.24
and themain
branch. For what it's worth, the issue doesn't occur if the classMyModel
does inherit fromMyMixin
.