From fc1446073ed9636047c48796cc20772ab60e12b0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Petr=20=C4=8Cerm=C3=A1k?= Date: Tue, 8 Sep 2020 16:21:41 +0200 Subject: [PATCH] Fixed #31987 -- Fixed Cast() with DurationField on MySQL. --- django/db/backends/mysql/operations.py | 1 + tests/db_functions/comparison/test_cast.py | 10 ++++++++++ 2 files changed, 11 insertions(+) diff --git a/django/db/backends/mysql/operations.py b/django/db/backends/mysql/operations.py index 05523fcdbe..8d5d7bc866 100644 --- a/django/db/backends/mysql/operations.py +++ b/django/db/backends/mysql/operations.py @@ -29,6 +29,7 @@ class DatabaseOperations(BaseDatabaseOperations): 'PositiveBigIntegerField': 'unsigned integer', 'PositiveIntegerField': 'unsigned integer', 'PositiveSmallIntegerField': 'unsigned integer', + 'DurationField': 'signed integer', } cast_char_field_without_max_length = 'char' explain_prefix = 'EXPLAIN' diff --git a/tests/db_functions/comparison/test_cast.py b/tests/db_functions/comparison/test_cast.py index a286e467a0..18344fe656 100644 --- a/tests/db_functions/comparison/test_cast.py +++ b/tests/db_functions/comparison/test_cast.py @@ -65,6 +65,16 @@ class CastTests(TestCase): numbers = Author.objects.annotate(cast_int=Cast('alias', field_class())) self.assertEqual(numbers.get().cast_int, 1) + def test_cast_to_duration(self): + duration = datetime.timedelta(days=1, seconds=2, microseconds=3) + DTModel.objects.create(duration=duration) + dtm = DTModel.objects.annotate( + cast_duration=Cast('duration', models.DurationField()), + cast_neg_duration=Cast(-duration, models.DurationField()), + ).get() + self.assertEqual(dtm.cast_duration, duration) + self.assertEqual(dtm.cast_neg_duration, -duration) + def test_cast_from_db_datetime_to_date(self): dt_value = datetime.datetime(2018, 9, 28, 12, 42, 10, 234567) DTModel.objects.create(start_datetime=dt_value)