]> granicus.if.org Git - python/commitdiff
Closes #15925: fix regression in parsedate() and parsedate_tz() that should return...
authorGeorg Brandl <georg@python.org>
Sat, 22 Sep 2012 07:03:56 +0000 (09:03 +0200)
committerGeorg Brandl <georg@python.org>
Sat, 22 Sep 2012 07:03:56 +0000 (09:03 +0200)
Lib/email/_parseaddr.py
Lib/email/utils.py
Lib/test/test_email/test_email.py
Misc/NEWS

index 3528d0297c82fe3db7873bd96633adce6e30542e..cdfa3729adc79efa0b8fc2cf972a76f301c24fdb 100644 (file)
@@ -48,6 +48,8 @@ def parsedate_tz(data):
     Accounts for military timezones.
     """
     res = _parsedate_tz(data)
+    if not res:
+        return
     if res[9] is None:
         res[9] = 0
     return tuple(res)
@@ -62,6 +64,8 @@ def _parsedate_tz(data):
     source timezone really was UTC.
 
     """
+    if not data:
+        return
     data = data.split()
     # The FWS after the comma after the day-of-week is optional, so search and
     # adjust for this.
index 73bc3481d637779cb9f3badf20368ae6b67d9840..6b6d7f4474479ef303b55131e1ee00deca82f605 100644 (file)
@@ -37,10 +37,7 @@ from email._parseaddr import quote
 from email._parseaddr import AddressList as _AddressList
 from email._parseaddr import mktime_tz
 
-# We need wormarounds for bugs in these methods in older Pythons (see below)
-from email._parseaddr import parsedate as _parsedate
-from email._parseaddr import parsedate_tz as _parsedate_tz
-from email._parseaddr import _parsedate_tz as __parsedate_tz
+from email._parseaddr import parsedate, parsedate_tz, _parsedate_tz
 
 from quopri import decodestring as _qdecode
 
@@ -222,25 +219,8 @@ def make_msgid(idstring=None, domain=None):
     return msgid
 
 
-
-# These functions are in the standalone mimelib version only because they've
-# subsequently been fixed in the latest Python versions.  We use this to worm
-# around broken older Pythons.
-def parsedate(data):
-    if not data:
-        return None
-    return _parsedate(data)
-
-
-def parsedate_tz(data):
-    if not data:
-        return None
-    return _parsedate_tz(data)
-
 def parsedate_to_datetime(data):
-    if not data:
-        return None
-    *dtuple, tz = __parsedate_tz(data)
+    *dtuple, tz = _parsedate_tz(data)
     if tz is None:
         return datetime.datetime(*dtuple[:6])
     return datetime.datetime(*dtuple[:6],
index 5cc6d0467ee84f52cfd4e266f889fd3c9f610deb..36c344f846be8f8550880ca06b06296ca22ce098 100644 (file)
@@ -2718,8 +2718,17 @@ class TestMiscellaneous(TestEmailBase):
             utils.formatdate(now, localtime=False, usegmt=True),
             time.strftime('%a, %d %b %Y %H:%M:%S GMT', time.gmtime(now)))
 
-    def test_parsedate_none(self):
-        self.assertEqual(utils.parsedate(''), None)
+    # parsedate and parsedate_tz will become deprecated interfaces someday
+    def test_parsedate_returns_None_for_invalid_strings(self):
+        self.assertIsNone(utils.parsedate(''))
+        self.assertIsNone(utils.parsedate_tz(''))
+        self.assertIsNone(utils.parsedate('0'))
+        self.assertIsNone(utils.parsedate_tz('0'))
+        self.assertIsNone(utils.parsedate('A Complete Waste of Time'))
+        self.assertIsNone(utils.parsedate_tz('A Complete Waste of Time'))
+        # Not a part of the spec but, but this has historically worked:
+        self.assertIsNone(utils.parsedate(None))
+        self.assertIsNone(utils.parsedate_tz(None))
 
     def test_parsedate_compact(self):
         # The FWS after the comma is optional
index b9cb2fec49a5aec67f52f8ad6457665507d542ec..05941528150773c77cc9856c67831c66a1f1f671 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -22,6 +22,10 @@ Library
   with decimal.py: Infinity coefficients are undefined in _decimal
   (in accordance with the specification).
 
+- Issue #15925: Fix a regression in email.util where the parsedate() and
+  parsedate_tz() functions did not return None anymore when the argument could
+  not be parsed.
+
 Extension Modules
 -----------------