mirror of
https://github.com/django/django.git
synced 2025-10-24 14:16:09 +00:00
Refs #18247 -- Fixed SQLite QuerySet filtering on decimal result of Least and Greatest.
This commit is contained in:
committed by
Tim Graham
parent
d5977e492e
commit
068d75688f
@@ -49,3 +49,8 @@ class DTModel(models.Model):
|
||||
|
||||
def __str__(self):
|
||||
return 'DTModel({0})'.format(self.name)
|
||||
|
||||
|
||||
class DecimalModel(models.Model):
|
||||
n1 = models.DecimalField(decimal_places=2, max_digits=6)
|
||||
n2 = models.DecimalField(decimal_places=2, max_digits=6)
|
||||
|
@@ -1,4 +1,5 @@
|
||||
from datetime import datetime, timedelta
|
||||
from decimal import Decimal
|
||||
from unittest import skipIf, skipUnless
|
||||
|
||||
from django.db import connection
|
||||
@@ -11,7 +12,7 @@ from django.db.models.functions import (
|
||||
from django.test import TestCase, skipIfDBFeature, skipUnlessDBFeature
|
||||
from django.utils import timezone
|
||||
|
||||
from .models import Article, Author, Fan
|
||||
from .models import Article, Author, DecimalModel, Fan
|
||||
|
||||
|
||||
lorem_ipsum = """
|
||||
@@ -202,6 +203,15 @@ class FunctionTests(TestCase):
|
||||
author.refresh_from_db()
|
||||
self.assertEqual(author.alias, 'Jim')
|
||||
|
||||
def test_greatest_decimal_filter(self):
|
||||
obj = DecimalModel.objects.create(n1=Decimal('1.1'), n2=Decimal('1.2'))
|
||||
self.assertCountEqual(
|
||||
DecimalModel.objects.annotate(
|
||||
greatest=Greatest('n1', 'n2'),
|
||||
).filter(greatest=Decimal('1.2')),
|
||||
[obj],
|
||||
)
|
||||
|
||||
def test_least(self):
|
||||
now = timezone.now()
|
||||
before = now - timedelta(hours=1)
|
||||
@@ -297,6 +307,15 @@ class FunctionTests(TestCase):
|
||||
author.refresh_from_db()
|
||||
self.assertEqual(author.alias, 'James Smith')
|
||||
|
||||
def test_least_decimal_filter(self):
|
||||
obj = DecimalModel.objects.create(n1=Decimal('1.1'), n2=Decimal('1.2'))
|
||||
self.assertCountEqual(
|
||||
DecimalModel.objects.annotate(
|
||||
least=Least('n1', 'n2'),
|
||||
).filter(least=Decimal('1.1')),
|
||||
[obj],
|
||||
)
|
||||
|
||||
def test_concat(self):
|
||||
Author.objects.create(name='Jayden')
|
||||
Author.objects.create(name='John Smith', alias='smithj', goes_by='John')
|
||||
|
Reference in New Issue
Block a user