123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234 |
- <?php
- namespace Composer\Test\Json;
- use Seld\JsonLint\ParsingException;
- use Composer\Json\JsonFile;
- use Composer\Test\TestCase;
- class JsonFileTest extends TestCase
- {
- public function testParseErrorDetectExtraComma()
- {
- $json = '{
- "foo": "bar",
- }';
- $this->expectParseException('Parse error on line 2', $json);
- }
- public function testParseErrorDetectExtraCommaInArray()
- {
- $json = '{
- "foo": [
- "bar",
- ]
- }';
- $this->expectParseException('Parse error on line 3', $json);
- }
- public function testParseErrorDetectUnescapedBackslash()
- {
- $json = '{
- "fo\o": "bar"
- }';
- $this->expectParseException('Parse error on line 1', $json);
- }
- public function testParseErrorSkipsEscapedBackslash()
- {
- $json = '{
- "fo\\\\o": "bar"
- "a": "b"
- }';
- $this->expectParseException('Parse error on line 2', $json);
- }
- public function testParseErrorDetectSingleQuotes()
- {
- if (defined('JSON_PARSER_NOTSTRICT') && version_compare(phpversion('json'), '1.3.9', '<')) {
- $this->markTestSkipped('jsonc issue, see https://github.com/remicollet/pecl-json-c/issues/23');
- }
- $json = '{
- \'foo\': "bar"
- }';
- $this->expectParseException('Parse error on line 1', $json);
- }
- public function testParseErrorDetectMissingQuotes()
- {
- $json = '{
- foo: "bar"
- }';
- $this->expectParseException('Parse error on line 1', $json);
- }
- public function testParseErrorDetectArrayAsHash()
- {
- $json = '{
- "foo": ["bar": "baz"]
- }';
- $this->expectParseException('Parse error on line 2', $json);
- }
- public function testParseErrorDetectMissingComma()
- {
- $json = '{
- "foo": "bar"
- "bar": "foo"
- }';
- $this->expectParseException('Parse error on line 2', $json);
- }
- public function testSchemaValidation()
- {
- $json = new JsonFile(__DIR__.'/Fixtures/composer.json');
- $this->assertTrue($json->validateSchema());
- }
- public function testParseErrorDetectMissingCommaMultiline()
- {
- $json = '{
- "foo": "barbar"
- "bar": "foo"
- }';
- $this->expectParseException('Parse error on line 2', $json);
- }
- public function testParseErrorDetectMissingColon()
- {
- $json = '{
- "foo": "bar",
- "bar" "foo"
- }';
- $this->expectParseException('Parse error on line 3', $json);
- }
- public function testSimpleJsonString()
- {
- $data = array('name' => 'composer/composer');
- $json = '{
- "name": "composer/composer"
- }';
- $this->assertJsonFormat($json, $data);
- }
- public function testTrailingBackslash()
- {
- $data = array('Metadata\\' => 'src/');
- $json = '{
- "Metadata\\\\": "src/"
- }';
- $this->assertJsonFormat($json, $data);
- }
- public function testFormatEmptyArray()
- {
- $data = array('test' => array(), 'test2' => new \stdClass);
- $json = '{
- "test": [],
- "test2": {}
- }';
- $this->assertJsonFormat($json, $data);
- }
- public function testEscape()
- {
- $data = array("Metadata\\\"" => 'src/');
- $json = '{
- "Metadata\\\\\\"": "src/"
- }';
- $this->assertJsonFormat($json, $data);
- }
- public function testUnicode()
- {
- if (!function_exists('mb_convert_encoding') && PHP_VERSION_ID < 50400) {
- $this->markTestSkipped('Test requires the mbstring extension');
- }
- $data = array("Žluťoučký \" kůň" => "úpěl ďábelské ódy za €");
- $json = '{
- "Žluťoučký \" kůň": "úpěl ďábelské ódy za €"
- }';
- $this->assertJsonFormat($json, $data);
- }
- public function testOnlyUnicode()
- {
- if (!function_exists('mb_convert_encoding') && PHP_VERSION_ID < 50400) {
- $this->markTestSkipped('Test requires the mbstring extension');
- }
- $data = "\\/ƌ";
- $this->assertJsonFormat('"\\\\\\/ƌ"', $data, JsonFile::JSON_UNESCAPED_UNICODE);
- }
- public function testEscapedSlashes()
- {
- $data = "\\/foo";
- $this->assertJsonFormat('"\\\\\\/foo"', $data, 0);
- }
- public function testEscapedBackslashes()
- {
- $data = "a\\b";
- $this->assertJsonFormat('"a\\\\b"', $data, 0);
- }
- public function testEscapedUnicode()
- {
- $data = "ƌ";
- $this->assertJsonFormat('"\\u018c"', $data, 0);
- }
- public function testDoubleEscapedUnicode()
- {
- $jsonFile = new JsonFile('composer.json');
- $data = array("Zdjęcia","hjkjhl\\u0119kkjk");
- $encodedData = $jsonFile->encode($data);
- $doubleEncodedData = $jsonFile->encode(array('t' => $encodedData));
- $decodedData = json_decode($doubleEncodedData, true);
- $doubleData = json_decode($decodedData['t'], true);
- $this->assertEquals($data, $doubleData);
- }
- private function expectParseException($text, $json)
- {
- try {
- $result = JsonFile::parseJson($json);
- $this->fail(sprintf("Parsing should have failed but didn't.\nExpected:\n\"%s\"\nFor:\n\"%s\"\nGot:\n\"%s\"", $text, $json, var_export($result, true)));
- } catch (ParsingException $e) {
- $this->assertContains($text, $e->getMessage());
- }
- }
- private function assertJsonFormat($json, $data, $options = null)
- {
- $file = new JsonFile('composer.json');
- $json = str_replace("\r", '', $json);
- if (null === $options) {
- $this->assertEquals($json, $file->encode($data));
- } else {
- $this->assertEquals($json, $file->encode($data, $options));
- }
- }
- }
|