From d3a64bea51676fcf8a0ae593cf7b103939e12c87 Mon Sep 17 00:00:00 2001 From: Mariusz Felisiak Date: Sat, 4 Dec 2021 15:55:03 +0100 Subject: [PATCH] Refs #33333 -- Fixed PickleabilityTestCase.test_annotation_with_callable_default() crash on Oracle. Grouping by LOBs is not allowed on Oracle. This moves a binary field to a separate model. --- tests/queryset_pickle/models.py | 3 +++ tests/queryset_pickle/tests.py | 8 +++++--- 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/tests/queryset_pickle/models.py b/tests/queryset_pickle/models.py index 9a033ffe953..f780dc2a18f 100644 --- a/tests/queryset_pickle/models.py +++ b/tests/queryset_pickle/models.py @@ -46,6 +46,9 @@ class Happening(models.Model): number1 = models.IntegerField(blank=True, default=standalone_number) number2 = models.IntegerField(blank=True, default=Numbers.get_static_number) event = models.OneToOneField(Event, models.CASCADE, null=True) + + +class BinaryFieldModel(models.Model): data = models.BinaryField(null=True) diff --git a/tests/queryset_pickle/tests.py b/tests/queryset_pickle/tests.py index 60d30cd8ced..1d47f13c7de 100644 --- a/tests/queryset_pickle/tests.py +++ b/tests/queryset_pickle/tests.py @@ -5,7 +5,9 @@ import django from django.db import models from django.test import TestCase -from .models import Container, Event, Group, Happening, M2MModel, MyEvent +from .models import ( + BinaryFieldModel, Container, Event, Group, Happening, M2MModel, MyEvent, +) class PickleabilityTestCase(TestCase): @@ -17,8 +19,8 @@ class PickleabilityTestCase(TestCase): self.assertEqual(list(pickle.loads(pickle.dumps(qs))), list(qs)) def test_binaryfield(self): - Happening.objects.create(data=b'binary data') - self.assert_pickles(Happening.objects.all()) + BinaryFieldModel.objects.create(data=b'binary data') + self.assert_pickles(BinaryFieldModel.objects.all()) def test_related_field(self): g = Group.objects.create(name="Ponies Who Own Maybachs")