diff --git a/django/db/models/fields/__init__.py b/django/db/models/fields/__init__.py index 5f8f59d69f12..f15b5856bfb1 100644 --- a/django/db/models/fields/__init__.py +++ b/django/db/models/fields/__init__.py @@ -1595,10 +1595,13 @@ def to_python(self, value): # local time. This won't work during DST change, but we can't # do much about it, so we let the exceptions percolate up the # call stack. + try: + name = f"{self.model.__name__}.{self.name}" + except AttributeError: + name = "(unbound)" warnings.warn( - "DateTimeField %s.%s received a naive datetime " - "(%s) while time zone support is active." - % (self.model.__name__, self.name, value), + f"DateTimeField {name} received a naive datetime ({value}) while " + "time zone support is active.", RuntimeWarning, ) default_timezone = timezone.get_default_timezone() diff --git a/tests/timezones/tests.py b/tests/timezones/tests.py index 433c921cd383..c45f078ef63c 100644 --- a/tests/timezones/tests.py +++ b/tests/timezones/tests.py @@ -10,6 +10,7 @@ from django.core import serializers from django.db import connection from django.db.models import F, Max, Min +from django.db.models.functions import Now from django.http import HttpRequest from django.template import ( Context, @@ -327,6 +328,13 @@ def test_datetime_from_date(self): event = Event.objects.get() self.assertEqual(event.dt, datetime.datetime(2011, 9, 1, tzinfo=EAT)) + @requires_tz_support + def test_filter_unbound_datetime_with_naive_date(self): + dt = datetime.date(2011, 9, 1) + msg = "DateTimeField (unbound) received a naive datetime" + with self.assertWarnsMessage(RuntimeWarning, msg): + Event.objects.annotate(unbound_datetime=Now()).filter(unbound_datetime=dt) + @requires_tz_support def test_naive_datetime_with_microsecond(self): dt = datetime.datetime(2011, 9, 1, 13, 20, 30, 405060)