Edit report at https://bugs.php.net/bug.php?id=62185&edit=1

 ID:                 62185
 Comment by:         riptide dot tempora at opinehub dot com
 Reported by:        omg00dness at yahoo dot com
 Summary:            strtotime() returns incorrect time around DST
                     (America)
 Status:             Open
 Type:               Bug
 Package:            Date/time related
 Operating System:   Ubuntu
 PHP Version:        5.3.13
 Block user comment: N
 Private report:     N

 New Comment:

Improved test script:

<?php
date_default_timezone_set('America/Los_Angeles'); 
echo strtotime("2012-03-11 5:00:00 -1 hour") . "\t";
echo date("M j Y H:i:s I", strtotime("2012-03-11 5:00:00 -1 hour")) . "\n";
echo strtotime("2012-03-11 4:00:00 -1 hour") . "\t";
echo date("M j Y H:i:s I", strtotime("2012-03-11 4:00:00 -1 hour")) . "\n";
echo strtotime("2012-03-11 3:00:00 -1 hour") . "\t";
echo date("M j Y H:i:s I", strtotime("2012-03-11 3:00:00 -1 hour")) . "\n";
echo strtotime("2012-03-11 3:01:00 -1 hour") . "\t";
echo date("M j Y H:i:s I", strtotime("2012-03-11 3:01:00 -1 hour")) . "\n";
echo strtotime("2012-03-11 2:59:00 -1 hour") . "\t";
echo date("M j Y H:i:s I", strtotime("2012-03-11 2:59:00 -1 hour")) . "\n";
echo strtotime("2012-03-11 1:00:00 +1 hour") . "\t";
echo date("M j Y H:i:s I", strtotime("2012-03-11 1:00:00 +1 hour")) . "\n";
echo strtotime("2012-03-11 0:00:00 +1 hour") . "\t";
echo date("M j Y H:i:s I", strtotime("2012-03-11 0:00:00 +1 hour")) . "\n";
?>

My server produced (PHP Version 5.3.13):
1331463600      Mar 11 2012 04:00:00 1
1331460000      Mar 11 2012 03:00:00 1
1331460000      Mar 11 2012 03:00:00 1
1331460060      Mar 11 2012 03:01:00 1
1331459940      Mar 11 2012 01:59:00 0
1331460000      Mar 11 2012 03:00:00 1
1331456400      Mar 11 2012 01:00:00 0

http://www.alpha7f.com/phpt/bug62185.php


Previous Comments:
------------------------------------------------------------------------
[2012-05-29 23:07:58] omg00dness at yahoo dot com

Description:
------------
For an American timezone (at least those that observe Daylight Savings Time), 
strtotime() is outputting incorrectly when adding a negative time string.

Example uses March 11, 2012 at 2:00am, where the local time jumps instead to 
3:00am.

Test script:
---------------
<?php
date_default_timezone_set('America/Los_Angeles'); 
echo date("M j Y H:i:s I", strtotime("2012-03-11 5:00:00 -1 hour")) . "\n";
echo date("M j Y H:i:s I", strtotime("2012-03-11 4:00:00 -1 hour")) . "\n";
echo date("M j Y H:i:s I", strtotime("2012-03-11 3:00:00 -1 hour")) . "\n";
echo date("M j Y H:i:s I", strtotime("2012-03-11 3:01:00 -1 hour")) . "\n";
echo date("M j Y H:i:s I", strtotime("2012-03-11 2:59:00 -1 hour")) . "\n";
echo date("M j Y H:i:s I", strtotime("2012-03-11 1:00:00 +1 hour")) . "\n";
echo date("M j Y H:i:s I", strtotime("2012-03-11 0:00:00 +1 hour")) . "\n";
?>

Expected result:
----------------
Mar 11 2012 04:00:00 1
Mar 11 2012 03:00:00 1
Mar 11 2012 01:00:00 0
Mar 11 2012 01:01:00 0
Dec 31 1969 16:00:00 0 //Perhaps output false?
Mar 11 2012 03:00:00 1
Mar 11 2012 01:00:00 0

Actual result:
--------------
Mar 11 2012 04:00:00 1
Mar 11 2012 03:00:00 1
Mar 11 2012 03:00:00 1
Mar 11 2012 03:01:00 1
Mar 11 2012 01:59:00 0
Mar 11 2012 03:00:00 1
Mar 11 2012 01:00:00 0


------------------------------------------------------------------------



-- 
Edit this bug report at https://bugs.php.net/bug.php?id=62185&edit=1

Reply via email to