diff options
author | Hartmut Holzgraefe <hholzgra@php.net> | 2004-03-29 05:56:18 +0000 |
---|---|---|
committer | Hartmut Holzgraefe <hholzgra@php.net> | 2004-03-29 05:56:18 +0000 |
commit | 5e3b2e3d313219126b03e9f8e4722a152a213f0c (patch) | |
tree | 843bb8d4c37d969f40d6d06bd4de62e0137b6381 | |
parent | 31b042714ede6b83119176f40654e5a60986a425 (diff) | |
download | php-git-5e3b2e3d313219126b03e9f8e4722a152a213f0c.tar.gz |
Test updated to test for additional libxml2/expat inconsistencies
-rw-r--r-- | ext/xml/tests/bug26614.phpt | 77 |
1 files changed, 68 insertions, 9 deletions
diff --git a/ext/xml/tests/bug26614.phpt b/ext/xml/tests/bug26614.phpt index 1ff9d15782..14a4ea8a9f 100644 --- a/ext/xml/tests/bug26614.phpt +++ b/ext/xml/tests/bug26614.phpt @@ -2,7 +2,21 @@ Bug #26614 (CDATA sections skipped on line count) --FILE-- <?php -$xml ='<?xml version="1.0"?> +/* +this test works fine with Expat but fails with libxml +which we now use as default + +further investigation has shown that not only line count +is skippet on CDATA sections but that libxml does also +show different column numbers and byte positions depending +on context and in opposition to what one would expect to +see and what good old Expat reported just fine ... +*/ + +$xmls = array(); + +// Case 1: CDATA Sections +$xmls["CDATA"] ='<?xml version="1.0" encoding="iso-8859-1" ?> <data> <![CDATA[ multi @@ -12,18 +26,63 @@ block ]]> </data>'; +// Case 2: replace some characters so that we get comments instead +$xmls["Comment"] ='<?xml version="1.0" encoding="iso-8859-1" ?> +<data> +<!-- ATA[ +multi +line +CDATA +block +--> +</data>'; + +// Case 3: replace even more characters so that only textual data is left +$xmls["Text"] ='<?xml version="1.0" encoding="iso-8859-1" ?> +<data> +-!-- ATA[ +multi +line +CDATA +block +--- +</data>'; + function startElement($parser, $name, $attrs) { - echo "<$name> at line ".xml_get_current_line_number($parser)."\n"; + printf("<$name> at line %d, col %d (byte %d)\n", + xml_get_current_line_number($parser), + xml_get_current_column_number($parser), + xml_get_current_byte_index($parser)); } + function endElement($parser, $name) { - echo "</$name> at line ".xml_get_current_line_number($parser)."\n"; + printf("</$name> at line %d, col %d (byte %d)\n", + xml_get_current_line_number($parser), + xml_get_current_column_number($parser), + xml_get_current_byte_index($parser)); +} + +function characterData($parser, $data) { + // dummy } -$xml_parser = xml_parser_create(); -xml_set_element_handler($xml_parser, "startElement", "endElement"); -xml_parse($xml_parser, $xml); -xml_parser_free($xml_parser); +foreach ($xmls as $desc => $xml) { + echo "$desc\n"; + $xml_parser = xml_parser_create(); + xml_set_element_handler($xml_parser, "startElement", "endElement"); + xml_set_character_data_handler($xml_parser, "characterData"); + if (!xml_parse($xml_parser, $xml, true)) + echo "Error: ".xml_error_string(xml_get_error_code($xml_parser))."\n"; + xml_parser_free($xml_parser); +} ?> --EXPECT-- -<DATA> at line 2 -</DATA> at line 9 +CDATA +<DATA> at line 2, col 0 (byte 45) +</DATA> at line 9, col 0 (byte 90) +Comment +<DATA> at line 2, col 0 (byte 45) +</DATA> at line 9, col 0 (byte 90) +Text +<DATA> at line 2, col 0 (byte 45) +</DATA> at line 9, col 0 (byte 90) |