3v4l.org

run code in 150+ php & hhvm versions
Bugs & Features
<?php $s1 = 'O:8:"DateTime":3:{s:4:"date";s:20:"10007-06-07 03:51:49";s:13:"timezone_type";i:3;s:8:"timezone";s:3:"UTC";}'; $s2 = 'O:3:"Foo":3:{s:4:"date";s:20:"10007-06-07 03:51:49";s:13:"timezone_type";i:3;s:8:"timezone";s:3:"UTC";}'; global $foo; class Foo extends DateTime { function __wakeup() { global $foo; $foo = $this; parent::__wakeup(); } } // Old test case try { unserialize( $s1 ); } catch ( Exception $e ) {} // My test case try { unserialize( $s2 ); } catch ( Exception $e ) { var_dump($e); } //var_dump( $foo );
Output for 7.1.0
Fatal error: Uncaught Error: Invalid serialization data for DateTime object in /in/NYSK2:18 Stack trace: #0 [internal function]: DateTime->__wakeup() #1 /in/NYSK2(18): unserialize('O:8:"DateTime":...') #2 {main} thrown in /in/NYSK2 on line 18
Process exited with code 255.
Output for 5.3.24 - 5.3.29, 5.4.14 - 5.6.21, 7.0.0 - 7.0.14
Fatal error: Invalid serialization data for DateTime object in /in/NYSK2 on line 18
Process exited with code 255.
Output for hhvm-3.12.0
object(Exception)#6 (7) { ["message":protected]=> string(121) "DateTime::__construct(): Failed to parse time string (10007-06-07 03:51:49) at position 12 (0): Double time specification" ["string":"Exception":private]=> string(0) "" ["code":protected]=> int(0) ["file":protected]=> string(9) "/in/NYSK2" ["line":protected]=> int(12) ["trace":"Exception":private]=> array(2) { [0]=> array(6) { ["file"]=> string(9) "/in/NYSK2" ["line"]=> int(12) ["function"]=> string(8) "__wakeup" ["class"]=> string(8) "DateTime" ["type"]=> string(2) "->" ["args"]=> array(0) { } } [1]=> array(6) { ["file"]=> string(9) "/in/NYSK2" ["line"]=> int(23) ["function"]=> string(8) "__wakeup" ["class"]=> string(3) "Foo" ["type"]=> string(2) "->" ["args"]=> array(0) { } } } ["previous":"Exception":private]=> NULL }
Output for hhvm-3.10.0
object(Exception)#6 (7) { ["message":protected]=> string(121) "DateTime::__construct(): Failed to parse time string (10007-06-07 03:51:49) at position 12 (0): Double time specification" ["string":"Exception":private]=> string(0) "" ["code":protected]=> int(0) ["file":protected]=> string(9) "/in/NYSK2" ["line":protected]=> int(-1) ["trace":"Exception":private]=> array(2) { [0]=> array(6) { ["file"]=> string(9) "/in/NYSK2" ["line"]=> int(-1) ["function"]=> string(8) "__wakeup" ["class"]=> string(8) "DateTime" ["type"]=> string(2) "->" ["args"]=> array(0) { } } [1]=> array(6) { ["file"]=> string(9) "/in/NYSK2" ["line"]=> int(-1) ["function"]=> string(8) "__wakeup" ["class"]=> string(3) "Foo" ["type"]=> string(2) "->" ["args"]=> array(0) { } } } ["previous":"Exception":private]=> NULL }
Output for 5.3.0 - 5.3.16, 5.3.18 - 5.3.23, 5.4.0 - 5.4.6, 5.4.8 - 5.4.13
Output for 5.3.17, 5.4.7
object(Exception)#4 (8) { ["message":protected]=> string(118) "DateTime::__wakeup(): Failed to parse time string (10007-06-07 03:51:49) at position 12 (0): Double time specification" ["string":"Exception":private]=> string(0) "" ["code":protected]=> int(0) ["file":protected]=> string(9) "/in/NYSK2" ["line":protected]=> int(12) ["trace":"Exception":private]=> array(3) { [0]=> array(6) { ["file"]=> string(9) "/in/NYSK2" ["line"]=> int(12) ["function"]=> string(8) "__wakeup" ["class"]=> string(8) "DateTime" ["type"]=> string(2) "->" ["args"]=> array(0) { } } [1]=> array(4) { ["function"]=> string(8) "__wakeup" ["class"]=> string(3) "Foo" ["type"]=> string(2) "->" ["args"]=> array(0) { } } [2]=> array(4) { ["file"]=> string(9) "/in/NYSK2" ["line"]=> int(23) ["function"]=> string(11) "unserialize" ["args"]=> array(1) { [0]=> string(103) "O:3:"Foo":3:{s:4:"date";s:20:"10007-06-07 03:51:49";s:13:"timezone_type";i:3;s:8:"timezone";s:3:"UTC";}" } } } ["previous":"Exception":private]=> NULL ["severity"]=> int(2) }
Output for 5.2.0 - 5.2.17
Fatal error: Call to undefined method DateTime::__wakeup() in /in/NYSK2 on line 12
Process exited with code 255.
Output for 5.0.0 - 5.0.5, 5.1.1 - 5.1.6
Fatal error: Class 'DateTime' not found in /in/NYSK2 on line 8
Process exited with code 255.
Output for 5.1.0
Fatal error: fatal flex scanner internal error--end of buffer missed in /in/NYSK2 on line 27
Process exited with code 255.
Output for 4.4.2 - 4.4.9
Parse error: syntax error, unexpected '{' in /in/NYSK2 on line 17
Process exited with code 255.
Output for 4.3.0 - 4.3.1, 4.3.5 - 4.4.1
Parse error: parse error, unexpected '{' in /in/NYSK2 on line 17
Process exited with code 255.
Output for 4.3.2 - 4.3.4
Parse error: parse error in /in/NYSK2 on line 17
Process exited with code 255.