This repository has been archived on 2023-08-20. You can view files and clone it, but cannot push or open issues or pull requests.
symfony/src/Symfony/Component/VarDumper/Tests/CliDumperTest.php

420 lines
8.7 KiB
PHP
Raw Normal View History

2014-04-05 20:31:16 +01:00
<?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\VarDumper\Tests;
use Symfony\Component\VarDumper\Cloner\VarCloner;
2014-04-05 20:31:16 +01:00
use Symfony\Component\VarDumper\Dumper\CliDumper;
use Symfony\Component\VarDumper\Test\VarDumperTestCase;
2014-04-05 20:31:16 +01:00
/**
* @author Nicolas Grekas <p@tchwork.com>
*/
class CliDumperTest extends VarDumperTestCase
2014-04-05 20:31:16 +01:00
{
public function testGet()
{
require __DIR__.'/Fixtures/dumb-var.php';
$dumper = new CliDumper('php://output');
$dumper->setColors(false);
$cloner = new VarCloner();
$cloner->addCasters(array(
':stream' => function ($res, $a) {
2015-06-30 18:32:40 +01:00
unset($a['uri'], $a['wrapper_data']);
return $a;
},
));
2014-04-05 20:31:16 +01:00
$data = $cloner->cloneVar($var);
ob_start();
$dumper->dump($data);
$out = ob_get_clean();
$out = preg_replace('/[ \t]+$/m', '', $out);
2014-09-26 08:07:47 +01:00
$intMax = PHP_INT_MAX;
2015-06-30 18:32:40 +01:00
$res = (int) $var['res'];
$closure54 = '';
2015-07-01 13:07:40 +01:00
$r = defined('HHVM_VERSION') ? '' : '#%d';
if (PHP_VERSION_ID >= 50400) {
$closure54 = <<<EOTXT
class: "Symfony\Component\VarDumper\Tests\CliDumperTest"
2015-07-01 13:07:40 +01:00
this: Symfony\Component\VarDumper\Tests\CliDumperTest {{$r} }
EOTXT;
}
2014-04-05 20:31:16 +01:00
2014-10-10 16:31:59 +01:00
$this->assertStringMatchesFormat(
2014-04-05 20:31:16 +01:00
<<<EOTXT
2015-06-30 18:32:40 +01:00
array:24 [
2014-04-05 20:31:16 +01:00
"number" => 1
2014-10-10 16:31:59 +01:00
0 => &1 null
2014-04-05 20:31:16 +01:00
"const" => 1.1
1 => true
2 => false
3 => NAN
4 => INF
5 => -INF
2014-09-26 08:07:47 +01:00
6 => {$intMax}
"str" => "déjà\\n"
7 => b"é\\x00"
2014-04-05 20:31:16 +01:00
"[]" => []
2015-06-30 18:32:40 +01:00
"res" => stream resource {@{$res}
2016-02-12 17:39:33 +00:00
%A wrapper_type: "plainfile"
stream_type: "STDIO"
2014-04-05 20:31:16 +01:00
mode: "r"
unread_bytes: 0
seekable: true
2016-02-12 17:39:33 +00:00
%A options: []
2014-04-05 20:31:16 +01:00
}
2014-10-10 16:31:59 +01:00
"obj" => Symfony\Component\VarDumper\Tests\Fixture\DumbFoo {#%d
+foo: "foo"
+"bar": "bar"
2014-04-05 20:31:16 +01:00
}
"closure" => Closure {{$r}{$closure54}
parameters: array:2 [
"\$a" => []
"&\$b" => array:2 [
"typeHint" => "PDO"
"default" => null
]
]
file: "{$var['file']}"
line: "{$var['line']} to {$var['line']}"
2014-04-05 20:31:16 +01:00
}
"line" => {$var['line']}
"nobj" => array:1 [
2014-10-10 16:31:59 +01:00
0 => &3 {#%d}
2014-04-05 20:31:16 +01:00
]
2014-10-10 16:31:59 +01:00
"recurs" => &4 array:1 [
0 => &4 array:1 [&4]
2014-04-05 20:31:16 +01:00
]
2015-06-30 18:32:40 +01:00
8 => &1 null
2014-10-10 16:31:59 +01:00
"sobj" => Symfony\Component\VarDumper\Tests\Fixture\DumbFoo {#%d}
"snobj" => &3 {#%d}
"snobj2" => {#%d}
2014-04-05 20:31:16 +01:00
"file" => "{$var['file']}"
b"bin-key-é" => ""
]
EOTXT
,
$out
);
}
/**
* @requires extension xml
*/
public function testXmlResource()
{
$var = xml_parser_create();
2015-07-01 13:07:40 +01:00
$this->assertDumpMatchesFormat(
<<<EOTXT
xml resource {
2015-07-01 13:07:40 +01:00
current_byte_index: %i
current_column_number: %i
current_line_number: 1
error_code: XML_ERROR_NONE
}
EOTXT
,
$var
);
}
public function testJsonCast()
{
$var = (array) json_decode('{"0":{},"1":null}');
foreach ($var as &$v) {
}
$var[] = &$v;
$var[''] = 2;
$this->assertDumpMatchesFormat(
<<<EOTXT
array:4 [
"0" => {}
"1" => &1 null
0 => &1 null
"" => 2
]
EOTXT
,
$var
);
}
public function testObjectCast()
{
$var = (object) array(1 => 1);
$var->{1} = 2;
$this->assertDumpMatchesFormat(
<<<EOTXT
{
+1: 1
+"1": 2
}
EOTXT
,
$var
);
}
2015-06-30 18:32:40 +01:00
public function testClosedResource()
{
if (defined('HHVM_VERSION') && HHVM_VERSION_ID < 30600) {
$this->markTestSkipped();
}
$var = fopen(__FILE__, 'r');
fclose($var);
$dumper = new CliDumper('php://output');
$dumper->setColors(false);
$cloner = new VarCloner();
$data = $cloner->cloneVar($var);
ob_start();
$dumper->dump($data);
$out = ob_get_clean();
$res = (int) $var;
$this->assertStringMatchesFormat(
<<<EOTXT
Closed resource @{$res}
2015-06-30 18:32:40 +01:00
EOTXT
,
$out
);
}
public function testThrowingCaster()
{
$out = fopen('php://memory', 'r+b');
$dumper = new CliDumper();
$dumper->setColors(false);
$cloner = new VarCloner();
2015-06-30 18:32:40 +01:00
$cloner->addCasters(array(
':stream' => function ($res, $a) {
unset($a['wrapper_data']);
return $a;
},
));
$cloner->addCasters(array(
':stream' => function () {
throw new \Exception('Foobar');
},
));
$line = __LINE__ - 3;
$file = __FILE__;
$ref = (int) $out;
$data = $cloner->cloneVar($out);
$dumper->dump($data, $out);
rewind($out);
$out = stream_get_contents($out);
2015-06-30 18:32:40 +01:00
$r = defined('HHVM_VERSION') ? '' : '#%d';
$this->assertStringMatchesFormat(
<<<EOTXT
stream resource {@{$ref}
2016-02-12 17:39:33 +00:00
%Awrapper_type: "PHP"
stream_type: "MEMORY"
2015-06-30 18:32:40 +01:00
mode: "%s+b"
unread_bytes: 0
seekable: true
uri: "php://memory"
2016-02-12 17:39:33 +00:00
%Aoptions: []
2015-06-30 18:32:40 +01:00
: Symfony\Component\VarDumper\Exception\ThrowingCasterException {{$r}
2015-04-03 18:35:00 +01:00
#message: "Unexpected Exception thrown from a caster: Foobar"
trace: array:1 [
0 => array:2 [
2015-06-30 18:32:40 +01:00
"call" => "%slosure%s()"
"file" => "{$file}:{$line}"
]
]
}
}
EOTXT
,
$out
);
}
public function testRefsInProperties()
{
$var = (object) array('foo' => 'foo');
$var->bar = &$var->foo;
$dumper = new CliDumper();
$dumper->setColors(false);
$cloner = new VarCloner();
$out = fopen('php://memory', 'r+b');
$data = $cloner->cloneVar($var);
$dumper->dump($data, $out);
rewind($out);
$out = stream_get_contents($out);
2015-06-30 18:32:40 +01:00
$r = defined('HHVM_VERSION') ? '' : '#%d';
$this->assertStringMatchesFormat(
<<<EOTXT
2015-06-30 18:32:40 +01:00
{{$r}
+"foo": &1 "foo"
+"bar": &1 "foo"
}
2014-04-05 20:31:16 +01:00
EOTXT
,
2015-03-30 16:59:31 +01:00
$out
);
}
/**
* @runInSeparateProcess
* @preserveGlobalState disabled
* @requires PHP 5.6
*/
public function testSpecialVars56()
{
$var = $this->getSpecialVars();
$this->assertDumpEquals(
<<<EOTXT
2015-01-13 12:58:22 +00:00
array:3 [
0 => array:1 [
0 => &1 array:1 [
0 => &1 array:1 [&1]
]
]
1 => array:1 [
"GLOBALS" => &2 array:1 [
"GLOBALS" => &2 array:1 [&2]
]
]
2015-01-13 12:58:22 +00:00
2 => &2 array:1 [&2]
]
EOTXT
,
2015-03-31 00:18:05 +01:00
$var
2014-04-05 20:31:16 +01:00
);
}
/**
* @runInSeparateProcess
* @preserveGlobalState disabled
*/
public function testGlobalsNoExt()
{
$var = $this->getSpecialVars();
unset($var[0]);
$out = '';
$dumper = new CliDumper(function ($line, $depth) use (&$out) {
if ($depth >= 0) {
$out .= str_repeat(' ', $depth).$line."\n";
}
});
$dumper->setColors(false);
$cloner = new VarCloner();
$refl = new \ReflectionProperty($cloner, 'useExt');
$refl->setAccessible(true);
$refl->setValue($cloner, false);
$data = $cloner->cloneVar($var);
$dumper->dump($data);
$this->assertSame(
<<<EOTXT
array:2 [
1 => array:1 [
"GLOBALS" => &1 array:1 [
"GLOBALS" => &1 array:1 [&1]
]
]
2 => &1 array:1 [&1]
]
EOTXT
,
$out
);
}
/**
* @runInSeparateProcess
* @preserveGlobalState disabled
*/
public function testBuggyRefs()
{
if (PHP_VERSION_ID >= 50600) {
$this->markTestSkipped('PHP 5.6 fixed refs counting');
}
$var = $this->getSpecialVars();
$var = $var[0];
$dumper = new CliDumper();
$dumper->setColors(false);
$cloner = new VarCloner();
$data = $cloner->cloneVar($var)->withMaxDepth(3);
$out = '';
$dumper->dump($data, function ($line, $depth) use (&$out) {
if ($depth >= 0) {
$out .= str_repeat(' ', $depth).$line."\n";
}
});
$this->assertSame(
<<<EOTXT
array:1 [
0 => array:1 [
0 => array:1 [
0 => array:1 [ …1]
]
]
]
EOTXT
,
$out
);
}
private function getSpecialVars()
{
foreach (array_keys($GLOBALS) as $var) {
if ('GLOBALS' !== $var) {
unset($GLOBALS[$var]);
}
}
$var = function &() {
$var = array();
$var[] = &$var;
return $var;
};
return array($var(), $GLOBALS, &$GLOBALS);
}
2014-04-05 20:31:16 +01:00
}