From 326398143dd920419dcd2e365cf93131b2e688d2 Mon Sep 17 00:00:00 2001 From: Andrew Godwin Date: Fri, 17 Jan 2014 10:45:31 +0000 Subject: [PATCH] Fixed #21785: Bad handling of both auto_now and _add on deconstruct --- django/db/models/fields/__init__.py | 3 +-- tests/field_deconstruction/tests.py | 6 ++++++ 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/django/db/models/fields/__init__.py b/django/db/models/fields/__init__.py index d3baa876c8..7ace8878aa 100644 --- a/django/db/models/fields/__init__.py +++ b/django/db/models/fields/__init__.py @@ -907,10 +907,9 @@ class DateField(Field): name, path, args, kwargs = super(DateField, self).deconstruct() if self.auto_now: kwargs['auto_now'] = True - del kwargs['editable'] - del kwargs['blank'] if self.auto_now_add: kwargs['auto_now_add'] = True + if self.auto_now or self.auto_now_add: del kwargs['editable'] del kwargs['blank'] return name, path, args, kwargs diff --git a/tests/field_deconstruction/tests.py b/tests/field_deconstruction/tests.py index 49bc57f8f1..cb78003318 100644 --- a/tests/field_deconstruction/tests.py +++ b/tests/field_deconstruction/tests.py @@ -96,6 +96,12 @@ class FieldDeconstructionTests(TestCase): self.assertEqual(path, "django.db.models.DateTimeField") self.assertEqual(args, []) self.assertEqual(kwargs, {"auto_now_add": True}) + # Bug #21785 + field = models.DateTimeField(auto_now=True, auto_now_add=True) + name, path, args, kwargs = field.deconstruct() + self.assertEqual(path, "django.db.models.DateTimeField") + self.assertEqual(args, []) + self.assertEqual(kwargs, {"auto_now_add": True, "auto_now": True}) def test_decimal_field(self): field = models.DecimalField(max_digits=5, decimal_places=2)