Opened 6 weeks ago

Last modified 2 weeks ago

#36523 assigned Cleanup/optimization

Implement helper method to find module path of value

Reported by: Jake Howard Owned by: shrutisachan08
Component: Utilities Version: dev
Severity: Normal Keywords:
Cc: Jake Howard Triage Stage: Someday/Maybe
Has patch: no Needs documentation: no
Needs tests: no Patch needs improvement: no
Easy pickings: no UI/UX: no

Description

Finding the module path for where a given class or function is defined is functionality used in a few places across the Django codebase. Whilst in the majority of cases, f"{val.__module__}.{val.__qualname__}" is enough, there are some cases it's not.

As part of #35859, a few more cases of this pattern are being added to the codebase. I think we're now at the [point https://en.wikipedia.org/wiki/Rule_of_three_(computer_programming)] where it makes sense to extract this out to a helper function somewhere in django.utils. The implementation in django.migrations.serializer.TypeSerializer seems to be the most robust, however will want some more thorough testing based on different input types.

Change History (4)

comment:1 by Jake Howard, 6 weeks ago

Probably worth holding off on this ticket until #35859 is merged, so all uses can be covered.

comment:2 by Natalia Bidart, 6 weeks ago

Component: UncategorizedUtilities
Easy pickings: unset
Triage Stage: UnreviewedSomeday/Maybe
Version: dev

Thank you Jake for creating the ticket. Could please enumerate the locations of where this functionality is found?

comment:3 by shrutisachan08, 4 weeks ago

Owner: set to shrutisachan08
Status: newassigned
Version 0, edited 4 weeks ago by shrutisachan08 (next)

comment:4 by Jake Howard, 2 weeks ago

Cc: Jake Howard added

That sounds like the right approach to me - thanks for picking this up!

Note: See TracTickets for help on using tickets.
Back to Top