1
0
mirror of https://github.com/pgbackrest/pgbackrest.git synced 2025-01-18 04:58:51 +02:00

Add XML to invalid XML error message.

There have been cases where pgBackRest has failed on invalid XML but it is not possible to determine what was wrong with the XML.

This will only work for XML up to about 8KiB (which is the error message limit) but it should work in most cases.
This commit is contained in:
David Steele 2022-02-23 10:26:39 -06:00
parent 10038db9c9
commit 67bdf07e69
2 changed files with 3 additions and 2 deletions

View File

@ -374,7 +374,7 @@ xmlDocumentNewBuf(const Buffer *buffer)
*this = (XmlDocument){{0}}; // Extra braces are required for older gcc versions
if ((this->xml = xmlReadMemory((const char *)bufPtrConst(buffer), (int)bufUsed(buffer), "noname.xml", NULL, 0)) == NULL)
THROW_FMT(FormatError, "invalid xml");
THROW_FMT(FormatError, "invalid xml in %zu byte(s):\n%s", bufUsed(buffer), strZ(strNewBuf(buffer)));
// Set callback to ensure xml document is freed
memContextCallbackSet(objMemContext(this), xmlDocumentFreeResource, this);

View File

@ -13,7 +13,8 @@ testRun(void)
// *****************************************************************************************************************************
if (testBegin("xml*()"))
{
TEST_ERROR(xmlDocumentNewBuf(bufNewC(BOGUS_STR, strlen(BOGUS_STR))), FormatError, "invalid xml");
TEST_ERROR(
xmlDocumentNewBuf(bufNewC(BOGUS_STR, strlen(BOGUS_STR))), FormatError, "invalid xml in 5 byte(s):\nBOGUS");
XmlDocument *xmlDocument = NULL;
TEST_ASSIGN(