<?php
/**
* SimpleXMLElement Introspection
*/
error_reporting(~0);
$xml = '<document>
<child>
give
<grandchild a1="v1" a2="v2">
me
</grandchild>
<grandchild>
more
</grandchild>
sugar.
</child>
<child>
</child>
<single/>
</document>
';
echo substr_count($xml, "\r");
return;
$simple = new SimpleXMLElement($xml);
/**
* @param SimpleXMLElement $element
* @return string
*/
function simplexml_get_xml_without_declaration(SimpleXMLElement $element)
{
list($elementNode) = $element->xpath('.');
list($documentElement) = $element->xpath('/*');
$xml = $element->asXML();
if ($elementNode == $element and $documentElement == $element) {
list(, $xml) = explode("\n", $xml, 2);
}
return $xml;
}
$documentElement = $simple;
$attributeList = $simple->child->grandchild->attributes();
$attributeListEmpty = $simple->child->attributes();
$attribute = $simple->child->grandchild['a1'];
$suite = array(
'get_xml_nodecl' => array('simplexml_get_xml_without_declaration', array(
array($xml, $simple),
array($simple->child->asXML(), $simple->child),
)),
);
echo "Running tests with LIBXML ", LIBXML_DOTTED_VERSION, ":\n";
run_test_suite($suite);
function run_test_suite(array $testsuite)
{
foreach ($testsuite as $caselabel => $testcasedef) {
list($callback, $testcase) = $testcasedef;
$stats[] = run_testcase($testcase, $callback, $caselabel);
}
echo "\n";
$stat['tests'] = 0;
$stat['failures'] = 0;
foreach ($stats as $singled) {
$stat['tests'] += $singled['tests'];
$stat['failures'] += $singled['failures'];
echo $singled['messages'];
}
printf("Done %d tests with %d failures.", $stat['tests'], $stat['failures']);
}
function run_testcase(array $testcase, $callback, $label = null)
{
if ($label === null) $label = $callback;
$stats['tests'] = 0;
$stats['failures'] = 0;
$messages = '';
foreach ($testcase as $i => $test) {
list($expected, $subject, $testlabel) = $test + array(2 => "#$i");
$labeltest = $label . ' ' . $testlabel;
ob_start();
$result = run_test($expected, $subject, $callback, $labeltest);
$buffer = ob_get_clean();
echo $result ? '.' : 'F';
if ($buffer) {
$messages .= sprintf("### %s ###\n", $labeltest);
$messages .= $buffer;
}
$stats['tests']++;
if (!$result) $stats['failures']++;
}
return $stats + array('messages' => $messages);
}
function run_test($expected, $subject, $callback, $label)
{
$actual = call_user_func($callback, $subject);
if ($expected instanceof SimpleXMLElement and $actual instanceof SimpleXMLElement) {
$result = $actual == $expected;
} else {
$result = $actual === $expected;
}
if (!$result) {
$extra = '';
if ($subject instanceof SimpleXMLElement) {
$extra = sprintf(' with %s', rtrim($subject->asXML()));
}
printf("FAILED to test %s%s.\n", $label, $extra);
echo 'expected: ', var_dump($expected);
echo 'actual:', var_dump($actual);
}
return $result;
}
- Output for 5.1.0 - 5.1.6, 5.2.0 - 5.2.17, 5.3.0 - 5.3.29, 5.4.0 - 5.4.45, 5.5.0 - 5.5.38, 5.6.0 - 5.6.28, 7.0.0 - 7.0.20, 7.1.0 - 7.1.10, 7.2.0 - 7.2.33, 7.3.12 - 7.3.33, 7.4.0 - 7.4.33, 8.0.0 - 8.0.30, 8.1.0 - 8.1.27, 8.2.0 - 8.2.17, 8.3.0 - 8.3.4
- 0
- Output for 5.0.0 - 5.0.5
- Parse error: parse error, unexpected T_ARRAY, expecting '&' or T_VARIABLE in /in/PKAMV on line 66
Process exited with code 255. - Output for 4.4.2 - 4.4.9
- Parse error: syntax error, unexpected T_STRING, expecting ')' in /in/PKAMV on line 35
Process exited with code 255. - Output for 4.3.0 - 4.3.1, 4.3.5 - 4.3.11, 4.4.0 - 4.4.1
- Parse error: parse error, unexpected T_STRING, expecting ')' in /in/PKAMV on line 35
Process exited with code 255. - Output for 4.3.2 - 4.3.4
- Parse error: parse error, expecting `')'' in /in/PKAMV on line 35
Process exited with code 255.
preferences:
231.62 ms | 401 KiB | 350 Q