[issue23600] tizinfo.fromutc changed for tzinfo wih StdOffset=0, DstOffset=1

Peter J C Law report at bugs.python.org
Sat Mar 7 12:33:17 CET 2015


Peter J C Law added the comment:

Hi,

Sorry for the overkill demo. I've attached a much shorter version, the key portion of which seems to be that, for the case of UK summer time the timezone, the tzinfo's `dst()` and `utcoffset()` methods return the same value.

This results in the delta between the two (which my understanding suggests equates to the non-dst offset of the timezone) is zero (which is right).

The python implementations (both in datetime.py and in the docs) cope with this by checking the DST difference and applying this after the timezone adjustments have happened.

>From a look through the CPython implementation, it looks to me like it's checking the wrong value before applying the DST difference. Specifically, on line 3033 in Modules/_datetimemodule.c, it checks `delta` before applying the DST.

For the majority of timezones this happens to work since the standard offset is not 0 and it ends up doing the addition anyway (and no functionality is lost if the DST value is 0).

Having tested changing the checked value to being dst rather than delta this does appear to fix this and all the existing tests still pass.

Peter

----------
Added file: http://bugs.python.org/file38372/time_issues.py

_______________________________________
Python tracker <report at bugs.python.org>
<http://bugs.python.org/issue23600>
_______________________________________


More information about the Python-bugs-list mailing list