mirror of
https://github.com/django/django.git
synced 2024-11-21 19:09:18 +01:00
Fixed #34539 -- Restored get_prep_value() call when adapting JSONFields.
Regression in 5c23d9f0c3
.
This commit is contained in:
parent
7414704e88
commit
0ec60661e6
1
AUTHORS
1
AUTHORS
@ -532,6 +532,7 @@ answer newbie questions, and generally made Django that much better:
|
||||
Julia Elman
|
||||
Julia Matsieva <julia.matsieva@gmail.com>
|
||||
Julian Bez
|
||||
Julie Rymer <rymerjulie.pro@gmail.com>
|
||||
Julien Phalip <jphalip@gmail.com>
|
||||
Junyoung Choi <cupjoo@gmail.com>
|
||||
junzhang.jn@gmail.com
|
||||
|
@ -99,6 +99,8 @@ class JSONField(CheckFieldDefaultMixin, Field):
|
||||
return "JSONField"
|
||||
|
||||
def get_db_prep_value(self, value, connection, prepared=False):
|
||||
if not prepared:
|
||||
value = self.get_prep_value(value)
|
||||
# RemovedInDjango51Warning: When the deprecation ends, replace with:
|
||||
# if (
|
||||
# isinstance(value, expressions.Value)
|
||||
|
@ -12,3 +12,6 @@ Bugfixes
|
||||
* Fixed a regression in Django 4.2 that caused an unnecessary
|
||||
``DBMS_LOB.SUBSTR()`` wrapping in the ``__isnull`` and ``__exact=None``
|
||||
lookups for ``TextField()``/``BinaryField()`` on Oracle (:ticket:`34544`).
|
||||
|
||||
* Restored, following a regression in Django 4.2, ``get_prep_value()`` call in
|
||||
``JSONField`` subclasses (:ticket:`34539`).
|
||||
|
@ -103,6 +103,29 @@ class TestMethods(SimpleTestCase):
|
||||
with self.assertRaisesMessage(TypeError, msg):
|
||||
KeyTransformTextLookupMixin(transform)
|
||||
|
||||
def test_get_prep_value(self):
|
||||
class JSONFieldGetPrepValue(models.JSONField):
|
||||
def get_prep_value(self, value):
|
||||
if value is True:
|
||||
return {"value": True}
|
||||
return value
|
||||
|
||||
def noop_adapt_json_value(value, encoder):
|
||||
return value
|
||||
|
||||
field = JSONFieldGetPrepValue()
|
||||
with mock.patch.object(
|
||||
connection.ops, "adapt_json_value", noop_adapt_json_value
|
||||
):
|
||||
self.assertEqual(
|
||||
field.get_db_prep_value(True, connection, prepared=False),
|
||||
{"value": True},
|
||||
)
|
||||
self.assertIs(
|
||||
field.get_db_prep_value(True, connection, prepared=True), True
|
||||
)
|
||||
self.assertEqual(field.get_db_prep_value(1, connection, prepared=False), 1)
|
||||
|
||||
|
||||
class TestValidation(SimpleTestCase):
|
||||
def test_invalid_encoder(self):
|
||||
|
Loading…
Reference in New Issue
Block a user