Opened 4 months ago
Last modified 3 months 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 , 4 months ago
comment:2 by , 4 months ago
| Component: | Uncategorized → Utilities |
|---|---|
| Easy pickings: | unset |
| Triage Stage: | Unreviewed → Someday/Maybe |
| Version: | → dev |
Thank you Jake for creating the ticket. Could please enumerate the locations of where this functionality is found?
comment:3 by , 3 months ago
| Owner: | set to |
|---|---|
| Status: | new → assigned |
comment:4 by , 3 months ago
| Cc: | added |
|---|
That sounds like the right approach to me - thanks for picking this up!
Probably worth holding off on this ticket until #35859 is merged, so all uses can be covered.