Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Warn (or solve) if there are duplicate child class field names #8

Closed
KrzysiekJ opened this issue Jun 26, 2013 · 2 comments · Fixed by #48
Closed

Warn (or solve) if there are duplicate child class field names #8

KrzysiekJ opened this issue Jun 26, 2013 · 2 comments · Fixed by #48

Comments

@KrzysiekJ
Copy link
Contributor

This issue is a copy of KrzysiekJ#1 by @mnieber.

The following does not work because the name "request_message" is duplicated in two child classes of the base class Message, which produces a conflict later on when querying the database.

class Message(TypedModel):
    pass

class AcceptMessage(Message):
    request_message = models.ForeignKey('self', null=True, blank=True, related_name='+')

class DeclineMessage(Message):
    request_message = models.ForeignKey('self', null=True, blank=True, related_name='+')

This can be solved by moving request_message to the base class but this is not always what you want (perhaps a third class inheriting from Message does not have a request_message field).

It would be nice if TypedModel would at least raise an exception in this case so that the programmer becomes aware of the problem.

@craigds
Copy link
Owner

craigds commented Jun 27, 2013

Perhaps it should work if the fields are exactly the same, but I don't know how we can reliably verify that... (f1.__dict__ == f2.__dict__ ?)

Otherwise this should definitely throw an error.

@craigds
Copy link
Owner

craigds commented Feb 27, 2018

Long time no speak, but since 2013 django's grown a reliable field serialisation and comparison scheme (for migrations) so this should be perfectly doable now.

If we find two fields exactly the same we can amalgamate them, and if they're different in any way but have the same name we can throw an error.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants