bug49649_1.phpt 896 B

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. --TEST--
  2. Bug #49649 (unserialize() doesn't handle changes in property visibility) - to protected
  3. --FILE--
  4. <?php
  5. /**
  6. *class Foo
  7. *{
  8. * private $private = 1;
  9. *
  10. * protected $protected = 2;
  11. *
  12. * public $public = 3;
  13. *
  14. * public $notThere = 'old';
  15. * }
  16. *
  17. * echo base64_encode(serialize(new Foo()));
  18. *
  19. * The class above represents the serialized, base64_encoded string below.
  20. */
  21. $serialized = 'TzozOiJGb28iOjQ6e3M6MTI6IgBGb28AcHJpdmF0ZSI7aToxO3M6MTI6IgAqAHByb3RlY3RlZCI7aToyO3M6NjoicHVibGljIjtpOjM7czo4OiJub3RUaGVyZSI7czozOiJvbGQiO30';
  22. class Foo
  23. {
  24. protected $public = null;
  25. protected $protected = null;
  26. protected $private = null;
  27. }
  28. $class = unserialize(base64_decode($serialized));
  29. var_dump($class);
  30. ?>
  31. --EXPECT--
  32. object(Foo)#1 (4) {
  33. ["public":protected]=>
  34. int(3)
  35. ["protected":protected]=>
  36. int(2)
  37. ["private":protected]=>
  38. int(1)
  39. ["notThere"]=>
  40. string(3) "old"
  41. }