|
|
|
@ -4990,6 +4990,78 @@ START_TEST(test_suspend_resume_internal_entity) {
|
|
|
|
|
}
|
|
|
|
|
END_TEST
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
suspending_comment_handler(void *userData, const XML_Char *data) {
|
|
|
|
|
UNUSED_P(data);
|
|
|
|
|
XML_Parser parser = (XML_Parser)userData;
|
|
|
|
|
XML_StopParser(parser, XML_TRUE);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
START_TEST(test_suspend_resume_internal_entity_issue_629) {
|
|
|
|
|
const char *const text
|
|
|
|
|
= "<!DOCTYPE a [<!ENTITY e '<!--COMMENT-->a'>]><a>&e;<b>\n"
|
|
|
|
|
"<"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
|
|
|
|
|
"/>"
|
|
|
|
|
"</b></a>";
|
|
|
|
|
const size_t firstChunkSizeBytes = 54;
|
|
|
|
|
|
|
|
|
|
XML_Parser parser = XML_ParserCreate(NULL);
|
|
|
|
|
XML_SetUserData(parser, parser);
|
|
|
|
|
XML_SetCommentHandler(parser, suspending_comment_handler);
|
|
|
|
|
|
|
|
|
|
if (XML_Parse(parser, text, (int)firstChunkSizeBytes, XML_FALSE)
|
|
|
|
|
!= XML_STATUS_SUSPENDED)
|
|
|
|
|
xml_failure(parser);
|
|
|
|
|
if (XML_ResumeParser(parser) != XML_STATUS_OK)
|
|
|
|
|
xml_failure(parser);
|
|
|
|
|
if (XML_Parse(parser, text + firstChunkSizeBytes,
|
|
|
|
|
(int)(strlen(text) - firstChunkSizeBytes), XML_TRUE)
|
|
|
|
|
!= XML_STATUS_OK)
|
|
|
|
|
xml_failure(parser);
|
|
|
|
|
XML_ParserFree(parser);
|
|
|
|
|
}
|
|
|
|
|
END_TEST
|
|
|
|
|
|
|
|
|
|
/* Test syntax error is caught at parse resumption */
|
|
|
|
|
START_TEST(test_resume_entity_with_syntax_error) {
|
|
|
|
|
const char *text = "<!DOCTYPE doc [\n"
|
|
|
|
@ -7589,7 +7661,7 @@ START_TEST(test_misc_version) {
|
|
|
|
|
fail("Version mismatch");
|
|
|
|
|
|
|
|
|
|
#if ! defined(XML_UNICODE) || defined(XML_UNICODE_WCHAR_T)
|
|
|
|
|
if (xcstrcmp(version_text, XCS("expat_2.4.7"))) /* needs bump on releases */
|
|
|
|
|
if (xcstrcmp(version_text, XCS("expat_2.4.9"))) /* needs bump on releases */
|
|
|
|
|
fail("XML_*_VERSION in expat.h out of sync?\n");
|
|
|
|
|
#else
|
|
|
|
|
/* If we have XML_UNICODE defined but not XML_UNICODE_WCHAR_T
|
|
|
|
@ -11764,12 +11836,12 @@ START_TEST(test_accounting_precision) {
|
|
|
|
|
END_TEST
|
|
|
|
|
|
|
|
|
|
static float
|
|
|
|
|
portableNAN() {
|
|
|
|
|
portableNAN(void) {
|
|
|
|
|
return strtof("nan", NULL);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static float
|
|
|
|
|
portableINFINITY() {
|
|
|
|
|
portableINFINITY(void) {
|
|
|
|
|
return strtof("infinity", NULL);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -12016,6 +12088,8 @@ make_suite(void) {
|
|
|
|
|
tcase_add_test(tc_basic, test_partial_char_in_epilog);
|
|
|
|
|
tcase_add_test(tc_basic, test_hash_collision);
|
|
|
|
|
tcase_add_test__ifdef_xml_dtd(tc_basic, test_suspend_resume_internal_entity);
|
|
|
|
|
tcase_add_test__ifdef_xml_dtd(tc_basic,
|
|
|
|
|
test_suspend_resume_internal_entity_issue_629);
|
|
|
|
|
tcase_add_test__ifdef_xml_dtd(tc_basic, test_resume_entity_with_syntax_error);
|
|
|
|
|
tcase_add_test__ifdef_xml_dtd(tc_basic, test_suspend_resume_parameter_entity);
|
|
|
|
|
tcase_add_test(tc_basic, test_restart_on_error);
|
|
|
|
|