Commit e29bbfd4 authored by Lennart Regebro's avatar Lennart Regebro

Merged Zope/branches/regebro-strftime_1127 28397:28400; bugfix for issue #1127

parent d49c0671
...@@ -36,6 +36,8 @@ Zope Changes ...@@ -36,6 +36,8 @@ Zope Changes
Statistics view in the ZMI Statistics view in the ZMI
Bugs fixed Bugs fixed
- Collector #1127: strftime did not take timezone into account.
- ZPublisher: changed some hardcoded 'latin1' arguments to 'iso-8859-15' - ZPublisher: changed some hardcoded 'latin1' arguments to 'iso-8859-15'
since latin1 is obsolete. since latin1 is obsolete.
......
...@@ -1476,11 +1476,7 @@ class DateTime: ...@@ -1476,11 +1476,7 @@ class DateTime:
def strftime(self, format): def strftime(self, format):
# Format the date/time using the *current timezone representation*. # Format the date/time using the *current timezone representation*.
diff = _tzoffset(self._tz, self._t) return strftime(format, safelocaltime(self.timeTime()))
format = re.sub('(^\|[^%])%z',
'\\1%+05d' % (diff / 36),
format)
return strftime(format, safegmtime(self.timeTime() + diff))
# General formats from previous DateTime # General formats from previous DateTime
def Date(self): def Date(self):
......
...@@ -7,6 +7,7 @@ import os ...@@ -7,6 +7,7 @@ import os
import time import time
import unittest import unittest
from DateTime.DateTime import _findLocalTimeZoneName
from DateTime import DateTime from DateTime import DateTime
try: try:
...@@ -338,6 +339,16 @@ class DateTimeTests(unittest.TestCase): ...@@ -338,6 +339,16 @@ class DateTimeTests(unittest.TestCase):
except DateTime.TimeError: except DateTime.TimeError:
self.fail('Zope Collector issue #484 (negative time bug): ' self.fail('Zope Collector issue #484 (negative time bug): '
'TimeError raised') 'TimeError raised')
def testStrftimeTZhandling(self):
'''strftime timezone testing'''
# This is a test for collector issue #1127
format = '%Y-%m-%d %H:%M %Z'
dt = DateTime('Wed, 19 Nov 2003 18:32:07 -0215')
dt_string = dt.strftime(format)
dt_local = dt.toZone(_findLocalTimeZoneName(0))
dt_localstring = dt_local.strftime(format)
self.assertEqual(dt_string, dt_localstring)
def test_suite(): def test_suite():
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment