mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-19 14:03:49 +03:00
util/xml: open XML files before calling libxml2
Libxml2 has awful error reporting behaviour when reading files. When we fail to load a file from the test driver we see: $ virsh -c test:///wibble.xml I/O warning : failed to load external entity "/wibble.xml" error: failed to connect to the hypervisor error: XML error: failed to parse xml document '/wibble.xml' where the I/O warning line is something printed by libxml2 itself, which also lacks any useful detail. Switching to our own file reading code we can massively improve things: $ ./build/tools/virsh -c test:///wibble.xml error: failed to connect to the hypervisor error: Failed to open file '/wibble.xml': No such file or directory Using 10 MB as an upper limit on XML file size ought to be sufficient for any XML files libvirt is reading. Reviewed-by: Richard W.M. Jones <rjones@redhat.com> Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
This commit is contained in:
parent
7f2fd38ee7
commit
94b393dd6e
@ -1143,6 +1143,7 @@ virXMLParseHelper(int domcode,
|
|||||||
xmlNodePtr rootnode;
|
xmlNodePtr rootnode;
|
||||||
const char *docname;
|
const char *docname;
|
||||||
int parseFlags = XML_PARSE_NONET | XML_PARSE_NOWARNING;
|
int parseFlags = XML_PARSE_NONET | XML_PARSE_NOWARNING;
|
||||||
|
g_autofree char *xmlStrPtr = NULL;
|
||||||
|
|
||||||
if (filename)
|
if (filename)
|
||||||
docname = filename;
|
docname = filename;
|
||||||
@ -1166,10 +1167,11 @@ virXMLParseHelper(int domcode,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (filename) {
|
if (filename) {
|
||||||
xml = xmlCtxtReadFile(pctxt, filename, NULL, parseFlags);
|
if (virFileReadAll(filename, 1024*1024*10, &xmlStrPtr) < 0)
|
||||||
} else {
|
return NULL;
|
||||||
xml = xmlCtxtReadDoc(pctxt, BAD_CAST xmlStr, url, NULL, parseFlags);
|
xmlStr = xmlStrPtr;
|
||||||
}
|
}
|
||||||
|
xml = xmlCtxtReadDoc(pctxt, BAD_CAST xmlStr, url, NULL, parseFlags);
|
||||||
|
|
||||||
if (!xml) {
|
if (!xml) {
|
||||||
if (virGetLastErrorCode() == VIR_ERR_OK) {
|
if (virGetLastErrorCode() == VIR_ERR_OK) {
|
||||||
|
@ -1 +1 @@
|
|||||||
XML error: failed to parse xml document 'ABS_SRCDIR/qemuxmlconfdata/nonexistent-file.xml'
|
Failed to open file 'ABS_SRCDIR/qemuxmlconfdata/nonexistent-file.xml': No such file or directory
|
||||||
|
Loading…
x
Reference in New Issue
Block a user