1
0
mirror of https://github.com/django/django.git synced 2025-10-24 14:16:09 +00:00

Fixed #24486 -- Fixed error with datetime and DurationField arithmetic

This commit is contained in:
Josh Smeaton
2015-03-16 15:51:23 +11:00
committed by Tim Graham
parent 81c2d9f60b
commit ff2aa40192
2 changed files with 15 additions and 5 deletions

View File

@@ -398,9 +398,10 @@ class DurationExpression(Expression):
output = side.output_field output = side.output_field
except FieldError: except FieldError:
pass pass
if output.get_internal_type() == 'DurationField': else:
sql, params = compiler.compile(side) if output.get_internal_type() == 'DurationField':
return connection.ops.format_for_duration_arithmetic(sql), params sql, params = compiler.compile(side)
return connection.ops.format_for_duration_arithmetic(sql), params
return compiler.compile(side) return compiler.compile(side)
def as_sql(self, compiler, connection): def as_sql(self, compiler, connection):

View File

@@ -617,8 +617,8 @@ class ExpressionOperatorTests(TestCase):
class FTimeDeltaTests(TestCase): class FTimeDeltaTests(TestCase):
def setUp(self): def setUp(self):
sday = datetime.date(2010, 6, 25) self.sday = sday = datetime.date(2010, 6, 25)
stime = datetime.datetime(2010, 6, 25, 12, 15, 30, 747000) self.stime = stime = datetime.datetime(2010, 6, 25, 12, 15, 30, 747000)
midnight = datetime.time(0) midnight = datetime.time(0)
delta0 = datetime.timedelta(0) delta0 = datetime.timedelta(0)
@@ -821,6 +821,15 @@ class FTimeDeltaTests(TestCase):
Experiment.objects.filter(estimated_time__lt=F('end') - F('start'))] Experiment.objects.filter(estimated_time__lt=F('end') - F('start'))]
self.assertEqual(over_estimate, ['e4']) self.assertEqual(over_estimate, ['e4'])
def test_duration_with_datetime(self):
# Exclude e1 which has very high precision so we can test this on all
# backends regardless of whether or not it supports
# microsecond_precision.
over_estimate = Experiment.objects.exclude(name='e1').filter(
completed__gt=self.stime + F('estimated_time'),
).order_by('name')
self.assertQuerysetEqual(over_estimate, ['e3', 'e4'], lambda e: e.name)
class ValueTests(TestCase): class ValueTests(TestCase):
def test_update_TimeField_using_Value(self): def test_update_TimeField_using_Value(self):