cacert-testmgr/external/ZendFramework-1.9.5/tests/Zend/JsonTest.php

798 lines
24 KiB
PHP
Raw Permalink Normal View History

<?php
/**
* Zend Framework
*
* LICENSE
*
* This source file is subject to the new BSD license that is bundled
* with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* http://framework.zend.com/license/new-bsd
* If you did not receive a copy of the license and are unable to
* obtain it through the world-wide-web, please send an email
* to license@zend.com so we can send you a copy immediately.
*
* @category Zend
* @package Zend_Json
* @subpackage UnitTests
* @copyright Copyright (c) 2005-2009 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
* @version $Id: JsonTest.php 17363 2009-08-03 07:40:18Z bkarwin $
*/
/**
* Test helper
*/
require_once dirname(__FILE__) . '/../TestHelper.php';
/**
* @see Zend_Json
*/
require_once 'Zend/Json.php';
/**
* @see Zend_Json_Expr
*/
require_once 'Zend/Json/Expr.php';
/**
* @see Zend_Json_Encoder
*/
require_once 'Zend/Json/Encoder.php';
/**
* @see Zend_Json_Decoder
*/
require_once 'Zend/Json/Decoder.php';
/**
* @category Zend
* @package Zend_Json
* @subpackage UnitTests
* @copyright Copyright (c) 2005-2009 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
* @group Zend_Json
*/
class Zend_JsonTest extends PHPUnit_Framework_TestCase
{
private $_originalUseBuiltinEncoderDecoderValue;
public function setUp()
{
$this->_originalUseBuiltinEncoderDecoderValue = Zend_Json::$useBuiltinEncoderDecoder;
}
public function tearDown()
{
Zend_Json::$useBuiltinEncoderDecoder = $this->_originalUseBuiltinEncoderDecoderValue;
}
public function testJsonWithPhpJsonExtension()
{
if (!extension_loaded('json')) {
$this->markTestSkipped('JSON extension is not loaded');
}
Zend_Json::$useBuiltinEncoderDecoder = false;
$this->_testJson(array('string', 327, true, null));
}
public function testJsonWithBuiltins()
{
Zend_Json::$useBuiltinEncoderDecoder = true;
$this->_testJson(array('string', 327, true, null));
}
/**
* Test encoding and decoding in a single step
* @param array $values array of values to test against encode/decode
*/
protected function _testJson($values)
{
$encoded = Zend_Json::encode($values);
$this->assertEquals($values, Zend_Json::decode($encoded));
}
/**
* test null encoding/decoding
*/
public function testNull()
{
$this->_testEncodeDecode(array(null));
}
/**
* test boolean encoding/decoding
*/
public function testBoolean()
{
$this->assertTrue(Zend_Json_Decoder::decode(Zend_Json_Encoder::encode(true)));
$this->assertFalse(Zend_Json_Decoder::decode(Zend_Json_Encoder::encode(false)));
}
/**
* test integer encoding/decoding
*/
public function testInteger()
{
$this->_testEncodeDecode(array(-2));
$this->_testEncodeDecode(array(-1));
$zero = Zend_Json_Decoder::decode(Zend_Json_Encoder::encode(0));
$this->assertEquals(0, $zero, 'Failed 0 integer test. Encoded: ' . serialize(Zend_Json_Encoder::encode(0)));
}
/**
* test float encoding/decoding
*/
public function testFloat()
{
$this->_testEncodeDecode(array(-2.1, 1.2));
}
/**
* test string encoding/decoding
*/
public function testString()
{
$this->_testEncodeDecode(array('string'));
$this->assertEquals('', Zend_Json_Decoder::decode(Zend_Json_Encoder::encode('')), 'Empty string encoded: ' . serialize(Zend_Json_Encoder::encode('')));
}
/**
* Test backslash escaping of string
*/
public function testString2()
{
$string = 'INFO: Path \\\\test\\123\\abc';
$expected = '"INFO: Path \\\\\\\\test\\\\123\\\\abc"';
$encoded = Zend_Json_Encoder::encode($string);
$this->assertEquals($expected, $encoded, 'Backslash encoding incorrect: expected: ' . serialize($expected) . '; received: ' . serialize($encoded) . "\n");
$this->assertEquals($string, Zend_Json_Decoder::decode($encoded));
}
/**
* Test newline escaping of string
*/
public function testString3()
{
$expected = '"INFO: Path\nSome more"';
$string = "INFO: Path\nSome more";
$encoded = Zend_Json_Encoder::encode($string);
$this->assertEquals($expected, $encoded, 'Newline encoding incorrect: expected ' . serialize($expected) . '; received: ' . serialize($encoded) . "\n");
$this->assertEquals($string, Zend_Json_Decoder::decode($encoded));
}
/**
* Test tab/non-tab escaping of string
*/
public function testString4()
{
$expected = '"INFO: Path\\t\\\\tSome more"';
$string = "INFO: Path\t\\tSome more";
$encoded = Zend_Json_Encoder::encode($string);
$this->assertEquals($expected, $encoded, 'Tab encoding incorrect: expected ' . serialize($expected) . '; received: ' . serialize($encoded) . "\n");
$this->assertEquals($string, Zend_Json_Decoder::decode($encoded));
}
/**
* Test double-quote escaping of string
*/
public function testString5()
{
$expected = '"INFO: Path \"Some more\""';
$string = 'INFO: Path "Some more"';
$encoded = Zend_Json_Encoder::encode($string);
$this->assertEquals($expected, $encoded, 'Quote encoding incorrect: expected ' . serialize($expected) . '; received: ' . serialize($encoded) . "\n");
$this->assertEquals($string, Zend_Json_Decoder::decode($encoded));
}
/**
* test indexed array encoding/decoding
*/
public function testArray()
{
$array = array(1, 'one', 2, 'two');
$encoded = Zend_Json_Encoder::encode($array);
$this->assertSame($array, Zend_Json_Decoder::decode($encoded), 'Decoded array does not match: ' . serialize($encoded));
}
/**
* test associative array encoding/decoding
*/
public function testAssocArray()
{
$this->_testEncodeDecode(array(array('one' => 1, 'two' => 2)));
}
/**
* test associative array encoding/decoding, with mixed key types
*/
public function testAssocArray2()
{
$this->_testEncodeDecode(array(array('one' => 1, 2 => 2)));
}
/**
* test associative array encoding/decoding, with integer keys not starting at 0
*/
public function testAssocArray3()
{
$this->_testEncodeDecode(array(array(1 => 'one', 2 => 'two')));
}
/**
* test object encoding/decoding (decoding to array)
*/
public function testObject()
{
$value = new stdClass();
$value->one = 1;
$value->two = 2;
$array = array('__className' => 'stdClass', 'one' => 1, 'two' => 2);
$encoded = Zend_Json_Encoder::encode($value);
$this->assertSame($array, Zend_Json_Decoder::decode($encoded));
}
/**
* test object encoding/decoding (decoding to stdClass)
*/
public function testObjectAsObject()
{
$value = new stdClass();
$value->one = 1;
$value->two = 2;
$encoded = Zend_Json_Encoder::encode($value);
$decoded = Zend_Json_Decoder::decode($encoded, Zend_Json::TYPE_OBJECT);
$this->assertTrue(is_object($decoded), 'Not decoded as an object');
$this->assertTrue($decoded instanceof StdClass, 'Not a StdClass object');
$this->assertTrue(isset($decoded->one), 'Expected property not set');
$this->assertEquals($value->one, $decoded->one, 'Unexpected value');
}
/**
* Test that arrays of objects decode properly; see issue #144
*/
public function testDecodeArrayOfObjects()
{
$value = '[{"id":1},{"foo":2}]';
$expect = array(array('id' => 1), array('foo' => 2));
$this->assertEquals($expect, Zend_Json_Decoder::decode($value));
}
/**
* Test that objects of arrays decode properly; see issue #107
*/
public function testDecodeObjectOfArrays()
{
$value = '{"codeDbVar" : {"age" : ["int", 5], "prenom" : ["varchar", 50]}, "234" : [22, "jb"], "346" : [64, "francois"], "21" : [12, "paul"]}';
$expect = array(
'codeDbVar' => array(
'age' => array('int', 5),
'prenom' => array('varchar', 50),
),
234 => array(22, 'jb'),
346 => array(64, 'francois'),
21 => array(12, 'paul')
);
$this->assertEquals($expect, Zend_Json_Decoder::decode($value));
}
/**
* Test encoding and decoding in a single step
* @param array $values array of values to test against encode/decode
*/
protected function _testEncodeDecode($values)
{
foreach ($values as $value) {
$encoded = Zend_Json_Encoder::encode($value);
$this->assertEquals($value, Zend_Json_Decoder::decode($encoded));
}
}
/**
* Test that version numbers such as 4.10 are encoded and decoded properly;
* See ZF-377
*/
public function testEncodeReleaseNumber()
{
$value = '4.10';
$this->_testEncodeDecode(array($value));
}
/**
* Tests that spaces/linebreaks prior to a closing right bracket don't throw
* exceptions. See ZF-283.
*/
public function testEarlyLineBreak()
{
$expected = array('data' => array(1, 2, 3, 4));
$json = '{"data":[1,2,3,4' . "\n]}";
$this->assertEquals($expected, Zend_Json_Decoder::decode($json));
$json = '{"data":[1,2,3,4 ]}';
$this->assertEquals($expected, Zend_Json_Decoder::decode($json));
}
/**
* Tests for ZF-504
*
* Three confirmed issues reported:
* - encoder improperly encoding empty arrays as structs
* - decoder happily decoding clearly borked JSON
* - decoder decoding octal values improperly (shouldn't decode them at all, as JSON does not support them)
*/
public function testZf504()
{
$test = array();
$this->assertSame('[]', Zend_Json_Encoder::encode($test));
try {
$json = '[a"],["a],[][]';
$test = Zend_Json_Decoder::decode($json);
$this->fail("Should not be able to decode '$json'");
$json = '[a"],["a]';
$test = Zend_Json_Decoder::decode($json);
$this->fail("Should not be able to decode '$json'");
} catch (Exception $e) {
// success
}
try {
$expected = 010;
$test = Zend_Json_Decoder::decode('010');
$this->fail('Octal values are not supported in JSON notation');
} catch (Exception $e) {
// sucess
}
}
/**
* Tests for ZF-461
*
* Check to see that cycling detection works properly
*/
public function testZf461()
{
$item1 = new Zend_JsonTest_Item() ;
$item2 = new Zend_JsonTest_Item() ;
$everything = array() ;
$everything['allItems'] = array($item1, $item2) ;
$everything['currentItem'] = $item1 ;
try {
$encoded = Zend_Json_Encoder::encode($everything);
} catch (Exception $e) {
$this->fail('Object cycling checks should check for recursion, not duplicate usage of an item');
}
try {
$encoded = Zend_Json_Encoder::encode($everything, true);
$this->fail('Object cycling not allowed when cycleCheck parameter is true');
} catch (Exception $e) {
// success
}
}
/**
* Test for ZF-4053
*
* Check to see that cyclical exceptions are silenced when
* $option['silenceCyclicalExceptions'] = true is used
*/
public function testZf4053()
{
$item1 = new Zend_JsonTest_Item() ;
$item2 = new Zend_JsonTest_Item() ;
$everything = array() ;
$everything['allItems'] = array($item1, $item2) ;
$everything['currentItem'] = $item1 ;
$options = array('silenceCyclicalExceptions'=>true);
Zend_Json::$useBuiltinEncoderDecoder = true;
$encoded = Zend_Json::encode($everything, true, $options);
$json = '{"allItems":[{"__className":"Zend_JsonTest_Item"},{"__className":"Zend_JsonTest_Item"}],"currentItem":"* RECURSION (Zend_JsonTest_Item) *"}';
$this->assertEquals($encoded,$json);
}
public function testEncodeObject()
{
$actual = new Zend_JsonTest_Object();
$encoded = Zend_Json_Encoder::encode($actual);
$decoded = Zend_Json_Decoder::decode($encoded, Zend_Json::TYPE_OBJECT);
$this->assertTrue(isset($decoded->__className));
$this->assertEquals('Zend_JsonTest_Object', $decoded->__className);
$this->assertTrue(isset($decoded->foo));
$this->assertEquals('bar', $decoded->foo);
$this->assertTrue(isset($decoded->bar));
$this->assertEquals('baz', $decoded->bar);
$this->assertFalse(isset($decoded->_foo));
}
public function testEncodeClass()
{
$encoded = Zend_Json_Encoder::encodeClass('Zend_JsonTest_Object');
$this->assertContains("Class.create('Zend_JsonTest_Object'", $encoded);
$this->assertContains("ZAjaxEngine.invokeRemoteMethod(this, 'foo'", $encoded);
$this->assertContains("ZAjaxEngine.invokeRemoteMethod(this, 'bar'", $encoded);
$this->assertNotContains("ZAjaxEngine.invokeRemoteMethod(this, 'baz'", $encoded);
$this->assertContains('variables:{foo:"bar",bar:"baz"}', $encoded);
$this->assertContains('constants : {FOO: "bar"}', $encoded);
}
public function testEncodeClasses()
{
$encoded = Zend_Json_Encoder::encodeClasses(array('Zend_JsonTest_Object', 'Zend_JsonTest'));
$this->assertContains("Class.create('Zend_JsonTest_Object'", $encoded);
$this->assertContains("Class.create('Zend_JsonTest'", $encoded);
}
public function testToJsonSerialization()
{
$toJsonObject = new ToJsonClass();
$result = Zend_Json::encode($toJsonObject);
$this->assertEquals('{"firstName":"John","lastName":"Doe","email":"john@doe.com"}', $result);
}
/**
* test encoding array with Zend_Json_Expr
*
* @group ZF-4946
*/
public function testEncodingArrayWithExpr()
{
$expr = new Zend_Json_Expr('window.alert("Zend Json Expr")');
$array = array('expr'=>$expr, 'int'=>9, 'string'=>'text');
$result = Zend_Json::encode($array, false, array('enableJsonExprFinder' => true));
$expected = '{"expr":window.alert("Zend Json Expr"),"int":9,"string":"text"}';
$this->assertEquals($expected, $result);
}
/**
* test encoding object with Zend_Json_Expr
*
* @group ZF-4946
*/
public function testEncodingObjectWithExprAndInternalEncoder()
{
Zend_Json::$useBuiltinEncoderDecoder = true;
$expr = new Zend_Json_Expr('window.alert("Zend Json Expr")');
$obj = new stdClass();
$obj->expr = $expr;
$obj->int = 9;
$obj->string = 'text';
$result = Zend_Json::encode($obj, false, array('enableJsonExprFinder' => true));
$expected = '{"__className":"stdClass","expr":window.alert("Zend Json Expr"),"int":9,"string":"text"}';
$this->assertEquals($expected, $result);
}
/**
* test encoding object with Zend_Json_Expr
*
* @group ZF-4946
*/
public function testEncodingObjectWithExprAndExtJson()
{
if(!function_exists('json_encode')) {
$this->markTestSkipped('Test only works with ext/json enabled!');
}
Zend_Json::$useBuiltinEncoderDecoder = false;
$expr = new Zend_Json_Expr('window.alert("Zend Json Expr")');
$obj = new stdClass();
$obj->expr = $expr;
$obj->int = 9;
$obj->string = 'text';
$result = Zend_Json::encode($obj, false, array('enableJsonExprFinder' => true));
$expected = '{"expr":window.alert("Zend Json Expr"),"int":9,"string":"text"}';
$this->assertEquals($expected, $result);
}
/**
* test encoding object with ToJson and Zend_Json_Expr
*
* @group ZF-4946
*/
public function testToJsonWithExpr()
{
Zend_Json::$useBuiltinEncoderDecoder = true;
$obj = new Zend_Json_ToJsonWithExpr();
$result = Zend_Json::encode($obj, false, array('enableJsonExprFinder' => true));
$expected = '{"expr":window.alert("Zend Json Expr"),"int":9,"string":"text"}';
$this->assertEquals($expected, $result);
}
/**
* Regression tests for Zend_Json_Expr and mutliple keys with the same name.
*
* @group ZF-4946
*/
public function testEncodingMultipleNestedSwitchingSameNameKeysWithDifferentJsonExprSettings()
{
$data = array(
0 => array(
"alpha" => new Zend_Json_Expr("function(){}"),
"beta" => "gamma",
),
1 => array(
"alpha" => "gamma",
"beta" => new Zend_Json_Expr("function(){}"),
),
2 => array(
"alpha" => "gamma",
"beta" => "gamma",
)
);
$result = Zend_Json::encode($data, false, array('enableJsonExprFinder' => true));
$this->assertEquals(
'[{"alpha":function(){},"beta":"gamma"},{"alpha":"gamma","beta":function(){}},{"alpha":"gamma","beta":"gamma"}]',
$result
);
}
/**
* Regression tests for Zend_Json_Expr and mutliple keys with the same name.
*
* @group ZF-4946
*/
public function testEncodingMultipleNestedIteratedSameNameKeysWithDifferentJsonExprSettings()
{
$data = array(
0 => array(
"alpha" => "alpha"
),
1 => array(
"alpha" => "beta",
),
2 => array(
"alpha" => new Zend_Json_Expr("gamma"),
),
3 => array(
"alpha" => "delta",
),
4 => array(
"alpha" => new Zend_Json_Expr("epsilon"),
)
);
$result = Zend_Json::encode($data, false, array('enableJsonExprFinder' => true));
$this->assertEquals('[{"alpha":"alpha"},{"alpha":"beta"},{"alpha":gamma},{"alpha":"delta"},{"alpha":epsilon}]', $result);
}
public function testDisabledJsonExprFinder()
{
Zend_Json::$useBuiltinEncoderDecoder = true;
$data = array(
0 => array(
"alpha" => new Zend_Json_Expr("function(){}"),
"beta" => "gamma",
),
);
$result = Zend_Json::encode($data);
$this->assertEquals(
'[{"alpha":{"__className":"Zend_Json_Expr"},"beta":"gamma"}]',
$result
);
}
/**
* @group ZF-4054
*/
public function testEncodeWithUtf8IsTransformedToPackedSyntax()
{
$data = array("Отмена");
$result = Zend_Json_Encoder::encode($data);
$this->assertEquals('["\u041e\u0442\u043c\u0435\u043d\u0430"]', $result);
}
/**
* @group ZF-4054
*
* This test contains assertions from the Solar Framework by Paul M. Jones
* @link http://solarphp.com
*/
public function testEncodeWithUtf8IsTransformedSolarRegression()
{
$expect = '"h\u00c3\u00a9ll\u00c3\u00b6 w\u00c3\u00b8r\u00c5\u201ad"';
$this->assertEquals($expect, Zend_Json_Encoder::encode('héllö wød'));
$this->assertEquals('héllö wød', Zend_Json_Decoder::decode($expect));
$expect = '"\u0440\u0443\u0441\u0441\u0438\u0448"';
$this->assertEquals($expect, Zend_Json_Encoder::encode("руссиш"));
$this->assertEquals("руссиш", Zend_Json_Decoder::decode($expect));
}
/**
* @group ZF-4054
*/
public function testEncodeUnicodeStringSolarRegression()
{
$value = 'héllö wød';
$expected = 'h\u00c3\u00a9ll\u00c3\u00b6 w\u00c3\u00b8r\u00c5\u201ad';
$this->assertEquals($expected, Zend_Json_Encoder::encodeUnicodeString($value));
$value = "\xC3\xA4";
$expected = '\u00e4';
$this->assertEquals($expected, Zend_Json_Encoder::encodeUnicodeString($value));
$value = "\xE1\x82\xA0\xE1\x82\xA8";
$expected = '\u10a0\u10a8';
$this->assertEquals($expected, Zend_Json_Encoder::encodeUnicodeString($value));
}
/**
* @group ZF-4054
*/
public function testDecodeUnicodeStringSolarRegression()
{
$expected = 'héllö wød';
$value = 'h\u00c3\u00a9ll\u00c3\u00b6 w\u00c3\u00b8r\u00c5\u201ad';
$this->assertEquals($expected, Zend_Json_Decoder::decodeUnicodeString($value));
$expected = "\xC3\xA4";
$value = '\u00e4';
$this->assertEquals($expected, Zend_Json_Decoder::decodeUnicodeString($value));
$value = '\u10a0';
$expected = "\xE1\x82\xA0";
$this->assertEquals($expected, Zend_Json_Decoder::decodeUnicodeString($value));
}
/**
* @group ZF-4054
*
* This test contains assertions from the Solar Framework by Paul M. Jones
* @link http://solarphp.com
*/
public function testEncodeWithUtf8IsTransformedSolarRegressionEqualsJsonExt()
{
if(function_exists('json_encode') == false) {
$this->markTestSkipped('Test can only be run, when ext/json is installed.');
}
$this->assertEquals(
json_encode('héllö wød'),
Zend_Json_Encoder::encode('héllö wød')
);
$this->assertEquals(
json_encode("руссиш"),
Zend_Json_Encoder::encode("руссиш")
);
}
/**
* @group ZF-4946
*/
public function testUtf8JsonExprFinder()
{
$data = array("Отмена" => new Zend_Json_Expr("foo"));
Zend_Json::$useBuiltinEncoderDecoder = true;
$result = Zend_Json::encode($data, false, array('enableJsonExprFinder' => true));
$this->assertEquals('{"\u041e\u0442\u043c\u0435\u043d\u0430":foo}', $result);
Zend_Json::$useBuiltinEncoderDecoder = false;
$result = Zend_Json::encode($data, false, array('enableJsonExprFinder' => true));
$this->assertEquals('{"\u041e\u0442\u043c\u0435\u043d\u0430":foo}', $result);
}
/**
* @group ZF-4437
*/
public function testKommaDecimalIsConvertedToCorrectJsonWithDot()
{
$localeInfo = localeconv();
if($localeInfo['decimal_point'] != ",") {
$this->markTestSkipped("This test only works for platforms where , is the decimal point separator.");
}
Zend_Json::$useBuiltinEncoderDecoder = true;
$this->assertEquals("[1.20, 1.68]", Zend_Json_Encode::encode(array(
(float)"1,20", (float)"1,68"
)));
}
public function testEncodeObjectImplementingIterator()
{
$this->markTestIncomplete('Test is not yet finished.');
}
}
/**
* Zend_JsonTest_Item: test item for use with testZf461()
*/
class Zend_JsonTest_Item
{
}
/**
* Zend_JsonTest_Object: test class for encoding classes
*/
class Zend_JsonTest_Object
{
const FOO = 'bar';
public $foo = 'bar';
public $bar = 'baz';
protected $_foo = 'fooled you';
public function foo($bar, $baz)
{
}
public function bar($baz)
{
}
protected function baz()
{
}
}
class ToJsonClass
{
private $_firstName = 'John';
private $_lastName = 'Doe';
private $_email = 'john@doe.com';
public function toJson()
{
$data = array(
'firstName' => $this->_firstName,
'lastName' => $this->_lastName,
'email' => $this->_email
);
return Zend_Json::encode($data);
}
}
/**
* ISSUE ZF-4946
*
*/
class Zend_Json_ToJsonWithExpr
{
private $_string = 'text';
private $_int = 9;
private $_expr = 'window.alert("Zend Json Expr")';
public function toJson()
{
$data = array(
'expr' => new Zend_Json_Expr($this->_expr),
'int' => $this->_int,
'string' => $this->_string
);
return Zend_Json::encode($data, false, array('enableJsonExprFinder' => true));
}
}