Skip to content

Commit

Permalink
Fixed #17937 -- Avoided an error in the timeuntil filter when it rece…
Browse files Browse the repository at this point in the history
…ives a date object. Thanks Dmitry Guyvoronsky for the report.

git-svn-id: http://code.djangoproject.com/svn/django/trunk@17774 bcc190cf-cafb-0310-a4f2-bffc1f526a37
  • Loading branch information
aaugustin committed Mar 22, 2012
1 parent 4219e2b commit 1e28567
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 8 deletions.
8 changes: 3 additions & 5 deletions django/utils/timesince.py
Expand Up @@ -3,7 +3,7 @@
from django.utils.timezone import is_aware, utc
from django.utils.translation import ungettext, ugettext

def timesince(d, now=None):
def timesince(d, now=None, reversed=False):
"""
Takes two datetime objects and returns the time between d and now
as a nicely formatted string, e.g. "10 minutes". If d occurs after now,
Expand Down Expand Up @@ -33,7 +33,7 @@ def timesince(d, now=None):
if not now:
now = datetime.datetime.now(utc if is_aware(d) else None)

delta = now - d
delta = (d - now) if reversed else (now - d)
# ignore microseconds
since = delta.days * 24 * 60 * 60 + delta.seconds
if since <= 0:
Expand All @@ -57,6 +57,4 @@ def timeuntil(d, now=None):
Like timesince, but returns a string measuring the time until
the given time.
"""
if not now:
now = datetime.datetime.now(utc if is_aware(d) else None)
return timesince(now, d)
return timesince(d, now, reversed=True)
12 changes: 9 additions & 3 deletions tests/regressiontests/utils/timesince.py
Expand Up @@ -99,12 +99,18 @@ def test_different_timezones(self):
self.assertEqual(timesince(now_tz), u'0 minutes')
self.assertEqual(timeuntil(now_tz, now_tz_i), u'0 minutes')

def test_date_objects(self):
""" Both timesince and timeuntil should work on date objects (#17937). """
today = datetime.date.today()
self.assertEqual(timesince(today + self.oneday), u'0 minutes')
self.assertEqual(timeuntil(today - self.oneday), u'0 minutes')

def test_both_date_objects(self):
""" Timesince should work with both date objects (#9672) """
today = datetime.date.today()
self.assertEqual(timeuntil(today+self.oneday, today), u'1 day')
self.assertEqual(timeuntil(today-self.oneday, today), u'0 minutes')
self.assertEqual(timeuntil(today+self.oneweek, today), u'1 week')
self.assertEqual(timeuntil(today + self.oneday, today), u'1 day')
self.assertEqual(timeuntil(today - self.oneday, today), u'0 minutes')
self.assertEqual(timeuntil(today + self.oneweek, today), u'1 week')

def test_naive_datetime_with_tzinfo_attribute(self):
class naive(datetime.tzinfo):
Expand Down

0 comments on commit 1e28567

Please sign in to comment.