Opened 14 years ago
Closed 14 years ago
#16159 closed Bug (duplicate)
ModelForm does not catch unique error with model inheritance of more than 2 levels
| Reported by: | mturtle | Owned by: | nobody | 
|---|---|---|---|
| Component: | Database layer (models, ORM) | Version: | 1.2 | 
| Severity: | Normal | Keywords: | unique constraint, ModelForm, inheritance | 
| Cc: | Triage Stage: | Unreviewed | |
| Has patch: | no | Needs documentation: | no | 
| Needs tests: | no | Patch needs improvement: | no | 
| Easy pickings: | no | UI/UX: | no | 
Description
Ticket #12881 describes the main problem, which was partially fixed. However, when you have a larger inheritance hierarchy, the form doesn't catch it in the validation, and instead a unique constraint error is raised by postgres.
The culprit:
class A(Model):
    username = CharField(max_length=255, unique=True)
class B(A):
    pass
class C(B):
    pass
(Note C extends B, and B extends A.)
In Django 1.2.5 in django/db/models/base.py, around line 762, I see the following:
        fields_with_class = [(self.__class__, self._meta.local_fields)]
        for parent_class in self._meta.parents.keys():
            fields_with_class.append((parent_class, parent_class._meta.local_fields))
When I change self._meta.parents.keys() to include the entire chain of superclasses, the problem is fixed. I don't know the best-practice way of calculating the chain of superclasses up to but not including Model, but my dirty hack method of demonstrating this is by changing self._meta.parents.keys() to self._meta.get_base_chain(type(self).__bases__[0].__bases__[0])
This #15321, I believe.