XmlSerializationTest.php 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. <?php
  2. /*
  3. * Copyright 2011 Johannes M. Schmitt <schmittjoh@gmail.com>
  4. *
  5. * Licensed under the Apache License, Version 2.0 (the "License");
  6. * you may not use this file except in compliance with the License.
  7. * You may obtain a copy of the License at
  8. *
  9. * http://www.apache.org/licenses/LICENSE-2.0
  10. *
  11. * Unless required by applicable law or agreed to in writing, software
  12. * distributed under the License is distributed on an "AS IS" BASIS,
  13. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. * See the License for the specific language governing permissions and
  15. * limitations under the License.
  16. */
  17. namespace JMS\SerializerBundle\Tests\Serializer;
  18. use JMS\SerializerBundle\Tests\Fixtures\InvalidUsageOfXmlValue;
  19. use JMS\SerializerBundle\Exception\InvalidArgumentException;
  20. use JMS\SerializerBundle\Annotation\Type;
  21. use JMS\SerializerBundle\Annotation\XmlValue;
  22. class XmlSerializationTest extends BaseSerializationTest
  23. {
  24. /**
  25. * @expectedException \RuntimeException
  26. */
  27. public function testInvalidUsageOfXmlValue()
  28. {
  29. $obj = new InvalidUsageOfXmlValue();
  30. $this->serialize($obj);
  31. }
  32. public function testExternalEntitiesAreDisabledByDefault()
  33. {
  34. $currentDir = getcwd();
  35. chdir(__DIR__);
  36. $entity = $this->deserialize('<?xml version="1.0"?>
  37. <!DOCTYPE author [
  38. <!ENTITY foo SYSTEM "php://filter/read=convert.base64-encode/resource='.basename(__FILE__).'">
  39. ]>
  40. <result>
  41. &foo;
  42. </result>', 'JMS\SerializerBundle\Tests\Serializer\ExternalEntityTest');
  43. chdir($currentDir);
  44. $this->assertEquals('', trim($entity->foo));
  45. }
  46. protected function getContent($key)
  47. {
  48. if (!file_exists($file = __DIR__.'/xml/'.$key.'.xml')) {
  49. throw new InvalidArgumentException(sprintf('The key "%s" is not supported.', $key));
  50. }
  51. return file_get_contents($file);
  52. }
  53. protected function getFormat()
  54. {
  55. return 'xml';
  56. }
  57. }
  58. class ExternalEntityTest
  59. {
  60. /** @Type("string") @XmlValue */
  61. public $foo;
  62. }