msxml3: createProcessingInstruction: Check arguments are valid.

This commit is contained in:
Alistair Leslie-Hughes 2008-01-08 11:07:12 +11:00 committed by Alexandre Julliard
parent 91ad27ea25
commit f31cd30841
2 changed files with 32 additions and 0 deletions

View File

@ -958,6 +958,12 @@ static HRESULT WINAPI domdoc_createProcessingInstruction(
TRACE("%p->(%s %s %p)\n", iface, debugstr_w(target), debugstr_w(data), pi);
if(!pi)
return E_INVALIDARG;
if(!target || lstrlenW(target) == 0)
return E_FAIL;
xml_target = xmlChar_from_wchar((WCHAR*)target);
xml_content = xmlChar_from_wchar((WCHAR*)data);

View File

@ -348,6 +348,7 @@ static void test_domdoc( void )
IXMLDOMComment *node_comment = NULL;
IXMLDOMAttribute *node_attr = NULL;
IXMLDOMNode *nodeChild = NULL;
IXMLDOMProcessingInstruction *nodePI = NULL;
VARIANT_BOOL b;
VARIANT var;
BSTR str;
@ -548,6 +549,31 @@ static void test_domdoc( void )
ok( r == S_OK, "returns %08x\n", r );
IXMLDOMText_Release( node_attr);
/* test Processing Instruction */
str = SysAllocStringLen(NULL, 0);
r = IXMLDOMDocument_createProcessingInstruction(doc, str, str, NULL);
ok( r == E_INVALIDARG, "returns %08x\n", r );
r = IXMLDOMDocument_createProcessingInstruction(doc, NULL, str, &nodePI);
ok( r == E_FAIL, "returns %08x\n", r );
r = IXMLDOMDocument_createProcessingInstruction(doc, str, str, &nodePI);
ok( r == E_FAIL, "returns %08x\n", r );
SysFreeString(str);
r = IXMLDOMDocument_createProcessingInstruction(doc, _bstr_("xml"), _bstr_("version=\"1.0\""), &nodePI);
ok( r == S_OK, "returns %08x\n", r );
if(nodePI)
{
/* Last Child Checks */
r = IXMLDOMProcessingInstruction_get_lastChild(nodePI, NULL);
ok(r == E_INVALIDARG, "ret %08x\n", r );
nodeChild = (IXMLDOMNode*)0x1;
r = IXMLDOMProcessingInstruction_get_lastChild(nodePI, &nodeChild);
ok(r == S_FALSE, "ret %08x\n", r );
ok(nodeChild == NULL, "nodeChild not NULL\n");
}
IXMLDOMProcessingInstruction_Release(nodePI);
r = IXMLDOMDocument_Release( doc );
ok( r == 0, "document ref count incorrect\n");