mirror of
https://github.com/django/django.git
synced 2025-01-20 15:19:20 +00:00
Refs #31894 -- Added tests for JSONField key lookups with QuerySet.exclude().
This commit is contained in:
parent
fd209f62f1
commit
94e2238107
@ -275,7 +275,7 @@ class TestQuerying(TestCase):
|
|||||||
'n': [None],
|
'n': [None],
|
||||||
},
|
},
|
||||||
[1, [2]],
|
[1, [2]],
|
||||||
{'k': True, 'l': False},
|
{'k': True, 'l': False, 'foo': 'bax'},
|
||||||
{
|
{
|
||||||
'foo': 'bar',
|
'foo': 'bar',
|
||||||
'baz': {'a': 'b', 'c': 'd'},
|
'baz': {'a': 'b', 'c': 'd'},
|
||||||
@ -616,6 +616,52 @@ class TestQuerying(TestCase):
|
|||||||
)
|
)
|
||||||
self.assertIs(NullableJSONModel.objects.filter(value__c__lt=5).exists(), False)
|
self.assertIs(NullableJSONModel.objects.filter(value__c__lt=5).exists(), False)
|
||||||
|
|
||||||
|
def test_lookup_exclude(self):
|
||||||
|
tests = [
|
||||||
|
(Q(value__a='b'), [self.objs[0]]),
|
||||||
|
(Q(value__foo='bax'), [self.objs[0], self.objs[7]]),
|
||||||
|
]
|
||||||
|
for condition, expected in tests:
|
||||||
|
self.assertSequenceEqual(
|
||||||
|
NullableJSONModel.objects.exclude(condition),
|
||||||
|
expected,
|
||||||
|
)
|
||||||
|
self.assertSequenceEqual(
|
||||||
|
NullableJSONModel.objects.filter(~condition),
|
||||||
|
expected,
|
||||||
|
)
|
||||||
|
|
||||||
|
def test_lookup_exclude_nonexistent_key(self):
|
||||||
|
# Values without the key are ignored.
|
||||||
|
condition = Q(value__foo='bax')
|
||||||
|
objs_with_value = [self.objs[6]]
|
||||||
|
objs_with_different_value = [self.objs[0], self.objs[7]]
|
||||||
|
self.assertSequenceEqual(
|
||||||
|
NullableJSONModel.objects.exclude(condition),
|
||||||
|
objs_with_different_value,
|
||||||
|
)
|
||||||
|
self.assertSequenceEqual(
|
||||||
|
NullableJSONModel.objects.exclude(~condition),
|
||||||
|
objs_with_value,
|
||||||
|
)
|
||||||
|
self.assertCountEqual(
|
||||||
|
NullableJSONModel.objects.filter(condition | ~condition),
|
||||||
|
objs_with_value + objs_with_different_value,
|
||||||
|
)
|
||||||
|
self.assertCountEqual(
|
||||||
|
NullableJSONModel.objects.exclude(condition & ~condition),
|
||||||
|
objs_with_value + objs_with_different_value,
|
||||||
|
)
|
||||||
|
# Add the __isnull lookup to get an exhaustive set.
|
||||||
|
self.assertSequenceEqual(
|
||||||
|
NullableJSONModel.objects.exclude(condition & Q(value__foo__isnull=False)),
|
||||||
|
self.objs[0:6] + self.objs[7:],
|
||||||
|
)
|
||||||
|
self.assertSequenceEqual(
|
||||||
|
NullableJSONModel.objects.filter(condition & Q(value__foo__isnull=False)),
|
||||||
|
objs_with_value,
|
||||||
|
)
|
||||||
|
|
||||||
@skipIf(
|
@skipIf(
|
||||||
connection.vendor == 'oracle',
|
connection.vendor == 'oracle',
|
||||||
'Raises ORA-00600: internal error code on Oracle 18.',
|
'Raises ORA-00600: internal error code on Oracle 18.',
|
||||||
|
Loading…
x
Reference in New Issue
Block a user