#25461 closed Bug (fixed)
Mistake in model _meta API migration guide for multi-table inheritance
Reported by: | ad-65 | Owned by: | nobody |
---|---|---|---|
Component: | Documentation | Version: | 1.8 |
Severity: | Normal | Keywords: | |
Cc: | romain.garrigues.cs@… | Triage Stage: | Accepted |
Has patch: | yes | Needs documentation: | no |
Needs tests: | no | Patch needs improvement: | no |
Easy pickings: | no | UI/UX: | no |
Description
The _meta API migration guide for Django 1.8 shows a replacement for _meta.get_all_related_objects() that isn't quite right when used on a multi-table inheritance child model.
class Party(): is_active = models.BooleanField(default=True) class Contact(Party): first_name = models.CharField(max_length=128) last_name = models.CharField(max_length=128)
[f for f in Contact._meta.get_all_related_objects()] ... [] [f for f in Contact._meta.get_fields() if (f.one_to_many or f.one_to_one) and f.auto_created] ... [<django.db.models.fields.related.OneToOneField: party_ptr>]
The _meta.get_all_related_objects() method would return nothing assuming no other external relations but the replacement method would return the automatically created OneToOneField pointing to the parent. Maybe changing the docs to use is_concrete would work, unless this causes other problems?
[f for f in Contact._meta.get_all_related_objects()] ... [] [f for f in Contact._meta.get_fields() if (f.one_to_many or f.one_to_one) and f.auto_created and not f.concrete] ... []
Change History (12)
comment:1 by , 9 years ago
Summary: | Model _meta API Migration Guide → Mistake in model _meta API migration guide for multi-table inheritance |
---|---|
Triage Stage: | Unreviewed → Accepted |
comment:2 by , 9 years ago
comment:3 by , 9 years ago
Cc: | added |
---|
comment:4 by , 9 years ago
Yes, unfortunately I don't think we have any tests for the upgrade guide (they would likely be in tests/model_meta
), so I'm hesitant to make the change for fear that it might break another case.
comment:5 by , 9 years ago
I wanted to add the compatibility functions described in the upgrade guide in one of my libraries to avoid copy/pasting this code in different packages, and cover them with unit tests.
Do you think it makes sense to write a unit test for each situation (each field "type", normal and reverse situations, inheritance, ...), or a big one that will contains all field types / all situations in one go?
If I can write them in a way that can be helpful for Django, it could be nice.
comment:6 by , 9 years ago
I don't think we'll need to add the tests in Django since the old APIs are removed in master at this point. I guess we can just update the docs and see if any other reports come in.
About replicating the old APIs in a compatibility library, I understand the rationale, but I'm not highly enthusiastic about it for the reason pointed out in the docs:
Although it’s possible to make strictly equivalent replacements of the old methods, that might not be the best approach. Taking the time to refactor any field loops to make better use of the new API - and possibly include fields that were previously excluded - will almost certainly result in better code
The compatibility library would only be needed for Django 1.7 which is unsupported.
comment:7 by , 9 years ago
Thanks for the explanation, it makes totally sense to not add these tests in Django.
Just to give you a bit of context why I wanted to create this backward-compatible library, I had to handle a Django upgrade from 1.4 to 1.8 on a big project, and I decided to make this project compatible between 1.4 and 1.X.
It made the whole process way easier by merging small chunks of upgrades (if interested, I described my strategy there: http://romgar.github.io/presentations/django_upgrade/).
And I thought it could have been helpful for other people in this kind of situation.
comment:8 by , 9 years ago
Has patch: | set |
---|
We just encountered that issue in
django-deep-collector
project.The proposed change seems to fix it.
What do you need to resolve this ticket?
Updating the documentation, adding some tests?