Update Composer, update everything
This commit is contained in:
parent
ea3e94409f
commit
dda5c284b6
19527 changed files with 1135420 additions and 351004 deletions
80
vendor/symfony/serializer/Tests/Encoder/ChainDecoderTest.php
vendored
Normal file
80
vendor/symfony/serializer/Tests/Encoder/ChainDecoderTest.php
vendored
Normal file
|
@ -0,0 +1,80 @@
|
|||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of the Symfony package.
|
||||
*
|
||||
* (c) Fabien Potencier <fabien@symfony.com>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace Symfony\Component\Serializer\Tests\Encoder;
|
||||
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use Symfony\Component\Serializer\Encoder\ChainDecoder;
|
||||
|
||||
class ChainDecoderTest extends TestCase
|
||||
{
|
||||
const FORMAT_1 = 'format1';
|
||||
const FORMAT_2 = 'format2';
|
||||
const FORMAT_3 = 'format3';
|
||||
|
||||
private $chainDecoder;
|
||||
private $decoder1;
|
||||
private $decoder2;
|
||||
|
||||
protected function setUp()
|
||||
{
|
||||
$this->decoder1 = $this
|
||||
->getMockBuilder('Symfony\Component\Serializer\Encoder\DecoderInterface')
|
||||
->getMock();
|
||||
|
||||
$this->decoder1
|
||||
->method('supportsDecoding')
|
||||
->will($this->returnValueMap(array(
|
||||
array(self::FORMAT_1, array(), true),
|
||||
array(self::FORMAT_2, array(), false),
|
||||
array(self::FORMAT_3, array(), false),
|
||||
array(self::FORMAT_3, array('foo' => 'bar'), true),
|
||||
)));
|
||||
|
||||
$this->decoder2 = $this
|
||||
->getMockBuilder('Symfony\Component\Serializer\Encoder\DecoderInterface')
|
||||
->getMock();
|
||||
|
||||
$this->decoder2
|
||||
->method('supportsDecoding')
|
||||
->will($this->returnValueMap(array(
|
||||
array(self::FORMAT_1, array(), false),
|
||||
array(self::FORMAT_2, array(), true),
|
||||
array(self::FORMAT_3, array(), false),
|
||||
)));
|
||||
|
||||
$this->chainDecoder = new ChainDecoder(array($this->decoder1, $this->decoder2));
|
||||
}
|
||||
|
||||
public function testSupportsDecoding()
|
||||
{
|
||||
$this->assertTrue($this->chainDecoder->supportsDecoding(self::FORMAT_1));
|
||||
$this->assertTrue($this->chainDecoder->supportsDecoding(self::FORMAT_2));
|
||||
$this->assertFalse($this->chainDecoder->supportsDecoding(self::FORMAT_3));
|
||||
$this->assertTrue($this->chainDecoder->supportsDecoding(self::FORMAT_3, array('foo' => 'bar')));
|
||||
}
|
||||
|
||||
public function testDecode()
|
||||
{
|
||||
$this->decoder1->expects($this->never())->method('decode');
|
||||
$this->decoder2->expects($this->once())->method('decode');
|
||||
|
||||
$this->chainDecoder->decode('string_to_decode', self::FORMAT_2);
|
||||
}
|
||||
|
||||
/**
|
||||
* @expectedException \Symfony\Component\Serializer\Exception\RuntimeException
|
||||
*/
|
||||
public function testDecodeUnsupportedFormat()
|
||||
{
|
||||
$this->chainDecoder->decode('string_to_decode', self::FORMAT_3);
|
||||
}
|
||||
}
|
137
vendor/symfony/serializer/Tests/Encoder/ChainEncoderTest.php
vendored
Normal file
137
vendor/symfony/serializer/Tests/Encoder/ChainEncoderTest.php
vendored
Normal file
|
@ -0,0 +1,137 @@
|
|||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of the Symfony package.
|
||||
*
|
||||
* (c) Fabien Potencier <fabien@symfony.com>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace Symfony\Component\Serializer\Tests\Encoder;
|
||||
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use Symfony\Component\Serializer\Encoder\ChainEncoder;
|
||||
use Symfony\Component\Serializer\Encoder\EncoderInterface;
|
||||
use Symfony\Component\Serializer\Encoder\NormalizationAwareInterface;
|
||||
|
||||
class ChainEncoderTest extends TestCase
|
||||
{
|
||||
const FORMAT_1 = 'format1';
|
||||
const FORMAT_2 = 'format2';
|
||||
const FORMAT_3 = 'format3';
|
||||
|
||||
private $chainEncoder;
|
||||
private $encoder1;
|
||||
private $encoder2;
|
||||
|
||||
protected function setUp()
|
||||
{
|
||||
$this->encoder1 = $this
|
||||
->getMockBuilder('Symfony\Component\Serializer\Encoder\EncoderInterface')
|
||||
->getMock();
|
||||
|
||||
$this->encoder1
|
||||
->method('supportsEncoding')
|
||||
->will($this->returnValueMap(array(
|
||||
array(self::FORMAT_1, array(), true),
|
||||
array(self::FORMAT_2, array(), false),
|
||||
array(self::FORMAT_3, array(), false),
|
||||
array(self::FORMAT_3, array('foo' => 'bar'), true),
|
||||
)));
|
||||
|
||||
$this->encoder2 = $this
|
||||
->getMockBuilder('Symfony\Component\Serializer\Encoder\EncoderInterface')
|
||||
->getMock();
|
||||
|
||||
$this->encoder2
|
||||
->method('supportsEncoding')
|
||||
->will($this->returnValueMap(array(
|
||||
array(self::FORMAT_1, array(), false),
|
||||
array(self::FORMAT_2, array(), true),
|
||||
array(self::FORMAT_3, array(), false),
|
||||
)));
|
||||
|
||||
$this->chainEncoder = new ChainEncoder(array($this->encoder1, $this->encoder2));
|
||||
}
|
||||
|
||||
public function testSupportsEncoding()
|
||||
{
|
||||
$this->assertTrue($this->chainEncoder->supportsEncoding(self::FORMAT_1));
|
||||
$this->assertTrue($this->chainEncoder->supportsEncoding(self::FORMAT_2));
|
||||
$this->assertFalse($this->chainEncoder->supportsEncoding(self::FORMAT_3));
|
||||
$this->assertTrue($this->chainEncoder->supportsEncoding(self::FORMAT_3, array('foo' => 'bar')));
|
||||
}
|
||||
|
||||
public function testEncode()
|
||||
{
|
||||
$this->encoder1->expects($this->never())->method('encode');
|
||||
$this->encoder2->expects($this->once())->method('encode');
|
||||
|
||||
$this->chainEncoder->encode(array('foo' => 123), self::FORMAT_2);
|
||||
}
|
||||
|
||||
/**
|
||||
* @expectedException \Symfony\Component\Serializer\Exception\RuntimeException
|
||||
*/
|
||||
public function testEncodeUnsupportedFormat()
|
||||
{
|
||||
$this->chainEncoder->encode(array('foo' => 123), self::FORMAT_3);
|
||||
}
|
||||
|
||||
public function testNeedsNormalizationBasic()
|
||||
{
|
||||
$this->assertTrue($this->chainEncoder->needsNormalization(self::FORMAT_1));
|
||||
$this->assertTrue($this->chainEncoder->needsNormalization(self::FORMAT_2));
|
||||
}
|
||||
|
||||
/**
|
||||
* @dataProvider booleanProvider
|
||||
*/
|
||||
public function testNeedsNormalizationChainNormalizationAware($bool)
|
||||
{
|
||||
$chainEncoder = $this
|
||||
->getMockBuilder('Symfony\Component\Serializer\Tests\Encoder\ChainNormalizationAwareEncoder')
|
||||
->getMock();
|
||||
|
||||
$chainEncoder->method('supportsEncoding')->willReturn(true);
|
||||
$chainEncoder->method('needsNormalization')->willReturn($bool);
|
||||
|
||||
$sut = new ChainEncoder(array($chainEncoder));
|
||||
|
||||
$this->assertEquals($bool, $sut->needsNormalization(self::FORMAT_1));
|
||||
}
|
||||
|
||||
public function testNeedsNormalizationNormalizationAware()
|
||||
{
|
||||
$encoder = new NormalizationAwareEncoder();
|
||||
$sut = new ChainEncoder(array($encoder));
|
||||
|
||||
$this->assertFalse($sut->needsNormalization(self::FORMAT_1));
|
||||
}
|
||||
|
||||
public function booleanProvider()
|
||||
{
|
||||
return array(
|
||||
array(true),
|
||||
array(false),
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
class ChainNormalizationAwareEncoder extends ChainEncoder implements NormalizationAwareInterface
|
||||
{
|
||||
}
|
||||
|
||||
class NormalizationAwareEncoder implements EncoderInterface, NormalizationAwareInterface
|
||||
{
|
||||
public function supportsEncoding($format)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
public function encode($data, $format, array $context = array())
|
||||
{
|
||||
}
|
||||
}
|
294
vendor/symfony/serializer/Tests/Encoder/CsvEncoderTest.php
vendored
Normal file
294
vendor/symfony/serializer/Tests/Encoder/CsvEncoderTest.php
vendored
Normal file
|
@ -0,0 +1,294 @@
|
|||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of the Symfony package.
|
||||
*
|
||||
* (c) Fabien Potencier <fabien@symfony.com>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace Symfony\Component\Serializer\Tests\Encoder;
|
||||
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use Symfony\Component\Serializer\Encoder\CsvEncoder;
|
||||
|
||||
/**
|
||||
* @author Kévin Dunglas <dunglas@gmail.com>
|
||||
*/
|
||||
class CsvEncoderTest extends TestCase
|
||||
{
|
||||
/**
|
||||
* @var CsvEncoder
|
||||
*/
|
||||
private $encoder;
|
||||
|
||||
protected function setUp()
|
||||
{
|
||||
$this->encoder = new CsvEncoder();
|
||||
}
|
||||
|
||||
public function testSupportEncoding()
|
||||
{
|
||||
$this->assertTrue($this->encoder->supportsEncoding('csv'));
|
||||
$this->assertFalse($this->encoder->supportsEncoding('foo'));
|
||||
}
|
||||
|
||||
public function testEncode()
|
||||
{
|
||||
$value = array('foo' => 'hello', 'bar' => 'hey ho');
|
||||
|
||||
$this->assertEquals(<<<'CSV'
|
||||
foo,bar
|
||||
hello,"hey ho"
|
||||
|
||||
CSV
|
||||
, $this->encoder->encode($value, 'csv'));
|
||||
}
|
||||
|
||||
public function testEncodeCollection()
|
||||
{
|
||||
$value = array(
|
||||
array('foo' => 'hello', 'bar' => 'hey ho'),
|
||||
array('foo' => 'hi', 'bar' => 'let\'s go'),
|
||||
);
|
||||
|
||||
$this->assertEquals(<<<'CSV'
|
||||
foo,bar
|
||||
hello,"hey ho"
|
||||
hi,"let's go"
|
||||
|
||||
CSV
|
||||
, $this->encoder->encode($value, 'csv'));
|
||||
}
|
||||
|
||||
public function testEncodePlainIndexedArray()
|
||||
{
|
||||
$this->assertEquals(<<<'CSV'
|
||||
0,1,2
|
||||
a,b,c
|
||||
|
||||
CSV
|
||||
, $this->encoder->encode(array('a', 'b', 'c'), 'csv'));
|
||||
}
|
||||
|
||||
public function testEncodeNonArray()
|
||||
{
|
||||
$this->assertEquals(<<<'CSV'
|
||||
0
|
||||
foo
|
||||
|
||||
CSV
|
||||
, $this->encoder->encode('foo', 'csv'));
|
||||
}
|
||||
|
||||
public function testEncodeNestedArrays()
|
||||
{
|
||||
$value = array('foo' => 'hello', 'bar' => array(
|
||||
array('id' => 'yo', 1 => 'wesh'),
|
||||
array('baz' => 'Halo', 'foo' => 'olá'),
|
||||
));
|
||||
|
||||
$this->assertEquals(<<<'CSV'
|
||||
foo,bar.0.id,bar.0.1,bar.1.baz,bar.1.foo
|
||||
hello,yo,wesh,Halo,olá
|
||||
|
||||
CSV
|
||||
, $this->encoder->encode($value, 'csv'));
|
||||
}
|
||||
|
||||
public function testEncodeCustomSettings()
|
||||
{
|
||||
$this->encoder = new CsvEncoder(';', "'", '|', '-');
|
||||
|
||||
$value = array('a' => 'he\'llo', 'c' => array('d' => 'foo'));
|
||||
|
||||
$this->assertEquals(<<<'CSV'
|
||||
a;c-d
|
||||
'he''llo';foo
|
||||
|
||||
CSV
|
||||
, $this->encoder->encode($value, 'csv'));
|
||||
}
|
||||
|
||||
public function testEncodeCustomSettingsPassedInContext()
|
||||
{
|
||||
$value = array('a' => 'he\'llo', 'c' => array('d' => 'foo'));
|
||||
|
||||
$this->assertSame(<<<'CSV'
|
||||
a;c-d
|
||||
'he''llo';foo
|
||||
|
||||
CSV
|
||||
, $this->encoder->encode($value, 'csv', array(
|
||||
CsvEncoder::DELIMITER_KEY => ';',
|
||||
CsvEncoder::ENCLOSURE_KEY => "'",
|
||||
CsvEncoder::ESCAPE_CHAR_KEY => '|',
|
||||
CsvEncoder::KEY_SEPARATOR_KEY => '-',
|
||||
)));
|
||||
}
|
||||
|
||||
public function testEncodeEmptyArray()
|
||||
{
|
||||
$this->assertEquals("\n\n", $this->encoder->encode(array(), 'csv'));
|
||||
$this->assertEquals("\n\n", $this->encoder->encode(array(array()), 'csv'));
|
||||
}
|
||||
|
||||
public function testEncodeVariableStructure()
|
||||
{
|
||||
$value = array(
|
||||
array('a' => array('foo', 'bar')),
|
||||
array('a' => array(), 'b' => 'baz'),
|
||||
array('a' => array('bar', 'foo'), 'c' => 'pong'),
|
||||
);
|
||||
$csv = <<<CSV
|
||||
a.0,a.1,c,b
|
||||
foo,bar,,
|
||||
,,,baz
|
||||
bar,foo,pong,
|
||||
|
||||
CSV;
|
||||
|
||||
$this->assertEquals($csv, $this->encoder->encode($value, 'csv'));
|
||||
}
|
||||
|
||||
public function testEncodeCustomHeaders()
|
||||
{
|
||||
$context = array(
|
||||
CsvEncoder::HEADERS_KEY => array(
|
||||
'b',
|
||||
'c',
|
||||
),
|
||||
);
|
||||
$value = array(
|
||||
array('a' => 'foo', 'b' => 'bar'),
|
||||
);
|
||||
$csv = <<<CSV
|
||||
b,c,a
|
||||
bar,,foo
|
||||
|
||||
CSV;
|
||||
|
||||
$this->assertEquals($csv, $this->encoder->encode($value, 'csv', $context));
|
||||
}
|
||||
|
||||
public function testSupportsDecoding()
|
||||
{
|
||||
$this->assertTrue($this->encoder->supportsDecoding('csv'));
|
||||
$this->assertFalse($this->encoder->supportsDecoding('foo'));
|
||||
}
|
||||
|
||||
public function testDecode()
|
||||
{
|
||||
$expected = array('foo' => 'a', 'bar' => 'b');
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->decode(<<<'CSV'
|
||||
foo,bar
|
||||
a,b
|
||||
CSV
|
||||
, 'csv'));
|
||||
}
|
||||
|
||||
public function testDecodeCollection()
|
||||
{
|
||||
$expected = array(
|
||||
array('foo' => 'a', 'bar' => 'b'),
|
||||
array('foo' => 'c', 'bar' => 'd'),
|
||||
array('foo' => 'f'),
|
||||
);
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->decode(<<<'CSV'
|
||||
foo,bar
|
||||
a,b
|
||||
c,d
|
||||
f
|
||||
|
||||
CSV
|
||||
, 'csv'));
|
||||
}
|
||||
|
||||
public function testDecodeToManyRelation()
|
||||
{
|
||||
$expected = array(
|
||||
array('foo' => 'bar', 'relations' => array(array('a' => 'b'), array('a' => 'b'))),
|
||||
array('foo' => 'bat', 'relations' => array(array('a' => 'b'), array('a' => ''))),
|
||||
array('foo' => 'bat', 'relations' => array(array('a' => 'b'))),
|
||||
array('foo' => 'baz', 'relations' => array(array('a' => 'c'), array('a' => 'c'))),
|
||||
);
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->decode(<<<'CSV'
|
||||
foo,relations.0.a,relations.1.a
|
||||
bar,b,b
|
||||
bat,b,
|
||||
bat,b
|
||||
baz,c,c
|
||||
CSV
|
||||
, 'csv'));
|
||||
}
|
||||
|
||||
public function testDecodeNestedArrays()
|
||||
{
|
||||
$expected = array(
|
||||
array('foo' => 'a', 'bar' => array('baz' => array('bat' => 'b'))),
|
||||
array('foo' => 'c', 'bar' => array('baz' => array('bat' => 'd'))),
|
||||
);
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->decode(<<<'CSV'
|
||||
foo,bar.baz.bat
|
||||
a,b
|
||||
c,d
|
||||
CSV
|
||||
, 'csv'));
|
||||
}
|
||||
|
||||
public function testDecodeCustomSettings()
|
||||
{
|
||||
$this->encoder = new CsvEncoder(';', "'", '|', '-');
|
||||
|
||||
$expected = array('a' => 'hell\'o', 'bar' => array('baz' => 'b'));
|
||||
$this->assertEquals($expected, $this->encoder->decode(<<<'CSV'
|
||||
a;bar-baz
|
||||
'hell''o';b;c
|
||||
CSV
|
||||
, 'csv'));
|
||||
}
|
||||
|
||||
public function testDecodeCustomSettingsPassedInContext()
|
||||
{
|
||||
$expected = array('a' => 'hell\'o', 'bar' => array('baz' => 'b'));
|
||||
$this->assertEquals($expected, $this->encoder->decode(<<<'CSV'
|
||||
a;bar-baz
|
||||
'hell''o';b;c
|
||||
CSV
|
||||
, 'csv', array(
|
||||
CsvEncoder::DELIMITER_KEY => ';',
|
||||
CsvEncoder::ENCLOSURE_KEY => "'",
|
||||
CsvEncoder::ESCAPE_CHAR_KEY => '|',
|
||||
CsvEncoder::KEY_SEPARATOR_KEY => '-',
|
||||
)));
|
||||
}
|
||||
|
||||
public function testDecodeMalformedCollection()
|
||||
{
|
||||
$expected = array(
|
||||
array('foo' => 'a', 'bar' => 'b'),
|
||||
array('foo' => 'c', 'bar' => 'd'),
|
||||
array('foo' => 'f'),
|
||||
);
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->decode(<<<'CSV'
|
||||
foo,bar
|
||||
a,b,e
|
||||
c,d,g,h
|
||||
f
|
||||
|
||||
CSV
|
||||
, 'csv'));
|
||||
}
|
||||
|
||||
public function testDecodeEmptyArray()
|
||||
{
|
||||
$this->assertEquals(array(), $this->encoder->decode('', 'csv'));
|
||||
}
|
||||
}
|
75
vendor/symfony/serializer/Tests/Encoder/JsonDecodeTest.php
vendored
Normal file
75
vendor/symfony/serializer/Tests/Encoder/JsonDecodeTest.php
vendored
Normal file
|
@ -0,0 +1,75 @@
|
|||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of the Symfony package.
|
||||
*
|
||||
* (c) Fabien Potencier <fabien@symfony.com>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace Symfony\Component\Serializer\Tests\Encoder;
|
||||
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use Symfony\Component\Serializer\Encoder\JsonDecode;
|
||||
use Symfony\Component\Serializer\Encoder\JsonEncoder;
|
||||
|
||||
class JsonDecodeTest extends TestCase
|
||||
{
|
||||
/** @var \Symfony\Component\Serializer\Encoder\JsonDecode */
|
||||
private $decode;
|
||||
|
||||
protected function setUp()
|
||||
{
|
||||
$this->decode = new JsonDecode();
|
||||
}
|
||||
|
||||
public function testSupportsDecoding()
|
||||
{
|
||||
$this->assertTrue($this->decode->supportsDecoding(JsonEncoder::FORMAT));
|
||||
$this->assertFalse($this->decode->supportsDecoding('foobar'));
|
||||
}
|
||||
|
||||
/**
|
||||
* @dataProvider decodeProvider
|
||||
*/
|
||||
public function testDecode($toDecode, $expected, $context)
|
||||
{
|
||||
$this->assertEquals(
|
||||
$expected,
|
||||
$this->decode->decode($toDecode, JsonEncoder::FORMAT, $context)
|
||||
);
|
||||
}
|
||||
|
||||
public function decodeProvider()
|
||||
{
|
||||
$stdClass = new \stdClass();
|
||||
$stdClass->foo = 'bar';
|
||||
|
||||
$assoc = array('foo' => 'bar');
|
||||
|
||||
return array(
|
||||
array('{"foo": "bar"}', $stdClass, array()),
|
||||
array('{"foo": "bar"}', $assoc, array('json_decode_associative' => true)),
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* @requires function json_last_error_msg
|
||||
* @dataProvider decodeProviderException
|
||||
* @expectedException \Symfony\Component\Serializer\Exception\UnexpectedValueException
|
||||
*/
|
||||
public function testDecodeWithException($value)
|
||||
{
|
||||
$this->decode->decode($value, JsonEncoder::FORMAT);
|
||||
}
|
||||
|
||||
public function decodeProviderException()
|
||||
{
|
||||
return array(
|
||||
array("{'foo': 'bar'}"),
|
||||
array('kaboom!'),
|
||||
);
|
||||
}
|
||||
}
|
60
vendor/symfony/serializer/Tests/Encoder/JsonEncodeTest.php
vendored
Normal file
60
vendor/symfony/serializer/Tests/Encoder/JsonEncodeTest.php
vendored
Normal file
|
@ -0,0 +1,60 @@
|
|||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of the Symfony package.
|
||||
*
|
||||
* (c) Fabien Potencier <fabien@symfony.com>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace Symfony\Component\Serializer\Tests\Encoder;
|
||||
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use Symfony\Component\Serializer\Encoder\JsonEncode;
|
||||
use Symfony\Component\Serializer\Encoder\JsonEncoder;
|
||||
|
||||
class JsonEncodeTest extends TestCase
|
||||
{
|
||||
private $encoder;
|
||||
|
||||
protected function setUp()
|
||||
{
|
||||
$this->encode = new JsonEncode();
|
||||
}
|
||||
|
||||
public function testSupportsEncoding()
|
||||
{
|
||||
$this->assertTrue($this->encode->supportsEncoding(JsonEncoder::FORMAT));
|
||||
$this->assertFalse($this->encode->supportsEncoding('foobar'));
|
||||
}
|
||||
|
||||
/**
|
||||
* @dataProvider encodeProvider
|
||||
*/
|
||||
public function testEncode($toEncode, $expected, $context)
|
||||
{
|
||||
$this->assertEquals(
|
||||
$expected,
|
||||
$this->encode->encode($toEncode, JsonEncoder::FORMAT, $context)
|
||||
);
|
||||
}
|
||||
|
||||
public function encodeProvider()
|
||||
{
|
||||
return array(
|
||||
array(array(), '[]', array()),
|
||||
array(array(), '{}', array('json_encode_options' => JSON_FORCE_OBJECT)),
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* @requires function json_last_error_msg
|
||||
* @expectedException \Symfony\Component\Serializer\Exception\UnexpectedValueException
|
||||
*/
|
||||
public function testEncodeWithError()
|
||||
{
|
||||
$this->encode->encode("\xB1\x31", JsonEncoder::FORMAT);
|
||||
}
|
||||
}
|
121
vendor/symfony/serializer/Tests/Encoder/JsonEncoderTest.php
vendored
Normal file
121
vendor/symfony/serializer/Tests/Encoder/JsonEncoderTest.php
vendored
Normal file
|
@ -0,0 +1,121 @@
|
|||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of the Symfony package.
|
||||
*
|
||||
* (c) Fabien Potencier <fabien@symfony.com>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace Symfony\Component\Serializer\Tests\Encoder;
|
||||
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use Symfony\Component\Serializer\Encoder\JsonEncoder;
|
||||
use Symfony\Component\Serializer\Normalizer\CustomNormalizer;
|
||||
use Symfony\Component\Serializer\Serializer;
|
||||
|
||||
class JsonEncoderTest extends TestCase
|
||||
{
|
||||
private $encoder;
|
||||
private $serializer;
|
||||
|
||||
protected function setUp()
|
||||
{
|
||||
$this->encoder = new JsonEncoder();
|
||||
$this->serializer = new Serializer(array(new CustomNormalizer()), array('json' => new JsonEncoder()));
|
||||
}
|
||||
|
||||
public function testEncodeScalar()
|
||||
{
|
||||
$obj = new \stdClass();
|
||||
$obj->foo = 'foo';
|
||||
|
||||
$expected = '{"foo":"foo"}';
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->encode($obj, 'json'));
|
||||
}
|
||||
|
||||
public function testComplexObject()
|
||||
{
|
||||
$obj = $this->getObject();
|
||||
|
||||
$expected = $this->getJsonSource();
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->encode($obj, 'json'));
|
||||
}
|
||||
|
||||
public function testOptions()
|
||||
{
|
||||
$context = array('json_encode_options' => JSON_NUMERIC_CHECK);
|
||||
|
||||
$arr = array();
|
||||
$arr['foo'] = '3';
|
||||
|
||||
$expected = '{"foo":3}';
|
||||
|
||||
$this->assertEquals($expected, $this->serializer->serialize($arr, 'json', $context));
|
||||
|
||||
$arr = array();
|
||||
$arr['foo'] = '3';
|
||||
|
||||
$expected = '{"foo":"3"}';
|
||||
|
||||
$this->assertEquals($expected, $this->serializer->serialize($arr, 'json'), 'Context should not be persistent');
|
||||
}
|
||||
|
||||
/**
|
||||
* @expectedException \Symfony\Component\Serializer\Exception\UnexpectedValueException
|
||||
*/
|
||||
public function testEncodeNotUtf8WithoutPartialOnError()
|
||||
{
|
||||
$arr = array(
|
||||
'utf8' => 'Hello World!',
|
||||
'notUtf8' => "\xb0\xd0\xb5\xd0",
|
||||
);
|
||||
|
||||
$this->encoder->encode($arr, 'json');
|
||||
}
|
||||
|
||||
public function testEncodeNotUtf8WithPartialOnError()
|
||||
{
|
||||
$context = array('json_encode_options' => JSON_PARTIAL_OUTPUT_ON_ERROR);
|
||||
|
||||
$arr = array(
|
||||
'utf8' => 'Hello World!',
|
||||
'notUtf8' => "\xb0\xd0\xb5\xd0",
|
||||
);
|
||||
|
||||
$result = $this->encoder->encode($arr, 'json', $context);
|
||||
$jsonLastError = json_last_error();
|
||||
|
||||
$this->assertSame(JSON_ERROR_UTF8, $jsonLastError);
|
||||
$this->assertEquals('{"utf8":"Hello World!","notUtf8":null}', $result);
|
||||
|
||||
$this->assertEquals('0', $this->serializer->serialize(NAN, 'json', $context));
|
||||
}
|
||||
|
||||
public function testDecodeFalseString()
|
||||
{
|
||||
$result = $this->encoder->decode('false', 'json');
|
||||
$this->assertSame(JSON_ERROR_NONE, json_last_error());
|
||||
$this->assertFalse($result);
|
||||
}
|
||||
|
||||
protected function getJsonSource()
|
||||
{
|
||||
return '{"foo":"foo","bar":["a","b"],"baz":{"key":"val","key2":"val","A B":"bar","item":[{"title":"title1"},{"title":"title2"}],"Barry":{"FooBar":{"Baz":"Ed","@id":1}}},"qux":"1"}';
|
||||
}
|
||||
|
||||
protected function getObject()
|
||||
{
|
||||
$obj = new \stdClass();
|
||||
$obj->foo = 'foo';
|
||||
$obj->bar = array('a', 'b');
|
||||
$obj->baz = array('key' => 'val', 'key2' => 'val', 'A B' => 'bar', 'item' => array(array('title' => 'title1'), array('title' => 'title2')), 'Barry' => array('FooBar' => array('Baz' => 'Ed', '@id' => 1)));
|
||||
$obj->qux = '1';
|
||||
|
||||
return $obj;
|
||||
}
|
||||
}
|
733
vendor/symfony/serializer/Tests/Encoder/XmlEncoderTest.php
vendored
Normal file
733
vendor/symfony/serializer/Tests/Encoder/XmlEncoderTest.php
vendored
Normal file
|
@ -0,0 +1,733 @@
|
|||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of the Symfony package.
|
||||
*
|
||||
* (c) Fabien Potencier <fabien@symfony.com>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace Symfony\Component\Serializer\Tests\Encoder;
|
||||
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use Symfony\Component\Serializer\Encoder\XmlEncoder;
|
||||
use Symfony\Component\Serializer\Normalizer\CustomNormalizer;
|
||||
use Symfony\Component\Serializer\Normalizer\NormalizerInterface;
|
||||
use Symfony\Component\Serializer\Serializer;
|
||||
use Symfony\Component\Serializer\Tests\Fixtures\Dummy;
|
||||
use Symfony\Component\Serializer\Tests\Fixtures\NormalizableTraversableDummy;
|
||||
use Symfony\Component\Serializer\Tests\Fixtures\ScalarDummy;
|
||||
|
||||
class XmlEncoderTest extends TestCase
|
||||
{
|
||||
/**
|
||||
* @var XmlEncoder
|
||||
*/
|
||||
private $encoder;
|
||||
|
||||
private $exampleDateTimeString = '2017-02-19T15:16:08+0300';
|
||||
|
||||
protected function setUp()
|
||||
{
|
||||
$this->encoder = new XmlEncoder();
|
||||
$serializer = new Serializer(array(new CustomNormalizer()), array('xml' => new XmlEncoder()));
|
||||
$this->encoder->setSerializer($serializer);
|
||||
}
|
||||
|
||||
public function testEncodeScalar()
|
||||
{
|
||||
$obj = new ScalarDummy();
|
||||
$obj->xmlFoo = 'foo';
|
||||
|
||||
$expected = '<?xml version="1.0"?>'."\n".
|
||||
'<response>foo</response>'."\n";
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->encode($obj, 'xml'));
|
||||
}
|
||||
|
||||
public function testSetRootNodeName()
|
||||
{
|
||||
$obj = new ScalarDummy();
|
||||
$obj->xmlFoo = 'foo';
|
||||
|
||||
$this->encoder->setRootNodeName('test');
|
||||
$expected = '<?xml version="1.0"?>'."\n".
|
||||
'<test>foo</test>'."\n";
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->encode($obj, 'xml'));
|
||||
}
|
||||
|
||||
/**
|
||||
* @expectedException \Symfony\Component\Serializer\Exception\UnexpectedValueException
|
||||
* @expectedExceptionMessage Document types are not allowed.
|
||||
*/
|
||||
public function testDocTypeIsNotAllowed()
|
||||
{
|
||||
$this->encoder->decode('<?xml version="1.0"?><!DOCTYPE foo><foo></foo>', 'foo');
|
||||
}
|
||||
|
||||
public function testAttributes()
|
||||
{
|
||||
$obj = new ScalarDummy();
|
||||
$obj->xmlFoo = array(
|
||||
'foo-bar' => array(
|
||||
'@id' => 1,
|
||||
'@name' => 'Bar',
|
||||
),
|
||||
'Foo' => array(
|
||||
'Bar' => 'Test',
|
||||
'@Type' => 'test',
|
||||
),
|
||||
'föo_bär' => 'a',
|
||||
'Bar' => array(1, 2, 3),
|
||||
'a' => 'b',
|
||||
);
|
||||
$expected = '<?xml version="1.0"?>'."\n".
|
||||
'<response>'.
|
||||
'<foo-bar id="1" name="Bar"/>'.
|
||||
'<Foo Type="test"><Bar>Test</Bar></Foo>'.
|
||||
'<föo_bär>a</föo_bär>'.
|
||||
'<Bar>1</Bar>'.
|
||||
'<Bar>2</Bar>'.
|
||||
'<Bar>3</Bar>'.
|
||||
'<a>b</a>'.
|
||||
'</response>'."\n";
|
||||
$this->assertEquals($expected, $this->encoder->encode($obj, 'xml'));
|
||||
}
|
||||
|
||||
public function testElementNameValid()
|
||||
{
|
||||
$obj = new ScalarDummy();
|
||||
$obj->xmlFoo = array(
|
||||
'foo-bar' => 'a',
|
||||
'foo_bar' => 'a',
|
||||
'föo_bär' => 'a',
|
||||
);
|
||||
|
||||
$expected = '<?xml version="1.0"?>'."\n".
|
||||
'<response>'.
|
||||
'<foo-bar>a</foo-bar>'.
|
||||
'<foo_bar>a</foo_bar>'.
|
||||
'<föo_bär>a</föo_bär>'.
|
||||
'</response>'."\n";
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->encode($obj, 'xml'));
|
||||
}
|
||||
|
||||
public function testEncodeSimpleXML()
|
||||
{
|
||||
$xml = simplexml_load_string('<firstname>Peter</firstname>');
|
||||
$array = array('person' => $xml);
|
||||
|
||||
$expected = '<?xml version="1.0"?>'."\n".
|
||||
'<response><person><firstname>Peter</firstname></person></response>'."\n";
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->encode($array, 'xml'));
|
||||
}
|
||||
|
||||
public function testEncodeXmlAttributes()
|
||||
{
|
||||
$xml = simplexml_load_string('<firstname>Peter</firstname>');
|
||||
$array = array('person' => $xml);
|
||||
|
||||
$expected = '<?xml version="1.1" encoding="utf-8" standalone="yes"?>'."\n".
|
||||
'<response><person><firstname>Peter</firstname></person></response>'."\n";
|
||||
|
||||
$context = array(
|
||||
'xml_version' => '1.1',
|
||||
'xml_encoding' => 'utf-8',
|
||||
'xml_standalone' => true,
|
||||
);
|
||||
|
||||
$this->assertSame($expected, $this->encoder->encode($array, 'xml', $context));
|
||||
}
|
||||
|
||||
public function testEncodeRemovingEmptyTags()
|
||||
{
|
||||
$array = array('person' => array('firstname' => 'Peter', 'lastname' => null));
|
||||
|
||||
$expected = '<?xml version="1.0"?>'."\n".
|
||||
'<response><person><firstname>Peter</firstname></person></response>'."\n";
|
||||
|
||||
$context = array('remove_empty_tags' => true);
|
||||
|
||||
$this->assertSame($expected, $this->encoder->encode($array, 'xml', $context));
|
||||
}
|
||||
|
||||
public function testEncodeNotRemovingEmptyTags()
|
||||
{
|
||||
$array = array('person' => array('firstname' => 'Peter', 'lastname' => null));
|
||||
|
||||
$expected = '<?xml version="1.0"?>'."\n".
|
||||
'<response><person><firstname>Peter</firstname><lastname/></person></response>'."\n";
|
||||
|
||||
$this->assertSame($expected, $this->encoder->encode($array, 'xml'));
|
||||
}
|
||||
|
||||
public function testContext()
|
||||
{
|
||||
$array = array('person' => array('name' => 'George Abitbol'));
|
||||
$expected = <<<'XML'
|
||||
<?xml version="1.0"?>
|
||||
<response>
|
||||
<person>
|
||||
<name>George Abitbol</name>
|
||||
</person>
|
||||
</response>
|
||||
|
||||
XML;
|
||||
|
||||
$context = array(
|
||||
'xml_format_output' => true,
|
||||
);
|
||||
|
||||
$this->assertSame($expected, $this->encoder->encode($array, 'xml', $context));
|
||||
}
|
||||
|
||||
public function testEncodeScalarRootAttributes()
|
||||
{
|
||||
$array = array(
|
||||
'#' => 'Paul',
|
||||
'@gender' => 'm',
|
||||
);
|
||||
|
||||
$expected = '<?xml version="1.0"?>'."\n".
|
||||
'<response gender="m">Paul</response>'."\n";
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->encode($array, 'xml'));
|
||||
}
|
||||
|
||||
public function testEncodeRootAttributes()
|
||||
{
|
||||
$array = array(
|
||||
'firstname' => 'Paul',
|
||||
'@gender' => 'm',
|
||||
);
|
||||
|
||||
$expected = '<?xml version="1.0"?>'."\n".
|
||||
'<response gender="m"><firstname>Paul</firstname></response>'."\n";
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->encode($array, 'xml'));
|
||||
}
|
||||
|
||||
public function testEncodeCdataWrapping()
|
||||
{
|
||||
$array = array(
|
||||
'firstname' => 'Paul <or Me>',
|
||||
);
|
||||
|
||||
$expected = '<?xml version="1.0"?>'."\n".
|
||||
'<response><firstname><![CDATA[Paul <or Me>]]></firstname></response>'."\n";
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->encode($array, 'xml'));
|
||||
}
|
||||
|
||||
public function testEncodeScalarWithAttribute()
|
||||
{
|
||||
$array = array(
|
||||
'person' => array('@gender' => 'M', '#' => 'Peter'),
|
||||
);
|
||||
|
||||
$expected = '<?xml version="1.0"?>'."\n".
|
||||
'<response><person gender="M">Peter</person></response>'."\n";
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->encode($array, 'xml'));
|
||||
}
|
||||
|
||||
public function testDecodeScalar()
|
||||
{
|
||||
$source = '<?xml version="1.0"?>'."\n".
|
||||
'<response>foo</response>'."\n";
|
||||
|
||||
$this->assertEquals('foo', $this->encoder->decode($source, 'xml'));
|
||||
}
|
||||
|
||||
public function testDecodeBigDigitAttributes()
|
||||
{
|
||||
$source = <<<XML
|
||||
<?xml version="1.0"?>
|
||||
<document index="182077241760011681341821060401202210011000045913000000017100">Name</document>
|
||||
XML;
|
||||
|
||||
$this->assertSame(array('@index' => 182077241760011681341821060401202210011000045913000000017100, '#' => 'Name'), $this->encoder->decode($source, 'xml'));
|
||||
}
|
||||
|
||||
public function testDecodeNegativeIntAttribute()
|
||||
{
|
||||
$source = <<<XML
|
||||
<?xml version="1.0"?>
|
||||
<document index="-1234">Name</document>
|
||||
XML;
|
||||
|
||||
$this->assertSame(array('@index' => -1234, '#' => 'Name'), $this->encoder->decode($source, 'xml'));
|
||||
}
|
||||
|
||||
public function testDecodeFloatAttribute()
|
||||
{
|
||||
$source = <<<XML
|
||||
<?xml version="1.0"?>
|
||||
<document index="-12.11">Name</document>
|
||||
XML;
|
||||
|
||||
$this->assertSame(array('@index' => -12.11, '#' => 'Name'), $this->encoder->decode($source, 'xml'));
|
||||
}
|
||||
|
||||
public function testDecodeNegativeFloatAttribute()
|
||||
{
|
||||
$source = <<<XML
|
||||
<?xml version="1.0"?>
|
||||
<document index="-12.11">Name</document>
|
||||
XML;
|
||||
|
||||
$this->assertSame(array('@index' => -12.11, '#' => 'Name'), $this->encoder->decode($source, 'xml'));
|
||||
}
|
||||
|
||||
public function testNoTypeCastAttribute()
|
||||
{
|
||||
$source = <<<XML
|
||||
<?xml version="1.0"?>
|
||||
<document a="018" b="-12.11">
|
||||
<node a="018" b="-12.11"/>
|
||||
</document>
|
||||
XML;
|
||||
|
||||
$data = $this->encoder->decode($source, 'xml', array('xml_type_cast_attributes' => false));
|
||||
$expected = array(
|
||||
'@a' => '018',
|
||||
'@b' => '-12.11',
|
||||
'node' => array(
|
||||
'@a' => '018',
|
||||
'@b' => '-12.11',
|
||||
'#' => '',
|
||||
),
|
||||
);
|
||||
$this->assertSame($expected, $data);
|
||||
}
|
||||
|
||||
public function testEncode()
|
||||
{
|
||||
$source = $this->getXmlSource();
|
||||
$obj = $this->getObject();
|
||||
|
||||
$this->assertEquals($source, $this->encoder->encode($obj, 'xml'));
|
||||
}
|
||||
|
||||
public function testEncodeWithNamespace()
|
||||
{
|
||||
$source = $this->getNamespacedXmlSource();
|
||||
$array = $this->getNamespacedArray();
|
||||
|
||||
$this->assertEquals($source, $this->encoder->encode($array, 'xml'));
|
||||
}
|
||||
|
||||
public function testEncodeSerializerXmlRootNodeNameOption()
|
||||
{
|
||||
$options = array('xml_root_node_name' => 'test');
|
||||
$this->encoder = new XmlEncoder();
|
||||
$serializer = new Serializer(array(), array('xml' => new XmlEncoder()));
|
||||
$this->encoder->setSerializer($serializer);
|
||||
|
||||
$array = array(
|
||||
'person' => array('@gender' => 'M', '#' => 'Peter'),
|
||||
);
|
||||
|
||||
$expected = '<?xml version="1.0"?>'."\n".
|
||||
'<test><person gender="M">Peter</person></test>'."\n";
|
||||
|
||||
$this->assertEquals($expected, $serializer->serialize($array, 'xml', $options));
|
||||
}
|
||||
|
||||
public function testEncodeTraversableWhenNormalizable()
|
||||
{
|
||||
$this->encoder = new XmlEncoder();
|
||||
$serializer = new Serializer(array(new CustomNormalizer()), array('xml' => new XmlEncoder()));
|
||||
$this->encoder->setSerializer($serializer);
|
||||
|
||||
$expected = <<<'XML'
|
||||
<?xml version="1.0"?>
|
||||
<response><foo>normalizedFoo</foo><bar>normalizedBar</bar></response>
|
||||
|
||||
XML;
|
||||
|
||||
$this->assertEquals($expected, $serializer->serialize(new NormalizableTraversableDummy(), 'xml'));
|
||||
}
|
||||
|
||||
public function testDecode()
|
||||
{
|
||||
$source = $this->getXmlSource();
|
||||
$obj = $this->getObject();
|
||||
|
||||
$this->assertEquals(get_object_vars($obj), $this->encoder->decode($source, 'xml'));
|
||||
}
|
||||
|
||||
public function testDecodeCdataWrapping()
|
||||
{
|
||||
$expected = array(
|
||||
'firstname' => 'Paul <or Me>',
|
||||
);
|
||||
|
||||
$xml = '<?xml version="1.0"?>'."\n".
|
||||
'<response><firstname><![CDATA[Paul <or Me>]]></firstname></response>'."\n";
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->decode($xml, 'xml'));
|
||||
}
|
||||
|
||||
public function testDecodeCdataWrappingAndWhitespace()
|
||||
{
|
||||
$expected = array(
|
||||
'firstname' => 'Paul <or Me>',
|
||||
);
|
||||
|
||||
$xml = '<?xml version="1.0"?>'."\n".
|
||||
'<response><firstname>'."\n".
|
||||
'<![CDATA[Paul <or Me>]]></firstname></response>'."\n";
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->decode($xml, 'xml'));
|
||||
}
|
||||
|
||||
public function testDecodeWithNamespace()
|
||||
{
|
||||
$source = $this->getNamespacedXmlSource();
|
||||
$array = $this->getNamespacedArray();
|
||||
|
||||
$this->assertEquals($array, $this->encoder->decode($source, 'xml'));
|
||||
}
|
||||
|
||||
public function testDecodeScalarWithAttribute()
|
||||
{
|
||||
$source = '<?xml version="1.0"?>'."\n".
|
||||
'<response><person gender="M">Peter</person></response>'."\n";
|
||||
|
||||
$expected = array(
|
||||
'person' => array('@gender' => 'M', '#' => 'Peter'),
|
||||
);
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->decode($source, 'xml'));
|
||||
}
|
||||
|
||||
public function testDecodeScalarRootAttributes()
|
||||
{
|
||||
$source = '<?xml version="1.0"?>'."\n".
|
||||
'<person gender="M">Peter</person>'."\n";
|
||||
|
||||
$expected = array(
|
||||
'#' => 'Peter',
|
||||
'@gender' => 'M',
|
||||
);
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->decode($source, 'xml'));
|
||||
}
|
||||
|
||||
public function testDecodeRootAttributes()
|
||||
{
|
||||
$source = '<?xml version="1.0"?>'."\n".
|
||||
'<person gender="M"><firstname>Peter</firstname><lastname>Mac Calloway</lastname></person>'."\n";
|
||||
|
||||
$expected = array(
|
||||
'firstname' => 'Peter',
|
||||
'lastname' => 'Mac Calloway',
|
||||
'@gender' => 'M',
|
||||
);
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->decode($source, 'xml'));
|
||||
}
|
||||
|
||||
public function testDecodeArray()
|
||||
{
|
||||
$source = '<?xml version="1.0"?>'."\n".
|
||||
'<response>'.
|
||||
'<people>'.
|
||||
'<person><firstname>Benjamin</firstname><lastname>Alexandre</lastname></person>'.
|
||||
'<person><firstname>Damien</firstname><lastname>Clay</lastname></person>'.
|
||||
'</people>'.
|
||||
'</response>'."\n";
|
||||
|
||||
$expected = array(
|
||||
'people' => array('person' => array(
|
||||
array('firstname' => 'Benjamin', 'lastname' => 'Alexandre'),
|
||||
array('firstname' => 'Damien', 'lastname' => 'Clay'),
|
||||
)),
|
||||
);
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->decode($source, 'xml'));
|
||||
}
|
||||
|
||||
public function testDecodeXMLWithProcessInstruction()
|
||||
{
|
||||
$source = <<<'XML'
|
||||
<?xml version="1.0"?>
|
||||
<?xml-stylesheet type="text/xsl" href="/xsl/xmlverbatimwrapper.xsl"?>
|
||||
<?display table-view?>
|
||||
<?sort alpha-ascending?>
|
||||
<response>
|
||||
<foo>foo</foo>
|
||||
<?textinfo whitespace is allowed ?>
|
||||
<bar>a</bar>
|
||||
<bar>b</bar>
|
||||
<baz>
|
||||
<key>val</key>
|
||||
<key2>val</key2>
|
||||
<item key="A B">bar</item>
|
||||
<item>
|
||||
<title>title1</title>
|
||||
</item>
|
||||
<?item ignore-title ?>
|
||||
<item>
|
||||
<title>title2</title>
|
||||
</item>
|
||||
<Barry>
|
||||
<FooBar id="1">
|
||||
<Baz>Ed</Baz>
|
||||
</FooBar>
|
||||
</Barry>
|
||||
</baz>
|
||||
<qux>1</qux>
|
||||
</response>
|
||||
<?instruction <value> ?>
|
||||
XML;
|
||||
$obj = $this->getObject();
|
||||
|
||||
$this->assertEquals(get_object_vars($obj), $this->encoder->decode($source, 'xml'));
|
||||
}
|
||||
|
||||
public function testDecodeIgnoreWhiteSpace()
|
||||
{
|
||||
$source = <<<'XML'
|
||||
<?xml version="1.0"?>
|
||||
<people>
|
||||
<person>
|
||||
<firstname>Benjamin</firstname>
|
||||
<lastname>Alexandre</lastname>
|
||||
</person>
|
||||
<person>
|
||||
<firstname>Damien</firstname>
|
||||
<lastname>Clay</lastname>
|
||||
</person>
|
||||
</people>
|
||||
XML;
|
||||
$expected = array('person' => array(
|
||||
array('firstname' => 'Benjamin', 'lastname' => 'Alexandre'),
|
||||
array('firstname' => 'Damien', 'lastname' => 'Clay'),
|
||||
));
|
||||
|
||||
$this->assertEquals($expected, $this->encoder->decode($source, 'xml'));
|
||||
}
|
||||
|
||||
public function testDecodeWithoutItemHash()
|
||||
{
|
||||
$obj = new ScalarDummy();
|
||||
$obj->xmlFoo = array(
|
||||
'foo-bar' => array(
|
||||
'@key' => 'value',
|
||||
'item' => array('@key' => 'key', 'key-val' => 'val'),
|
||||
),
|
||||
'Foo' => array(
|
||||
'Bar' => 'Test',
|
||||
'@Type' => 'test',
|
||||
),
|
||||
'föo_bär' => 'a',
|
||||
'Bar' => array(1, 2, 3),
|
||||
'a' => 'b',
|
||||
);
|
||||
$expected = array(
|
||||
'foo-bar' => array(
|
||||
'@key' => 'value',
|
||||
'key' => array('@key' => 'key', 'key-val' => 'val'),
|
||||
),
|
||||
'Foo' => array(
|
||||
'Bar' => 'Test',
|
||||
'@Type' => 'test',
|
||||
),
|
||||
'föo_bär' => 'a',
|
||||
'Bar' => array(1, 2, 3),
|
||||
'a' => 'b',
|
||||
);
|
||||
$xml = $this->encoder->encode($obj, 'xml');
|
||||
$this->assertEquals($expected, $this->encoder->decode($xml, 'xml'));
|
||||
}
|
||||
|
||||
/**
|
||||
* @expectedException \Symfony\Component\Serializer\Exception\UnexpectedValueException
|
||||
*/
|
||||
public function testDecodeInvalidXml()
|
||||
{
|
||||
$this->encoder->decode('<?xml version="1.0"?><invalid><xml>', 'xml');
|
||||
}
|
||||
|
||||
/**
|
||||
* @expectedException \Symfony\Component\Serializer\Exception\UnexpectedValueException
|
||||
*/
|
||||
public function testPreventsComplexExternalEntities()
|
||||
{
|
||||
$this->encoder->decode('<?xml version="1.0"?><!DOCTYPE scan[<!ENTITY test SYSTEM "php://filter/read=convert.base64-encode/resource=XmlEncoderTest.php">]><scan>&test;</scan>', 'xml');
|
||||
}
|
||||
|
||||
public function testDecodeEmptyXml()
|
||||
{
|
||||
if (method_exists($this, 'expectException')) {
|
||||
$this->expectException('Symfony\Component\Serializer\Exception\UnexpectedValueException');
|
||||
$this->expectExceptionMessage('Invalid XML data, it can not be empty.');
|
||||
} else {
|
||||
$this->setExpectedException('Symfony\Component\Serializer\Exception\UnexpectedValueException', 'Invalid XML data, it can not be empty.');
|
||||
}
|
||||
$this->encoder->decode(' ', 'xml');
|
||||
}
|
||||
|
||||
protected function getXmlSource()
|
||||
{
|
||||
return '<?xml version="1.0"?>'."\n".
|
||||
'<response>'.
|
||||
'<foo>foo</foo>'.
|
||||
'<bar>a</bar><bar>b</bar>'.
|
||||
'<baz><key>val</key><key2>val</key2><item key="A B">bar</item>'.
|
||||
'<item><title>title1</title></item><item><title>title2</title></item>'.
|
||||
'<Barry><FooBar id="1"><Baz>Ed</Baz></FooBar></Barry></baz>'.
|
||||
'<qux>1</qux>'.
|
||||
'</response>'."\n";
|
||||
}
|
||||
|
||||
protected function getNamespacedXmlSource()
|
||||
{
|
||||
return '<?xml version="1.0"?>'."\n".
|
||||
'<response xmlns="http://www.w3.org/2005/Atom" xmlns:app="http://www.w3.org/2007/app" xmlns:media="http://search.yahoo.com/mrss/" xmlns:gd="http://schemas.google.com/g/2005" xmlns:yt="http://gdata.youtube.com/schemas/2007">'.
|
||||
'<qux>1</qux>'.
|
||||
'<app:foo>foo</app:foo>'.
|
||||
'<yt:bar>a</yt:bar><yt:bar>b</yt:bar>'.
|
||||
'<media:baz><media:key>val</media:key><media:key2>val</media:key2><item key="A B">bar</item>'.
|
||||
'<item><title>title1</title></item><item><title>title2</title></item>'.
|
||||
'<Barry size="large"><FooBar gd:id="1"><Baz>Ed</Baz></FooBar></Barry></media:baz>'.
|
||||
'</response>'."\n";
|
||||
}
|
||||
|
||||
protected function getNamespacedArray()
|
||||
{
|
||||
return array(
|
||||
'@xmlns' => 'http://www.w3.org/2005/Atom',
|
||||
'@xmlns:app' => 'http://www.w3.org/2007/app',
|
||||
'@xmlns:media' => 'http://search.yahoo.com/mrss/',
|
||||
'@xmlns:gd' => 'http://schemas.google.com/g/2005',
|
||||
'@xmlns:yt' => 'http://gdata.youtube.com/schemas/2007',
|
||||
'qux' => '1',
|
||||
'app:foo' => 'foo',
|
||||
'yt:bar' => array('a', 'b'),
|
||||
'media:baz' => array(
|
||||
'media:key' => 'val',
|
||||
'media:key2' => 'val',
|
||||
'A B' => 'bar',
|
||||
'item' => array(
|
||||
array(
|
||||
'title' => 'title1',
|
||||
),
|
||||
array(
|
||||
'title' => 'title2',
|
||||
),
|
||||
),
|
||||
'Barry' => array(
|
||||
'@size' => 'large',
|
||||
'FooBar' => array(
|
||||
'Baz' => 'Ed',
|
||||
'@gd:id' => 1,
|
||||
),
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
||||
protected function getObject()
|
||||
{
|
||||
$obj = new Dummy();
|
||||
$obj->foo = 'foo';
|
||||
$obj->bar = array('a', 'b');
|
||||
$obj->baz = array('key' => 'val', 'key2' => 'val', 'A B' => 'bar', 'item' => array(array('title' => 'title1'), array('title' => 'title2')), 'Barry' => array('FooBar' => array('Baz' => 'Ed', '@id' => 1)));
|
||||
$obj->qux = '1';
|
||||
|
||||
return $obj;
|
||||
}
|
||||
|
||||
public function testEncodeXmlWithBoolValue()
|
||||
{
|
||||
$expectedXml = <<<'XML'
|
||||
<?xml version="1.0"?>
|
||||
<response><foo>1</foo><bar>0</bar></response>
|
||||
|
||||
XML;
|
||||
|
||||
$actualXml = $this->encoder->encode(array('foo' => true, 'bar' => false), 'xml');
|
||||
|
||||
$this->assertEquals($expectedXml, $actualXml);
|
||||
}
|
||||
|
||||
public function testEncodeXmlWithDateTimeObjectValue()
|
||||
{
|
||||
$xmlEncoder = $this->createXmlEncoderWithDateTimeNormalizer();
|
||||
|
||||
$actualXml = $xmlEncoder->encode(array('dateTime' => new \DateTime($this->exampleDateTimeString)), 'xml');
|
||||
|
||||
$this->assertEquals($this->createXmlWithDateTime(), $actualXml);
|
||||
}
|
||||
|
||||
public function testEncodeXmlWithDateTimeObjectField()
|
||||
{
|
||||
$xmlEncoder = $this->createXmlEncoderWithDateTimeNormalizer();
|
||||
|
||||
$actualXml = $xmlEncoder->encode(array('foo' => array('@dateTime' => new \DateTime($this->exampleDateTimeString))), 'xml');
|
||||
|
||||
$this->assertEquals($this->createXmlWithDateTimeField(), $actualXml);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return XmlEncoder
|
||||
*/
|
||||
private function createXmlEncoderWithDateTimeNormalizer()
|
||||
{
|
||||
$encoder = new XmlEncoder();
|
||||
$serializer = new Serializer(array($this->createMockDateTimeNormalizer()), array('xml' => new XmlEncoder()));
|
||||
$encoder->setSerializer($serializer);
|
||||
|
||||
return $encoder;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return \PHPUnit_Framework_MockObject_MockObject|NormalizerInterface
|
||||
*/
|
||||
private function createMockDateTimeNormalizer()
|
||||
{
|
||||
$mock = $this->getMockBuilder('\Symfony\Component\Serializer\Normalizer\CustomNormalizer')->getMock();
|
||||
|
||||
$mock
|
||||
->expects($this->once())
|
||||
->method('normalize')
|
||||
->with(new \DateTime($this->exampleDateTimeString), 'xml', array())
|
||||
->willReturn($this->exampleDateTimeString);
|
||||
|
||||
$mock
|
||||
->expects($this->once())
|
||||
->method('supportsNormalization')
|
||||
->with(new \DateTime($this->exampleDateTimeString), 'xml')
|
||||
->willReturn(true);
|
||||
|
||||
return $mock;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string
|
||||
*/
|
||||
private function createXmlWithDateTime()
|
||||
{
|
||||
return sprintf('<?xml version="1.0"?>
|
||||
<response><dateTime>%s</dateTime></response>
|
||||
', $this->exampleDateTimeString);
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string
|
||||
*/
|
||||
private function createXmlWithDateTimeField()
|
||||
{
|
||||
return sprintf('<?xml version="1.0"?>
|
||||
<response><foo dateTime="%s"/></response>
|
||||
', $this->exampleDateTimeString);
|
||||
}
|
||||
}
|
71
vendor/symfony/serializer/Tests/Encoder/YamlEncoderTest.php
vendored
Normal file
71
vendor/symfony/serializer/Tests/Encoder/YamlEncoderTest.php
vendored
Normal file
|
@ -0,0 +1,71 @@
|
|||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of the Symfony package.
|
||||
*
|
||||
* (c) Fabien Potencier <fabien@symfony.com>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace Symfony\Component\Serializer\Tests\Encoder;
|
||||
|
||||
use PHPUnit\Framework\TestCase;
|
||||
use Symfony\Component\Serializer\Encoder\YamlEncoder;
|
||||
use Symfony\Component\Yaml\Dumper;
|
||||
use Symfony\Component\Yaml\Parser;
|
||||
use Symfony\Component\Yaml\Yaml;
|
||||
|
||||
/**
|
||||
* @author Kévin Dunglas <dunglas@gmail.com>
|
||||
*/
|
||||
class YamlEncoderTest extends TestCase
|
||||
{
|
||||
public function testEncode()
|
||||
{
|
||||
$encoder = new YamlEncoder();
|
||||
|
||||
$this->assertEquals('foo', $encoder->encode('foo', 'yaml'));
|
||||
$this->assertEquals('{ foo: 1 }', $encoder->encode(array('foo' => 1), 'yaml'));
|
||||
}
|
||||
|
||||
public function testSupportsEncoding()
|
||||
{
|
||||
$encoder = new YamlEncoder();
|
||||
|
||||
$this->assertTrue($encoder->supportsEncoding('yaml'));
|
||||
$this->assertFalse($encoder->supportsEncoding('json'));
|
||||
}
|
||||
|
||||
public function testDecode()
|
||||
{
|
||||
$encoder = new YamlEncoder();
|
||||
|
||||
$this->assertEquals('foo', $encoder->decode('foo', 'yaml'));
|
||||
$this->assertEquals(array('foo' => 1), $encoder->decode('{ foo: 1 }', 'yaml'));
|
||||
}
|
||||
|
||||
public function testSupportsDecoding()
|
||||
{
|
||||
$encoder = new YamlEncoder();
|
||||
|
||||
$this->assertTrue($encoder->supportsDecoding('yaml'));
|
||||
$this->assertFalse($encoder->supportsDecoding('json'));
|
||||
}
|
||||
|
||||
public function testContext()
|
||||
{
|
||||
$encoder = new YamlEncoder(new Dumper(), new Parser(), array('yaml_inline' => 1, 'yaml_indent' => 4, 'yaml_flags' => Yaml::DUMP_OBJECT | Yaml::PARSE_OBJECT));
|
||||
|
||||
$obj = new \stdClass();
|
||||
$obj->bar = 2;
|
||||
|
||||
$legacyTag = " foo: !php/object:O:8:\"stdClass\":1:{s:3:\"bar\";i:2;}\n";
|
||||
$spacedTag = " foo: !php/object 'O:8:\"stdClass\":1:{s:3:\"bar\";i:2;}'\n";
|
||||
$this->assertThat($encoder->encode(array('foo' => $obj), 'yaml'), $this->logicalOr($this->equalTo($legacyTag), $this->equalTo($spacedTag)));
|
||||
$this->assertEquals(' { foo: null }', $encoder->encode(array('foo' => $obj), 'yaml', array('yaml_inline' => 0, 'yaml_indent' => 2, 'yaml_flags' => 0)));
|
||||
$this->assertEquals(array('foo' => $obj), $encoder->decode("foo: !php/object 'O:8:\"stdClass\":1:{s:3:\"bar\";i:2;}'", 'yaml'));
|
||||
$this->assertEquals(array('foo' => null), $encoder->decode("foo: !php/object 'O:8:\"stdClass\":1:{s:3:\"bar\";i:2;}'", 'yaml', array('yaml_flags' => 0)));
|
||||
}
|
||||
}
|
Reference in a new issue