#29441 closed Cleanup/optimization (wontfix)
Allow dumpdata in YAML using ruamel.yaml rather than PyYaml.
Reported by: | Rémy Hubscher | Owned by: | Daniel Rios |
---|---|---|---|
Component: | Core (Serialization) | Version: | 2.0 |
Severity: | Normal | Keywords: | |
Cc: | Triage Stage: | Unreviewed | |
Has patch: | no | Needs documentation: | no |
Needs tests: | no | Patch needs improvement: | no |
Easy pickings: | no | UI/UX: | no |
Description
For some reason, ruamel.yaml is a recommanded lib for loading Yaml in Python.
However Django dumpdata command ask for PyYaml.
Could we consider having trying to use ruamel.yaml if PyYaml is not installed but ruamel.yaml is?
Change History (3)
comment:1 by , 7 years ago
Component: | Uncategorized → Core (Serialization) |
---|---|
Type: | Uncategorized → Cleanup/optimization |
comment:2 by , 7 years ago
Owner: | changed from | to
---|---|
Status: | new → assigned |
comment:3 by , 7 years ago
Resolution: | → wontfix |
---|---|
Status: | assigned → closed |
Hi.
First, reasons should be provided as to why something is recommended. In this case, ruaml is recommended because it is, as far as my research has taken me, the only other python yaml library out there.
The preference for the pyyaml module is baked into django/core/serializers/__init__.py
in the BUILTIN_SERIALIZERS
constant at https://github.com/django/django/blob/5cc81cd9eb69f5f7a711412c02039b435c393135/django/core/serializers/__init__.py#L26
I don't think it makes sense to have another built-in serializer. However, there is a workaround:
Django does offer the possibility to use your own serializer in the docstring of the same file (https://github.com/django/django/blob/5cc81cd9eb69f5f7a711412c02039b435c393135/django/core/serializers/__init__.py#L10), but the actual user-facing documentation seems to be nonexistent.
I was able to, however, overwrite the preference for pyyaml by installing ruamel and with SERIALIZATION_MODULES
in settings.py as follows:
SERIALIZATION_MODULES = { 'yaml': 'ruamel.yaml.serializer' }
I was unable to get it running because ruaml (even though based on pyyaml) is written a bit different to the way Django handles serializers but the fact that it does support other serializers means that it would be possible to get ruaml to work.
A better idea would be to create a third party package django-ruaml-serializer
that patches the differences in ruaml to work with the existing django serializer.
Recommended by who? What are the advantages of switching? Is it backwards compatible?