Edit report at https://bugs.php.net/bug.php?id=52143&edit=1
ID: 52143 Comment by: sonnenberg at gmail dot com Reported by: jason dot woods at blueyonder dot co dot uk Summary: strtotime() unexpectedly changed from 5.2.13 to 5.3.2 breaking alot of scripts Status: Open Type: Bug Package: Date/time related Operating System: CentOS 5.5 x86_64 PHP Version: 5.3.2 Block user comment: N Private report: N New Comment: I have a similar problem, but I'm calculating with weeks and am getting inconsistent results. Test script: ------------ <?php echo strftime("%Y %W", strtotime("-1 week", strtotime("2013W01"))) . "\n"; echo strftime("%Y %W", strtotime("+1 week", strtotime("2012W52"))) . "\n"; echo gmdate("Y W", strtotime("2012W53")) . "\n"; echo strftime("%Y %W", strtotime("2012W53")) . "\n"; echo date("Y W", strtotime("2012W53")) . "\n"; ?> Expected result: ---------------- 2012 53 2012 53 2012 53 2012 53 2012 53 Actual result: -------------- 2012 52 2012 53 2012 52 2012 53 2012 01 - this one is particulary interesting... I've tried different timezones, but that does not seem to affect this issue as I get the same output for all timezones. php version: ------------ PHP 5.3.10-1ubuntu3.4 with Suhosin-Patch (cli) (built: Sep 12 2012 18:59:41) Copyright (c) 1997-2012 The PHP Group Zend Engine v2.3.0, Copyright (c) 1998-2012 Zend Technologies with Xdebug v2.2.1, Copyright (c) 2002-2012, by Derick Rethans Previous Comments: ------------------------------------------------------------------------ [2010-09-27 10:49:30] der...@php.net The new behaviour is correct; this was a bug fix. ------------------------------------------------------------------------ [2010-09-24 02:57:19] kkcagg at gmail dot com Bug also shows up in PHP version 5.3.3. It seems to be normalizing the value to the Monday of the target week. For example: strtotime('next week') would be equivalent to strtotime('Monday next week') instead of the expected value of the current time plus the number of seconds in a week. ------------------------------------------------------------------------ [2010-06-22 13:01:38] jason dot woods at blueyonder dot co dot uk Description: ------------ In version 5.2.13 the following code: <?php echo ($now = strtotime('+1 day')) . ' - ' . date('d-m-Y H.i.s', $now) . "\n"; echo ($last = strtotime('last week', $now)) . ' - ' . date('d-m-Y H.i.s', $last) . "\n"; echo ($next = strtotime('+1 week', $last)) . ' - ' . date('d-m-Y H.i.s', $next) . "\n"; ?> Gives the following result: 1277283067 - 23-06-2010 09.51.07 1276678267 - 16-06-2010 09.51.07 1277283067 - 23-06-2010 09.51.07 That is, first line is current time. Second time is "last week", otherwise known as "-1 week". Third time is "+1 week", which reverses the change that the "-1 week" did. However, this changed in 5.3.2 and it now gives the following result: 1277281904 - 23-06-2010 09.31.44 1276504304 - 14-06-2010 09.31.44 1277109104 - 21-06-2010 09.31.44 So it appears "last week" is no longer the equivalent of "-1 week". Is this a deliberate change or something that was broken in 5.3.2? I have been unable to test other versions and can only give you the difference from 5.2.13 and 5.3.2. Thanks. Test script: --------------- <?php echo ($now = strtotime('+1 day')) . ' - ' . date('d-m-Y H.i.s', $now) . "\n"; echo ($last = strtotime('last week', $now)) . ' - ' . date('d-m-Y H.i.s', $last) . "\n"; echo ($next = strtotime('+1 week', $last)) . ' - ' . date('d-m-Y H.i.s', $next) . "\n"; ?> Expected result: ---------------- 1277283067 - 23-06-2010 09.51.07 1276678267 - 16-06-2010 09.51.07 1277283067 - 23-06-2010 09.51.07 Actual result: -------------- 1277281904 - 23-06-2010 09.31.44 1276504304 - 14-06-2010 09.31.44 1277109104 - 21-06-2010 09.31.44 ------------------------------------------------------------------------ -- Edit this bug report at https://bugs.php.net/bug.php?id=52143&edit=1