urlmon: Added ibind argument handling in CreateAsyncBindCtx.
[wine] / dlls / msxml3 / tests / domdoc.c
1 /*
2  * XML test
3  *
4  * Copyright 2005 Mike McCormack for CodeWeavers
5  *
6  * This library is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2.1 of the License, or (at your option) any later version.
10  *
11  * This library is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with this library; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
19  */
20
21
22 #define COBJMACROS
23
24 #include "windows.h"
25 #include "ole2.h"
26 #include "xmldom.h"
27 #include "msxml2.h"
28 #include <stdio.h>
29 #include <assert.h>
30
31 #include "wine/test.h"
32
33 const CLSID CLSID_DOMDocument2 = {0xf6d90f11, 0x9c73, 0x11d3, {0xb3, 0x2e, 0x00, 0xc0, 0x4f, 0x99, 0x0b, 0xb4}};
34 const IID IID_IXMLDOMDocument2 = {0x2933bf95, 0x7b36, 0x11d2, {0xb2, 0x0e, 0x00, 0xc0, 0x4f, 0x98, 0x3e, 0x60}};
35
36 static const WCHAR szEmpty[] = { 0 };
37 static const WCHAR szIncomplete[] = {
38     '<','?','x','m','l',' ',
39     'v','e','r','s','i','o','n','=','\'','1','.','0','\'','?','>','\n',0
40 };
41 static const WCHAR szComplete1[] = {
42     '<','?','x','m','l',' ',
43     'v','e','r','s','i','o','n','=','\'','1','.','0','\'','?','>','\n',
44     '<','o','p','e','n','>','<','/','o','p','e','n','>','\n',0
45 };
46 static const WCHAR szComplete2[] = {
47     '<','?','x','m','l',' ',
48     'v','e','r','s','i','o','n','=','\'','1','.','0','\'','?','>','\n',
49     '<','o','>','<','/','o','>','\n',0
50 };
51 static const WCHAR szComplete3[] = {
52     '<','?','x','m','l',' ',
53     'v','e','r','s','i','o','n','=','\'','1','.','0','\'','?','>','\n',
54     '<','a','>','<','/','a','>','\n',0
55 };
56 static const WCHAR szComplete4[] = {
57     '<','?','x','m','l',' ','v','e','r','s','i','o','n','=','\'','1','.','0','\'','?','>','\n',
58     '<','l','c',' ','d','l','=','\'','s','t','r','1','\'','>','\n',
59         '<','b','s',' ','v','r','=','\'','s','t','r','2','\'',' ','s','z','=','\'','1','2','3','4','\'','>',
60             'f','n','1','.','t','x','t','\n',
61         '<','/','b','s','>','\n',
62         '<','p','r',' ','i','d','=','\'','s','t','r','3','\'',' ','v','r','=','\'','1','.','2','.','3','\'',' ',
63                     'p','n','=','\'','w','i','n','e',' ','2','0','0','5','0','8','0','4','\'','>','\n',
64             'f','n','2','.','t','x','t','\n',
65         '<','/','p','r','>','\n',
66         '<','e','m','p','t','y','>','<','/','e','m','p','t','y','>','\n',
67         '<','f','o','>','\n',
68             '<','b','a','>','\n',
69                 'f','1','\n',
70             '<','/','b','a','>','\n',
71         '<','/','f','o','>','\n',
72     '<','/','l','c','>','\n',0
73 };
74 static const WCHAR szComplete5[] = {
75     '<','S',':','s','e','a','r','c','h',' ','x','m','l','n','s',':','D','=','"','D','A','V',':','"',' ',
76     'x','m','l','n','s',':','C','=','"','u','r','n',':','s','c','h','e','m','a','s','-','m','i','c','r','o','s','o','f','t','-','c','o','m',':','o','f','f','i','c','e',':','c','l','i','p','g','a','l','l','e','r','y','"',
77     ' ','x','m','l','n','s',':','S','=','"','u','r','n',':','s','c','h','e','m','a','s','-','m','i','c','r','o','s','o','f','t','-','c','o','m',':','o','f','f','i','c','e',':','c','l','i','p','g','a','l','l','e','r','y',':','s','e','a','r','c','h','"','>',
78         '<','S',':','s','c','o','p','e','>',
79             '<','S',':','d','e','e','p','>','/','<','/','S',':','d','e','e','p','>',
80         '<','/','S',':','s','c','o','p','e','>',
81         '<','S',':','c','o','n','t','e','n','t','f','r','e','e','t','e','x','t','>',
82             '<','C',':','t','e','x','t','o','r','p','r','o','p','e','r','t','y','/','>',
83             'c','o','m','p','u','t','e','r',
84         '<','/','S',':','c','o','n','t','e','n','t','f','r','e','e','t','e','x','t','>',
85     '<','/','S',':','s','e','a','r','c','h','>',0
86 };
87
88 static const CHAR szExampleXML[] =
89 "<?xml version='1.0' encoding='utf-8'?>\n"
90 "<root xmlns:foo='urn:uuid:86B2F87F-ACB6-45cd-8B77-9BDB92A01A29'>\n"
91 "    <elem>\n"
92 "        <a>A1 field</a>\n"
93 "        <b>B1 field</b>\n"
94 "        <c>C1 field</c>\n"
95 "        <description xmlns:foo='http://www.winehq.org' xmlns:bar='urn:uuid:86B2F87F-ACB6-45cd-8B77-9BDB92A01A29'>\n"
96 "            <html xmlns='http://www.w3.org/1999/xhtml'>\n"
97 "                This is <strong>a</strong> <i>description</i>. <bar:x/>\n"
98 "            </html>\n"
99 "        </description>\n"
100 "    </elem>\n"
101 "\n"
102 "    <elem>\n"
103 "        <a>A2 field</a>\n"
104 "        <b>B2 field</b>\n"
105 "        <c type=\"old\">C2 field</c>\n"
106 "    </elem>\n"
107 "\n"
108 "    <elem xmlns='urn:uuid:86B2F87F-ACB6-45cd-8B77-9BDB92A01A29'>\n"
109 "        <a>A3 field</a>\n"
110 "        <b>B3 field</b>\n"
111 "        <c>C3 field</c>\n"
112 "    </elem>\n"
113 "\n"
114 "    <elem>\n"
115 "        <a>A4 field</a>\n"
116 "        <b>B4 field</b>\n"
117 "        <foo:c>C4 field</foo:c>\n"
118 "    </elem>\n"
119 "</root>\n";
120
121 static const WCHAR szNonExistentFile[] = {
122     'c', ':', '\\', 'N', 'o', 'n', 'e', 'x', 'i', 's', 't', 'e', 'n', 't', '.', 'x', 'm', 'l', 0
123 };
124 static const WCHAR szDocument[] = {
125     '#', 'd', 'o', 'c', 'u', 'm', 'e', 'n', 't', 0
126 };
127
128 static const WCHAR szOpen[] = { 'o','p','e','n',0 };
129 static WCHAR szdl[] = { 'd','l',0 };
130 static const WCHAR szvr[] = { 'v','r',0 };
131 static const WCHAR szlc[] = { 'l','c',0 };
132 static WCHAR szbs[] = { 'b','s',0 };
133 static const WCHAR szstr1[] = { 's','t','r','1',0 };
134 static const WCHAR szstr2[] = { 's','t','r','2',0 };
135 static const WCHAR szstar[] = { '*',0 };
136 static const WCHAR szfn1_txt[] = {'f','n','1','.','t','x','t',0};
137
138 #define expect_bstr_eq_and_free(bstr, expect) { \
139     BSTR bstrExp = alloc_str_from_narrow(expect); \
140     ok(lstrcmpW(bstr, bstrExp) == 0, "String differs\n"); \
141     SysFreeString(bstr); \
142     SysFreeString(bstrExp); \
143 }
144
145 #define expect_eq(expr, value, type, format) { type ret = (expr); ok((value) == ret, #expr " expected " format " got " format "\n", value, ret); }
146
147 #define ole_check(expr) { \
148     HRESULT r = expr; \
149     ok(r == S_OK, #expr " returned %x\n", r); \
150 }
151
152 #define ole_expect(expr, expect) { \
153     HRESULT r = expr; \
154     ok(r == (expect), #expr " returned %x, expected %x\n", r, expect); \
155 }
156
157 static BSTR alloc_str_from_narrow(const char *str)
158 {
159     int len = MultiByteToWideChar(CP_ACP, 0, str, -1, NULL, 0);
160     BSTR ret = SysAllocStringLen(NULL, len - 1);  /* NUL character added automatically */
161     MultiByteToWideChar(CP_ACP, 0, str, -1, ret, len);
162     return ret;
163 }
164
165 BSTR alloced_bstrs[256];
166 int alloced_bstrs_count = 0;
167
168 static BSTR _bstr_(const char *str)
169 {
170     assert(alloced_bstrs_count < sizeof(alloced_bstrs)/sizeof(alloced_bstrs[0]));
171     alloced_bstrs[alloced_bstrs_count] = alloc_str_from_narrow(str);
172     return alloced_bstrs[alloced_bstrs_count++];
173 }
174
175 static void free_bstrs(void)
176 {
177     int i;
178     for (i = 0; i < alloced_bstrs_count; i++)
179         SysFreeString(alloced_bstrs[i]);
180     alloced_bstrs_count = 0;
181 }
182
183 static VARIANT _variantbstr_(const char *str)
184 {
185     VARIANT v;
186     V_VT(&v) = VT_BSTR;
187     V_BSTR(&v) = _bstr_(str);
188     return v;
189 }
190
191 static void get_str_for_type(DOMNodeType type, char *buf)
192 {
193     switch (type)
194     {
195         case NODE_ATTRIBUTE:
196             strcpy(buf, "A");
197             break;
198         case NODE_ELEMENT:
199             strcpy(buf, "E");
200             break;
201         case NODE_DOCUMENT:
202             strcpy(buf, "D");
203             break;
204         default:
205             wsprintfA(buf, "[%d]", type);
206     }
207 }
208
209 static int get_node_position(IXMLDOMNode *node)
210 {
211     HRESULT r;
212     int pos = 0;
213
214     IXMLDOMNode_AddRef(node);
215     do
216     {
217         IXMLDOMNode *new_node;
218
219         pos++;
220         r = IXMLDOMNode_get_previousSibling(node, &new_node);
221         ok(!FAILED(r), "get_previousSibling failed\n");
222         IXMLDOMNode_Release(node);
223         node = new_node;
224     } while (r == S_OK);
225     return pos;
226 }
227
228 static void node_to_string(IXMLDOMNode *node, char *buf)
229 {
230     HRESULT r = S_OK;
231     DOMNodeType type;
232
233     if (node == NULL)
234     {
235         lstrcpyA(buf, "(null)");
236         return;
237     }
238
239     IXMLDOMNode_AddRef(node);
240     while (r == S_OK)
241     {
242         IXMLDOMNode *new_node;
243
244         ole_check(IXMLDOMNode_get_nodeType(node, &type));
245         get_str_for_type(type, buf);
246         buf+=strlen(buf);
247
248         if (type == NODE_ATTRIBUTE)
249         {
250             BSTR bstr;
251             ole_check(IXMLDOMNode_get_nodeName(node, &bstr));
252             *(buf++) = '\'';
253             wsprintfA(buf, "%ws", bstr);
254             buf += strlen(buf);
255             *(buf++) = '\'';
256             SysFreeString(bstr);
257
258             r = IXMLDOMNode_selectSingleNode(node, _bstr_(".."), &new_node);
259         }
260         else
261         {
262             int pos = get_node_position(node);
263             DOMNodeType parent_type = NODE_INVALID;
264             r = IXMLDOMNode_get_parentNode(node, &new_node);
265
266             /* currently wine doesn't create a node for the <?xml ... ?>. To be able to test query
267              * results we "fix" it */
268             if (r == S_OK)
269                 ole_check(IXMLDOMNode_get_nodeType(node, &parent_type));
270             /* we need also to workaround the no document node problem - see below */
271             if (((r == S_FALSE && type != NODE_DOCUMENT) || parent_type == NODE_DOCUMENT) && type != NODE_PROCESSING_INSTRUCTION && pos==1)
272             {
273                 todo_wine ok(FALSE, "The first child of the document node in MSXML is the <?xml ... ?> processing instruction\n");
274                 pos++;
275             }
276             wsprintf(buf, "%d", pos);
277             buf += strlen(buf);
278         }
279
280         ok(!FAILED(r), "get_parentNode failed (%08x)\n", r);
281         IXMLDOMNode_Release(node);
282         node = new_node;
283         if (r == S_OK)
284             *(buf++) = '.';
285     }
286
287     /* currently we can't access document node in wine. All our examples this is the
288      * root node so to be able to test query results we add it */
289     if (type != NODE_DOCUMENT)
290     {
291         todo_wine ok(FALSE, "Document node is not the last returned node!\n");
292         *(buf++) = '.';
293         *(buf++) = 'D';
294         *(buf++) = '1';
295     }
296     *buf = 0;
297 }
298
299 static char *list_to_string(IXMLDOMNodeList *list)
300 {
301     static char buf[4096];
302     char *pos = buf;
303     long len = 0;
304     int i;
305
306     if (list == NULL)
307     {
308         lstrcpyA(buf, "(null)");
309         return buf;
310     }
311     ole_check(IXMLDOMNodeList_get_length(list, &len));
312     for (i = 0; i < len; i++)
313     {
314         IXMLDOMNode *node;
315         if (i > 0)
316             *(pos++) = ' ';
317         ole_check(IXMLDOMNodeList_nextNode(list, &node));
318         node_to_string(node, pos);
319         pos += strlen(pos);
320         IXMLDOMNode_Release(node);
321     }
322     *pos = 0;
323     return buf;
324 }
325
326 #define expect_node(node, expstr) { char str[4096]; node_to_string(node, str); ok(strcmp(str, expstr)==0, "Invalid node: %s, exptected %s\n", str, expstr); }
327 #define expect_list_and_release(list, expstr) { char *str = list_to_string(list); ok(strcmp(str, expstr)==0, "Invalid node list: %s, exptected %s\n", str, expstr); if (list) IXMLDOMNodeList_Release(list); }
328
329 static void test_domdoc( void )
330 {
331     HRESULT r;
332     IXMLDOMDocument *doc = NULL;
333     IXMLDOMParseError *error;
334     IXMLDOMElement *element = NULL;
335     IXMLDOMNode *node;
336     IXMLDOMText *nodetext = NULL;
337     VARIANT_BOOL b;
338     VARIANT var;
339     BSTR str;
340     long code;
341
342     r = CoCreateInstance( &CLSID_DOMDocument, NULL, 
343         CLSCTX_INPROC_SERVER, &IID_IXMLDOMDocument, (LPVOID*)&doc );
344     if( r != S_OK )
345         return;
346
347     /* try some stupid things */
348     r = IXMLDOMDocument_loadXML( doc, NULL, NULL );
349     ok( r == S_FALSE, "loadXML failed\n");
350
351     b = VARIANT_TRUE;
352     r = IXMLDOMDocument_loadXML( doc, NULL, &b );
353     ok( r == S_FALSE, "loadXML failed\n");
354     ok( b == VARIANT_FALSE, "failed to load XML string\n");
355
356     /* try to load a document from a nonexistent file */
357     b = VARIANT_TRUE;
358     str = SysAllocString( szNonExistentFile );
359     VariantInit(&var);
360     V_VT(&var) = VT_BSTR;
361     V_BSTR(&var) = str;
362
363     r = IXMLDOMDocument_load( doc, var, &b);
364     ok( r == S_FALSE, "load (from file) failed\n");
365     ok( b == VARIANT_FALSE, "failed to load XML file\n");
366     SysFreeString( str );
367
368     /* try load an empty document */
369     b = VARIANT_TRUE;
370     str = SysAllocString( szEmpty );
371     r = IXMLDOMDocument_loadXML( doc, str, &b );
372     ok( r == S_FALSE, "loadXML failed\n");
373     ok( b == VARIANT_FALSE, "failed to load XML string\n");
374     SysFreeString( str );
375
376     /* check that there's no document element */
377     element = NULL;
378     r = IXMLDOMDocument_get_documentElement( doc, &element );
379     ok( r == S_FALSE, "should be no document element\n");
380
381     /* try finding a node */
382     node = NULL;
383     str = SysAllocString( szstr1 );
384     r = IXMLDOMDocument_selectSingleNode( doc, str, &node );
385     ok( r == S_FALSE, "ret %08x\n", r );
386     SysFreeString( str );
387
388     b = VARIANT_TRUE;
389     str = SysAllocString( szIncomplete );
390     r = IXMLDOMDocument_loadXML( doc, str, &b );
391     ok( r == S_FALSE, "loadXML failed\n");
392     ok( b == VARIANT_FALSE, "failed to load XML string\n");
393     SysFreeString( str );
394
395     /* check that there's no document element */
396     element = (IXMLDOMElement*)1;
397     r = IXMLDOMDocument_get_documentElement( doc, &element );
398     ok( r == S_FALSE, "should be no document element\n");
399     ok( element == NULL, "Element should be NULL\n");
400
401     /* try to load something valid */
402     b = VARIANT_FALSE;
403     str = SysAllocString( szComplete1 );
404     r = IXMLDOMDocument_loadXML( doc, str, &b );
405     ok( r == S_OK, "loadXML failed\n");
406     ok( b == VARIANT_TRUE, "failed to load XML string\n");
407     SysFreeString( str );
408
409     /* try with a null out pointer */
410     r = IXMLDOMDocument_get_documentElement( doc, NULL );
411     ok( r == E_INVALIDARG, "should be no document element\n");
412
413     /* check if nodename is correct */
414     r = IXMLDOMDocument_get_nodeName( doc, NULL );
415     ok ( r == E_INVALIDARG, "get_nodeName (NULL) wrong code\n");
416
417     /* content doesn't matter here */
418     str = NULL;
419     r = IXMLDOMDocument_get_nodeName( doc, &str );
420     ok ( r == S_OK, "get_nodeName wrong code\n");
421     ok ( str != NULL, "str is null\n");
422     ok( !lstrcmpW( str, szDocument ), "incorrect nodeName\n");
423     SysFreeString( str );
424
425
426     /* check that there's a document element */
427     element = NULL;
428     r = IXMLDOMDocument_get_documentElement( doc, &element );
429     ok( r == S_OK, "should be a document element\n");
430     if( element )
431     {
432         BSTR tag = NULL;
433
434         /* check if the tag is correct */
435         r = IXMLDOMElement_get_tagName( element, &tag );
436         ok( r == S_OK, "couldn't get tag name\n");
437         ok( tag != NULL, "tag was null\n");
438         ok( !lstrcmpW( tag, szOpen ), "incorrect tag name\n");
439         SysFreeString( tag );
440
441         /* figure out what happens if we try to reload the document */
442         str = SysAllocString( szComplete2 );
443         r = IXMLDOMDocument_loadXML( doc, str, &b );
444         ok( r == S_OK, "loadXML failed\n");
445         ok( b == VARIANT_TRUE, "failed to load XML string\n");
446         SysFreeString( str );
447
448         /* check if the tag is still correct */
449         tag = NULL;
450         r = IXMLDOMElement_get_tagName( element, &tag );
451         ok( r == S_OK, "couldn't get tag name\n");
452         ok( tag != NULL, "tag was null\n");
453         ok( !lstrcmpW( tag, szOpen ), "incorrect tag name\n");
454         SysFreeString( tag );
455
456         IXMLDOMElement_Release( element );
457         element = NULL;
458     }
459
460     /* as soon as we call loadXML again, the document element will disappear */
461     b = 2;
462     r = IXMLDOMDocument_loadXML( doc, NULL, NULL );
463     ok( r == S_FALSE, "loadXML failed\n");
464     ok( b == 2, "variant modified\n");
465     r = IXMLDOMDocument_get_documentElement( doc, &element );
466     ok( r == S_FALSE, "should be no document element\n");
467
468     /* try to load something else simple and valid */
469     b = VARIANT_FALSE;
470     str = SysAllocString( szComplete3 );
471     r = IXMLDOMDocument_loadXML( doc, str, &b );
472     ok( r == S_OK, "loadXML failed\n");
473     ok( b == VARIANT_TRUE, "failed to load XML string\n");
474     SysFreeString( str );
475
476     /* try something a little more complicated */
477     b = FALSE;
478     str = SysAllocString( szComplete4 );
479     r = IXMLDOMDocument_loadXML( doc, str, &b );
480     ok( r == S_OK, "loadXML failed\n");
481     ok( b == VARIANT_TRUE, "failed to load XML string\n");
482     SysFreeString( str );
483
484     r = IXMLDOMDocument_get_parseError( doc, &error );
485     ok( r == S_OK, "returns %08x\n", r );
486
487     r = IXMLDOMParseError_get_errorCode( error, &code );
488     ok( r == S_FALSE, "returns %08x\n", r );
489     ok( code == 0, "code %ld\n", code );
490     IXMLDOMParseError_Release( error );
491
492      /* test createTextNode */
493     str = SysAllocString( szOpen );
494     r = IXMLDOMDocument_createTextNode(doc, str, NULL);
495     ok( r == E_INVALIDARG, "returns %08x\n", r );
496     r = IXMLDOMDocument_createTextNode(doc, str, &nodetext);
497     ok( r == S_OK, "returns %08x\n", r );
498     IXMLDOMText_Release( nodetext );
499     SysFreeString( str );
500
501     r = IXMLDOMDocument_Release( doc );
502     ok( r == 0, "document ref count incorrect\n");
503
504 }
505
506 static void test_domnode( void )
507 {
508     HRESULT r;
509     IXMLDOMDocument *doc = NULL, *owner = NULL;
510     IXMLDOMElement *element = NULL;
511     IXMLDOMNamedNodeMap *map = NULL;
512     IXMLDOMNode *node = NULL, *next = NULL;
513     IXMLDOMNodeList *list = NULL;
514     DOMNodeType type = NODE_INVALID;
515     VARIANT_BOOL b;
516     BSTR str;
517     VARIANT var;
518     long count;
519
520     r = CoCreateInstance( &CLSID_DOMDocument, NULL, 
521         CLSCTX_INPROC_SERVER, &IID_IXMLDOMDocument, (LPVOID*)&doc );
522     if( r != S_OK )
523         return;
524
525     b = FALSE;
526     str = SysAllocString( szComplete4 );
527     r = IXMLDOMDocument_loadXML( doc, str, &b );
528     ok( r == S_OK, "loadXML failed\n");
529     ok( b == VARIANT_TRUE, "failed to load XML string\n");
530     SysFreeString( str );
531
532     if (doc)
533     {
534         b = 1;
535         r = IXMLDOMNode_hasChildNodes( doc, &b );
536         ok( r == S_OK, "hasChildNoes bad return\n");
537         ok( b == VARIANT_TRUE, "hasChildNoes wrong result\n");
538
539         r = IXMLDOMDocument_get_documentElement( doc, &element );
540         ok( r == S_OK, "should be a document element\n");
541         ok( element != NULL, "should be an element\n");
542     }
543     else
544         ok( FALSE, "no document\n");
545
546     VariantInit(&var);
547     ok( V_VT(&var) == VT_EMPTY, "variant init failed\n");
548     r = IXMLDOMNode_get_nodeValue( doc, &var );
549     ok( r == S_FALSE, "nextNode returned wrong code\n");
550     ok( V_VT(&var) == VT_NULL, "variant wasn't empty\n");
551     ok( V_BSTR(&var) == NULL, "variant value wasn't null\n");
552
553     if (element)
554     {
555         owner = NULL;
556         r = IXMLDOMNode_get_ownerDocument( element, &owner );
557         todo_wine {
558         ok( r == S_OK, "get_ownerDocument return code\n");
559         }
560         ok( owner != doc, "get_ownerDocument return\n");
561
562         type = NODE_INVALID;
563         r = IXMLDOMNode_get_nodeType( element, &type);
564         ok( r == S_OK, "getNamedItem returned wrong code\n");
565         ok( type == NODE_ELEMENT, "node not an element\n");
566
567         str = NULL;
568         r = IXMLDOMNode_get_baseName( element, &str );
569         ok( r == S_OK, "get_baseName returned wrong code\n");
570         ok( lstrcmpW(str,szlc) == 0, "basename was wrong\n");
571         SysFreeString(str);
572
573         /* check if nodename is correct */
574         r = IXMLDOMElement_get_nodeName( element, NULL );
575         ok ( r == E_INVALIDARG, "get_nodeName (NULL) wrong code\n");
576     
577         /* content doesn't matter here */
578         str = NULL;
579         r = IXMLDOMElement_get_nodeName( element, &str );
580         ok ( r == S_OK, "get_nodeName wrong code\n");
581         ok ( str != NULL, "str is null\n");
582         ok( !lstrcmpW( str, szlc ), "incorrect nodeName\n");
583         SysFreeString( str );
584
585         str = SysAllocString( szNonExistentFile );      
586         V_VT(&var) = VT_I4;
587         V_I4(&var) = 0x1234;
588         r = IXMLDOMElement_getAttribute( element, str, &var );
589         ok( r == E_FAIL, "getAttribute ret %08x\n", r );
590         ok( V_VT(&var) == VT_EMPTY, "vt = %x\n", V_VT(&var));
591         VariantClear(&var);
592         SysFreeString( str );
593
594         str = SysAllocString( szdl );   
595         V_VT(&var) = VT_I4;
596         V_I4(&var) = 0x1234;
597         r = IXMLDOMElement_getAttribute( element, str, &var );
598         ok( r == S_OK, "getAttribute ret %08x\n", r );
599         ok( V_VT(&var) == VT_BSTR, "vt = %x\n", V_VT(&var));
600         ok( !lstrcmpW(V_BSTR(&var), szstr1), "wrong attr value\n");
601         VariantClear( &var );
602         SysFreeString( str );
603
604         r = IXMLDOMElement_get_attributes( element, &map );
605         ok( r == S_OK, "get_attributes returned wrong code\n");
606         ok( map != NULL, "should be attributes\n");
607
608         b = 1;
609         r = IXMLDOMNode_hasChildNodes( element, &b );
610         ok( r == S_OK, "hasChildNoes bad return\n");
611         ok( b == VARIANT_TRUE, "hasChildNoes wrong result\n");
612     }
613     else
614         ok( FALSE, "no element\n");
615
616     if (map)
617     {
618         ISupportErrorInfo *support_error;
619         r = IXMLDOMNamedNodeMap_QueryInterface( map, &IID_ISupportErrorInfo, (LPVOID*)&support_error );
620         ok( r == S_OK, "ret %08x\n", r );
621
622         r = ISupportErrorInfo_InterfaceSupportsErrorInfo( support_error, &IID_IXMLDOMNamedNodeMap );
623 todo_wine
624 {
625         ok( r == S_OK, "ret %08x\n", r );
626 }
627         ISupportErrorInfo_Release( support_error );
628
629         str = SysAllocString( szdl );
630         r = IXMLDOMNamedNodeMap_getNamedItem( map, str, &node );
631         ok( r == S_OK, "getNamedItem returned wrong code\n");
632         ok( node != NULL, "should be attributes\n");
633         IXMLDOMNode_Release(node);
634         SysFreeString( str );
635
636         str = SysAllocString( szdl );
637         r = IXMLDOMNamedNodeMap_getNamedItem( map, str, NULL );
638         ok( r == E_INVALIDARG, "getNamedItem should return E_INVALIDARG\n");
639         SysFreeString( str );
640
641         /* something that isn't in szComplete4 */
642         str = SysAllocString( szOpen );
643         node = (IXMLDOMNode *) 1;
644         r = IXMLDOMNamedNodeMap_getNamedItem( map, str, &node );
645         ok( r = S_FALSE, "getNamedItem found a node that wasn't there\n");
646         ok( node == NULL, "getNamedItem should have returned NULL\n");
647         SysFreeString( str );
648
649         /* test indexed access of attributes */
650         r = IXMLDOMNamedNodeMap_get_length( map, &count );
651         ok ( r == S_OK, "get_length wrong code\n");
652         ok ( count == 1, "get_length != 1\n");
653
654         node = NULL;
655         r = IXMLDOMNamedNodeMap_get_item( map, -1, &node);
656         ok ( r == S_FALSE, "get_item (-1) wrong code\n");
657         ok ( node == NULL, "there is no node\n");
658
659         node = NULL;
660         r = IXMLDOMNamedNodeMap_get_item( map, 1, &node);
661         ok ( r == S_FALSE, "get_item (1) wrong code\n");
662         ok ( node == NULL, "there is no attribute\n");
663
664         node = NULL;
665         r = IXMLDOMNamedNodeMap_get_item( map, 0, &node);
666         ok ( r == S_OK, "get_item (0) wrong code\n");
667         ok ( node != NULL, "should be attribute\n");
668
669         r = IXMLDOMNode_get_nodeName( node, NULL );
670         ok ( r == E_INVALIDARG, "get_nodeName (NULL) wrong code\n");
671
672         /* content doesn't matter here */
673         str = NULL;
674         r = IXMLDOMNode_get_nodeName( node, &str );
675         ok ( r == S_OK, "get_nodeName wrong code\n");
676         ok ( str != NULL, "str is null\n");
677         ok( !lstrcmpW( str, szdl ), "incorrect node name\n");
678         SysFreeString( str );
679
680         /* test sequential access of attributes */
681         node = NULL;
682         r = IXMLDOMNamedNodeMap_nextNode( map, &node );
683         ok ( r == S_OK, "nextNode (first time) wrong code\n");
684         ok ( node != NULL, "nextNode, should be attribute\n");
685
686         r = IXMLDOMNamedNodeMap_nextNode( map, &node );
687         ok ( r != S_OK, "nextNode (second time) wrong code\n");
688         ok ( node == NULL, "nextNode, there is no attribute\n");
689
690         r = IXMLDOMNamedNodeMap_reset( map );
691         ok ( r == S_OK, "reset should return S_OK\n");
692
693         r = IXMLDOMNamedNodeMap_nextNode( map, &node );
694         ok ( r == S_OK, "nextNode (third time) wrong code\n");
695         ok ( node != NULL, "nextNode, should be attribute\n");
696     }
697     else
698         ok( FALSE, "no map\n");
699
700     if (node)
701     {
702         type = NODE_INVALID;
703         r = IXMLDOMNode_get_nodeType( node, &type);
704         ok( r == S_OK, "getNamedItem returned wrong code\n");
705         ok( type == NODE_ATTRIBUTE, "node not an attribute\n");
706
707         str = NULL;
708         r = IXMLDOMNode_get_baseName( node, NULL );
709         ok( r == E_INVALIDARG, "get_baseName returned wrong code\n");
710
711         str = NULL;
712         r = IXMLDOMNode_get_baseName( node, &str );
713         ok( r == S_OK, "get_baseName returned wrong code\n");
714         ok( lstrcmpW(str,szdl) == 0, "basename was wrong\n");
715         SysFreeString( str );
716
717         r = IXMLDOMNode_get_nodeValue( node, &var );
718         ok( r == S_OK, "returns %08x\n", r );
719         ok( V_VT(&var) == VT_BSTR, "vt %x\n", V_VT(&var));
720         ok( !lstrcmpW(V_BSTR(&var), szstr1), "nodeValue incorrect\n");
721         VariantClear(&var);
722
723         r = IXMLDOMNode_get_childNodes( node, NULL );
724         ok( r == E_INVALIDARG, "get_childNodes returned wrong code\n");
725
726         r = IXMLDOMNode_get_childNodes( node, &list );
727         ok( r == S_OK, "get_childNodes returned wrong code\n");
728
729         if (list)
730         {
731             r = IXMLDOMNodeList_nextNode( list, &next );
732             ok( r == S_OK, "nextNode returned wrong code\n");
733         }
734         else
735             ok( FALSE, "no childlist\n");
736
737         if (next)
738         {
739             b = 1;
740             r = IXMLDOMNode_hasChildNodes( next, &b );
741             ok( r == S_FALSE, "hasChildNoes bad return\n");
742             ok( b == VARIANT_FALSE, "hasChildNoes wrong result\n");
743
744             type = NODE_INVALID;
745             r = IXMLDOMNode_get_nodeType( next, &type);
746             ok( r == S_OK, "getNamedItem returned wrong code\n");
747             ok( type == NODE_TEXT, "node not text\n");
748
749             str = (BSTR) 1;
750             r = IXMLDOMNode_get_baseName( next, &str );
751             ok( r == S_FALSE, "get_baseName returned wrong code\n");
752             ok( str == NULL, "basename was wrong\n");
753             SysFreeString(str);
754         }
755         else
756             ok( FALSE, "no next\n");
757
758         if (next)
759             IXMLDOMNode_Release( next );
760         next = NULL;
761         if (list)
762             IXMLDOMNodeList_Release( list );
763         list = NULL;
764         if (node)
765             IXMLDOMNode_Release( node );
766     }
767     else
768         ok( FALSE, "no node\n");
769     node = NULL;
770
771     if (map)
772         IXMLDOMNamedNodeMap_Release( map );
773
774     /* now traverse the tree from the root element */
775     if (element)
776     {
777         IXMLDOMNode *node;
778         r = IXMLDOMNode_get_childNodes( element, &list );
779         ok( r == S_OK, "get_childNodes returned wrong code\n");
780
781         /* using get_item for child list doesn't advance the position */
782         ole_check(IXMLDOMNodeList_get_item(list, 1, &node));
783         expect_node(node, "E2.E2.D1");
784         IXMLDOMNode_Release(node);
785         ole_check(IXMLDOMNodeList_nextNode(list, &node));
786         expect_node(node, "E1.E2.D1");
787         IXMLDOMNode_Release(node);
788         ole_check(IXMLDOMNodeList_reset(list));
789
790         IXMLDOMNodeList_AddRef(list);
791         expect_list_and_release(list, "E1.E2.D1 E2.E2.D1 E3.E2.D1 E4.E2.D1");
792         ole_check(IXMLDOMNodeList_reset(list));
793     }
794     else
795         ok( FALSE, "no element\n");
796
797     node = (void*)0xdeadbeef;
798     r = IXMLDOMNode_selectSingleNode( element, szdl, &node );
799     ok( r == S_FALSE, "ret %08x\n", r );
800     ok( node == NULL, "node %p\n", node );
801     r = IXMLDOMNode_selectSingleNode( element, szbs, &node );
802     ok( r == S_OK, "ret %08x\n", r );
803     r = IXMLDOMNode_Release( node );
804     ok( r == 0, "ret %08x\n", r );
805
806     if (list)
807     {
808         r = IXMLDOMNodeList_get_length( list, &count );
809         ok( r == S_OK, "get_length returns %08x\n", r );
810         ok( count == 4, "get_length got %ld\n", count );
811
812         r = IXMLDOMNodeList_nextNode( list, &node );
813         ok( r == S_OK, "nextNode returned wrong code\n");
814     }
815     else
816         ok( FALSE, "no list\n");
817
818     if (node)
819     {
820         type = NODE_INVALID;
821         r = IXMLDOMNode_get_nodeType( node, &type);
822         ok( r == S_OK, "getNamedItem returned wrong code\n");
823         ok( type == NODE_ELEMENT, "node not text\n");
824
825         VariantInit(&var);
826         ok( V_VT(&var) == VT_EMPTY, "variant init failed\n");
827         r = IXMLDOMNode_get_nodeValue( node, &var );
828         ok( r == S_FALSE, "nextNode returned wrong code\n");
829         ok( V_VT(&var) == VT_NULL, "variant wasn't empty\n");
830         ok( V_BSTR(&var) == NULL, "variant value wasn't null\n");
831
832         r = IXMLDOMNode_hasChildNodes( node, NULL );
833         ok( r == E_INVALIDARG, "hasChildNoes bad return\n");
834
835         b = 1;
836         r = IXMLDOMNode_hasChildNodes( node, &b );
837         ok( r == S_OK, "hasChildNoes bad return\n");
838         ok( b == VARIANT_TRUE, "hasChildNoes wrong result\n");
839
840         str = NULL;
841         r = IXMLDOMNode_get_baseName( node, &str );
842         ok( r == S_OK, "get_baseName returned wrong code\n");
843         ok( lstrcmpW(str,szbs) == 0, "basename was wrong\n");
844         SysFreeString(str);
845     }
846     else
847         ok( FALSE, "no node\n");
848
849     if (node)
850         IXMLDOMNode_Release( node );
851     if (list)
852         IXMLDOMNodeList_Release( list );
853     if (element)
854         IXMLDOMElement_Release( element );
855
856     b = FALSE;
857     str = SysAllocString( szComplete5 );
858     r = IXMLDOMDocument_loadXML( doc, str, &b );
859     ok( r == S_OK, "loadXML failed\n");
860     ok( b == VARIANT_TRUE, "failed to load XML string\n");
861     SysFreeString( str );
862
863     b = 1;
864     r = IXMLDOMNode_hasChildNodes( doc, &b );
865     ok( r == S_OK, "hasChildNoes bad return\n");
866     ok( b == VARIANT_TRUE, "hasChildNoes wrong result\n");
867
868     r = IXMLDOMDocument_get_documentElement( doc, &element );
869     ok( r == S_OK, "should be a document element\n");
870     ok( element != NULL, "should be an element\n");
871
872     if (element)
873     {
874         static const WCHAR szSSearch[] = {'S',':','s','e','a','r','c','h',0};
875         BSTR tag = NULL;
876
877         /* check if the tag is correct */
878         r = IXMLDOMElement_get_tagName( element, &tag );
879         ok( r == S_OK, "couldn't get tag name\n");
880         ok( tag != NULL, "tag was null\n");
881         ok( !lstrcmpW( tag, szSSearch ), "incorrect tag name\n");
882         SysFreeString( tag );
883     }
884
885     if (element)
886         IXMLDOMElement_Release( element );
887     if (doc)
888         IXMLDOMDocument_Release( doc );
889 }
890
891 static void test_refs(void)
892 {
893     HRESULT r;
894     BSTR str;
895     VARIANT_BOOL b;
896     IXMLDOMDocument *doc = NULL;
897     IXMLDOMElement *element = NULL;
898     IXMLDOMNode *node = NULL, *node2;
899     IXMLDOMNodeList *node_list = NULL;
900     LONG ref;
901     IUnknown *unk, *unk2;
902
903     r = CoCreateInstance( &CLSID_DOMDocument, NULL, 
904         CLSCTX_INPROC_SERVER, &IID_IXMLDOMDocument, (LPVOID*)&doc );
905     if( r != S_OK )
906         return;
907     ref = IXMLDOMDocument_Release(doc);
908     ok( ref == 0, "ref %d\n", ref);
909
910     r = CoCreateInstance( &CLSID_DOMDocument, NULL, 
911         CLSCTX_INPROC_SERVER, &IID_IXMLDOMDocument, (LPVOID*)&doc );
912     if( r != S_OK )
913         return;
914
915     str = SysAllocString( szComplete4 );
916     r = IXMLDOMDocument_loadXML( doc, str, &b );
917     ok( r == S_OK, "loadXML failed\n");
918     ok( b == VARIANT_TRUE, "failed to load XML string\n");
919     SysFreeString( str );
920
921     ref = IXMLDOMDocument_AddRef( doc );
922     ok( ref == 2, "ref %d\n", ref );
923     ref = IXMLDOMDocument_AddRef( doc );
924     ok( ref == 3, "ref %d\n", ref );
925     IXMLDOMDocument_Release( doc );
926     IXMLDOMDocument_Release( doc );
927
928     r = IXMLDOMDocument_get_documentElement( doc, &element );
929     ok( r == S_OK, "should be a document element\n");
930     ok( element != NULL, "should be an element\n");
931
932     ref = IXMLDOMDocument_AddRef( doc );
933     ok( ref == 2, "ref %d\n", ref );
934     IXMLDOMDocument_Release( doc );
935
936     r = IXMLDOMElement_get_childNodes( element, &node_list );
937     ok( r == S_OK, "rets %08x\n", r);
938     ref = IXMLDOMNodeList_AddRef( node_list );
939     ok( ref == 2, "ref %d\n", ref );
940     IXMLDOMNodeList_Release( node_list );
941
942     IXMLDOMNodeList_get_item( node_list, 0, &node );
943     ok( r == S_OK, "rets %08x\n", r);
944
945     IXMLDOMNodeList_get_item( node_list, 0, &node2 );
946     ok( r == S_OK, "rets %08x\n", r);
947
948     ref = IXMLDOMNode_AddRef( node );
949     ok( ref == 2, "ref %d\n", ref );
950     IXMLDOMNode_Release( node );
951
952     ref = IXMLDOMNode_Release( node );
953     ok( ref == 0, "ref %d\n", ref );
954     ref = IXMLDOMNode_Release( node2 );
955     ok( ref == 0, "ref %d\n", ref );
956
957     ref = IXMLDOMNodeList_Release( node_list );
958     ok( ref == 0, "ref %d\n", ref );
959
960     ok( node != node2, "node %p node2 %p\n", node, node2 );
961
962     ref = IXMLDOMDocument_Release( doc );
963     ok( ref == 0, "ref %d\n", ref );
964
965     ref = IXMLDOMElement_AddRef( element );
966     todo_wine {
967     ok( ref == 3, "ref %d\n", ref );
968     }
969     IXMLDOMElement_Release( element );
970
971     /* IUnknown must be unique however we obtain it */
972     r = IXMLDOMElement_QueryInterface( element, &IID_IUnknown, (LPVOID*)&unk );
973     ok( r == S_OK, "rets %08x\n", r );
974     r = IXMLDOMElement_QueryInterface( element, &IID_IXMLDOMNode, (LPVOID*)&node );
975     ok( r == S_OK, "rets %08x\n", r );
976     r = IXMLDOMNode_QueryInterface( node, &IID_IUnknown, (LPVOID*)&unk2 );
977     ok( r == S_OK, "rets %08x\n", r );
978     ok( unk == unk2, "unk %p unk2 %p\n", unk, unk2 );
979
980     IUnknown_Release( unk2 );
981     IUnknown_Release( unk );
982     IXMLDOMNode_Release( node );
983
984     IXMLDOMElement_Release( element );
985
986 }
987
988 static void test_create(void)
989 {
990     HRESULT r;
991     VARIANT var;
992     BSTR str, name;
993     IXMLDOMDocument *doc;
994     IXMLDOMElement *element;
995     IXMLDOMNode *root, *node, *child;
996     IXMLDOMNamedNodeMap *attr_map;
997     IUnknown *unk;
998     LONG ref;
999     long num;
1000
1001     r = CoCreateInstance( &CLSID_DOMDocument, NULL, 
1002         CLSCTX_INPROC_SERVER, &IID_IXMLDOMDocument, (LPVOID*)&doc );
1003     if( r != S_OK )
1004         return;
1005
1006     V_VT(&var) = VT_I4;
1007     V_I4(&var) = NODE_ELEMENT;
1008     str = SysAllocString( szlc );
1009     r = IXMLDOMDocument_createNode( doc, var, str, NULL, &node );
1010     ok( r == S_OK, "returns %08x\n", r );
1011     r = IXMLDOMDocument_appendChild( doc, node, &root );
1012     ok( r == S_OK, "returns %08x\n", r );
1013     ok( node == root, "%p %p\n", node, root );
1014
1015     ref = IXMLDOMNode_AddRef( node );
1016     ok(ref == 3, "ref %d\n", ref);
1017     IXMLDOMNode_Release( node );
1018
1019     ref = IXMLDOMNode_Release( node );
1020     ok(ref == 1, "ref %d\n", ref);
1021     SysFreeString( str );
1022
1023     V_VT(&var) = VT_I4;
1024     V_I4(&var) = NODE_ELEMENT;
1025     str = SysAllocString( szbs );
1026     r = IXMLDOMDocument_createNode( doc, var, str, NULL, &node );
1027     ok( r == S_OK, "returns %08x\n", r );
1028
1029     ref = IXMLDOMNode_AddRef( node );
1030     ok(ref == 2, "ref = %d\n", ref);
1031     IXMLDOMNode_Release( node );
1032
1033     r = IXMLDOMNode_QueryInterface( node, &IID_IUnknown, (LPVOID*)&unk );
1034     ok( r == S_OK, "returns %08x\n", r );
1035
1036     ref = IXMLDOMNode_AddRef( unk );
1037     ok(ref == 3, "ref = %d\n", ref);
1038     IXMLDOMNode_Release( unk );
1039
1040     V_VT(&var) = VT_EMPTY;
1041     r = IXMLDOMNode_insertBefore( root, (IXMLDOMNode*)unk, var, &child );
1042     ok( r == S_OK, "returns %08x\n", r );
1043     ok( unk == (IUnknown*)child, "%p %p\n", unk, child );
1044     IXMLDOMNode_Release( child );
1045     IUnknown_Release( unk );
1046
1047
1048     V_VT(&var) = VT_NULL;
1049     V_DISPATCH(&var) = (IDispatch*)node;
1050     r = IXMLDOMNode_insertBefore( root, node, var, &child );
1051     ok( r == S_OK, "returns %08x\n", r );
1052     ok( node == child, "%p %p\n", node, child );
1053     IXMLDOMNode_Release( child );
1054
1055
1056     V_VT(&var) = VT_NULL;
1057     V_DISPATCH(&var) = (IDispatch*)node;
1058     r = IXMLDOMNode_insertBefore( root, node, var, NULL );
1059     ok( r == S_OK, "returns %08x\n", r );
1060     IXMLDOMNode_Release( node );
1061
1062     r = IXMLDOMNode_QueryInterface( root, &IID_IXMLDOMElement, (LPVOID*)&element );
1063     ok( r == S_OK, "returns %08x\n", r );
1064
1065     r = IXMLDOMElement_get_attributes( element, &attr_map );
1066     ok( r == S_OK, "returns %08x\n", r );
1067     r = IXMLDOMNamedNodeMap_get_length( attr_map, &num );
1068     ok( r == S_OK, "returns %08x\n", r );
1069     ok( num == 0, "num %ld\n", num );
1070     IXMLDOMNamedNodeMap_Release( attr_map );
1071
1072     V_VT(&var) = VT_BSTR;
1073     V_BSTR(&var) = SysAllocString( szstr1 );
1074     name = SysAllocString( szdl );
1075     r = IXMLDOMElement_setAttribute( element, name, var );
1076     ok( r == S_OK, "returns %08x\n", r );
1077     r = IXMLDOMElement_get_attributes( element, &attr_map );
1078     ok( r == S_OK, "returns %08x\n", r );
1079     r = IXMLDOMNamedNodeMap_get_length( attr_map, &num );
1080     ok( r == S_OK, "returns %08x\n", r );
1081     ok( num == 1, "num %ld\n", num );
1082     IXMLDOMNamedNodeMap_Release( attr_map );
1083     VariantClear(&var);
1084
1085     V_VT(&var) = VT_BSTR;
1086     V_BSTR(&var) = SysAllocString( szstr2 );
1087     r = IXMLDOMElement_setAttribute( element, name, var );
1088     ok( r == S_OK, "returns %08x\n", r );
1089     r = IXMLDOMElement_get_attributes( element, &attr_map );
1090     ok( r == S_OK, "returns %08x\n", r );
1091     r = IXMLDOMNamedNodeMap_get_length( attr_map, &num );
1092     ok( r == S_OK, "returns %08x\n", r );
1093     ok( num == 1, "num %ld\n", num );
1094     IXMLDOMNamedNodeMap_Release( attr_map );
1095     VariantClear(&var);
1096     r = IXMLDOMElement_getAttribute( element, name, &var );
1097     ok( r == S_OK, "returns %08x\n", r );
1098     ok( !lstrcmpW(V_BSTR(&var), szstr2), "wrong attr value\n");
1099     VariantClear(&var);
1100     SysFreeString(name);
1101
1102     V_VT(&var) = VT_BSTR;
1103     V_BSTR(&var) = SysAllocString( szstr1 );
1104     name = SysAllocString( szlc );
1105     r = IXMLDOMElement_setAttribute( element, name, var );
1106     ok( r == S_OK, "returns %08x\n", r );
1107     r = IXMLDOMElement_get_attributes( element, &attr_map );
1108     ok( r == S_OK, "returns %08x\n", r );
1109     r = IXMLDOMNamedNodeMap_get_length( attr_map, &num );
1110     ok( r == S_OK, "returns %08x\n", r );
1111     ok( num == 2, "num %ld\n", num );
1112     IXMLDOMNamedNodeMap_Release( attr_map );
1113     VariantClear(&var);
1114     SysFreeString(name);
1115
1116     V_VT(&var) = VT_I4;
1117     V_I4(&var) = 10;
1118     name = SysAllocString( szbs );
1119     r = IXMLDOMElement_setAttribute( element, name, var );
1120     ok( r == S_OK, "returns %08x\n", r );
1121     VariantClear(&var);
1122     r = IXMLDOMElement_getAttribute( element, name, &var );
1123     ok( r == S_OK, "returns %08x\n", r );
1124     ok( V_VT(&var) == VT_BSTR, "variant type %x\n", V_VT(&var));
1125     VariantClear(&var);
1126     SysFreeString(name);
1127
1128     IXMLDOMElement_Release( element );
1129     IXMLDOMNode_Release( root );
1130     IXMLDOMDocument_Release( doc );
1131 }
1132
1133 static void test_getElementsByTagName(void)
1134 {
1135     HRESULT r;
1136     BSTR str;
1137     VARIANT_BOOL b;
1138     IXMLDOMDocument *doc;
1139     IXMLDOMNodeList *node_list;
1140     long len;
1141
1142     r = CoCreateInstance( &CLSID_DOMDocument, NULL, 
1143         CLSCTX_INPROC_SERVER, &IID_IXMLDOMDocument, (LPVOID*)&doc );
1144     if( r != S_OK )
1145         return;
1146
1147     str = SysAllocString( szComplete4 );
1148     r = IXMLDOMDocument_loadXML( doc, str, &b );
1149     ok( r == S_OK, "loadXML failed\n");
1150     ok( b == VARIANT_TRUE, "failed to load XML string\n");
1151     SysFreeString( str );
1152
1153     str = SysAllocString( szstar );
1154     r = IXMLDOMDocument_getElementsByTagName(doc, str, &node_list);
1155     ok( r == S_OK, "ret %08x\n", r );
1156     r = IXMLDOMNodeList_get_length( node_list, &len );
1157     ok( r == S_OK, "ret %08x\n", r );
1158     ok( len == 6, "len %ld\n", len );
1159     IXMLDOMNodeList_Release( node_list );
1160     SysFreeString( str );
1161
1162     str = SysAllocString( szbs );
1163     r = IXMLDOMDocument_getElementsByTagName(doc, str, &node_list);
1164     ok( r == S_OK, "ret %08x\n", r );
1165     r = IXMLDOMNodeList_get_length( node_list, &len );
1166     ok( r == S_OK, "ret %08x\n", r );
1167     ok( len == 1, "len %ld\n", len );
1168     IXMLDOMNodeList_Release( node_list );
1169     SysFreeString( str );
1170
1171     str = SysAllocString( szdl );
1172     r = IXMLDOMDocument_getElementsByTagName(doc, str, &node_list);
1173     ok( r == S_OK, "ret %08x\n", r );
1174     r = IXMLDOMNodeList_get_length( node_list, &len );
1175     ok( r == S_OK, "ret %08x\n", r );
1176     ok( len == 0, "len %ld\n", len );
1177     IXMLDOMNodeList_Release( node_list );
1178     SysFreeString( str );
1179
1180     str = SysAllocString( szstr1 );
1181     r = IXMLDOMDocument_getElementsByTagName(doc, str, &node_list);
1182     ok( r == S_OK, "ret %08x\n", r );
1183     r = IXMLDOMNodeList_get_length( node_list, &len );
1184     ok( r == S_OK, "ret %08x\n", r );
1185     ok( len == 0, "len %ld\n", len );
1186     IXMLDOMNodeList_Release( node_list );
1187     SysFreeString( str );
1188
1189     IXMLDOMDocument_Release( doc );
1190 }
1191
1192 static void test_get_text(void)
1193 {
1194     HRESULT r;
1195     BSTR str;
1196     VARIANT_BOOL b;
1197     IXMLDOMDocument *doc;
1198     IXMLDOMNode *node, *node2, *node3;
1199     IXMLDOMNodeList *node_list;
1200     IXMLDOMNamedNodeMap *node_map;
1201
1202     r = CoCreateInstance( &CLSID_DOMDocument, NULL, 
1203         CLSCTX_INPROC_SERVER, &IID_IXMLDOMDocument, (LPVOID*)&doc );
1204     if( r != S_OK )
1205         return;
1206
1207     str = SysAllocString( szComplete4 );
1208     r = IXMLDOMDocument_loadXML( doc, str, &b );
1209     ok( r == S_OK, "loadXML failed\n");
1210     ok( b == VARIANT_TRUE, "failed to load XML string\n");
1211     SysFreeString( str );
1212
1213     str = SysAllocString( szbs );
1214     r = IXMLDOMDocument_getElementsByTagName( doc, str, &node_list );
1215     ok( r == S_OK, "ret %08x\n", r );
1216     SysFreeString(str);
1217     
1218     r = IXMLDOMNodeList_get_item( node_list, 0, &node );
1219     ok( r == S_OK, "ret %08x\n", r ); 
1220     IXMLDOMNodeList_Release( node_list );
1221
1222     /* Invalid output parameter*/
1223     r = IXMLDOMNode_get_text( node, NULL );
1224     ok( r == E_INVALIDARG, "ret %08x\n", r );
1225
1226     r = IXMLDOMNode_get_text( node, &str );
1227     ok( r == S_OK, "ret %08x\n", r );
1228 todo_wine {
1229     ok( !memcmp(str, szfn1_txt, sizeof(szfn1_txt)), "wrong string\n" );
1230  }
1231     ok( !memcmp(str, szfn1_txt, sizeof(szfn1_txt)-4), "wrong string\n" );
1232     SysFreeString(str);
1233
1234     r = IXMLDOMNode_get_attributes( node, &node_map );
1235     ok( r == S_OK, "ret %08x\n", r );
1236     
1237     str = SysAllocString( szvr );
1238     r = IXMLDOMNamedNodeMap_getNamedItem( node_map, str, &node2 );
1239     ok( r == S_OK, "ret %08x\n", r );
1240     SysFreeString(str);
1241
1242     r = IXMLDOMNode_get_text( node2, &str );
1243     ok( r == S_OK, "ret %08x\n", r );
1244     ok( !memcmp(str, szstr2, sizeof(szstr2)), "wrong string\n" );
1245     SysFreeString(str);
1246
1247     r = IXMLDOMNode_get_firstChild( node2, &node3 );
1248     ok( r == S_OK, "ret %08x\n", r );
1249
1250     r = IXMLDOMNode_get_text( node3, &str );
1251     ok( r == S_OK, "ret %08x\n", r );
1252     ok( !memcmp(str, szstr2, sizeof(szstr2)), "wrong string\n" );
1253     SysFreeString(str);
1254
1255
1256     IXMLDOMNode_Release( node3 );
1257     IXMLDOMNode_Release( node2 );
1258     IXMLDOMNamedNodeMap_Release( node_map );
1259     IXMLDOMNode_Release( node );
1260     IXMLDOMDocument_Release( doc );
1261 }
1262
1263 static void test_get_childNodes(void)
1264 {
1265     HRESULT r;
1266     BSTR str;
1267     VARIANT_BOOL b;
1268     IXMLDOMDocument *doc;
1269     IXMLDOMElement *element;
1270     IXMLDOMNode *node, *node2;
1271     IXMLDOMNodeList *node_list, *node_list2;
1272     long len;
1273
1274     r = CoCreateInstance( &CLSID_DOMDocument, NULL, 
1275         CLSCTX_INPROC_SERVER, &IID_IXMLDOMDocument, (LPVOID*)&doc );
1276     if( r != S_OK )
1277         return;
1278
1279     str = SysAllocString( szComplete4 );
1280     r = IXMLDOMDocument_loadXML( doc, str, &b );
1281     ok( r == S_OK, "loadXML failed\n");
1282     ok( b == VARIANT_TRUE, "failed to load XML string\n");
1283     SysFreeString( str );
1284
1285     r = IXMLDOMDocument_get_documentElement( doc, &element );
1286     ok( r == S_OK, "ret %08x\n", r);
1287
1288     r = IXMLDOMElement_get_childNodes( element, &node_list );
1289     ok( r == S_OK, "ret %08x\n", r);
1290
1291     r = IXMLDOMNodeList_get_length( node_list, &len );
1292     ok( r == S_OK, "ret %08x\n", r);
1293     ok( len == 4, "len %ld\n", len);
1294
1295     r = IXMLDOMNodeList_get_item( node_list, 2, &node );
1296     ok( r == S_OK, "ret %08x\n", r);
1297
1298     r = IXMLDOMNode_get_childNodes( node, &node_list2 );
1299     ok( r == S_OK, "ret %08x\n", r);
1300
1301     r = IXMLDOMNodeList_get_length( node_list2, &len );
1302     ok( r == S_OK, "ret %08x\n", r);
1303     ok( len == 0, "len %ld\n", len);
1304
1305     r = IXMLDOMNodeList_get_item( node_list2, 0, &node2);
1306     ok( r == S_FALSE, "ret %08x\n", r);
1307
1308     IXMLDOMNodeList_Release( node_list2 );
1309     IXMLDOMNode_Release( node );
1310     IXMLDOMNodeList_Release( node_list );
1311     IXMLDOMElement_Release( element );
1312     IXMLDOMDocument_Release( doc );
1313 }
1314
1315 static void test_removeChild(void)
1316 {
1317     HRESULT r;
1318     BSTR str;
1319     VARIANT_BOOL b;
1320     IXMLDOMDocument *doc;
1321     IXMLDOMElement *element;
1322     IXMLDOMNode *node, *node2, *node3, *node4;
1323     IXMLDOMNodeList *node_list, *node_list2;
1324
1325     r = CoCreateInstance( &CLSID_DOMDocument, NULL, 
1326         CLSCTX_INPROC_SERVER, &IID_IXMLDOMDocument, (LPVOID*)&doc );
1327     if( r != S_OK )
1328         return;
1329
1330     str = SysAllocString( szComplete4 );
1331     r = IXMLDOMDocument_loadXML( doc, str, &b );
1332     ok( r == S_OK, "loadXML failed\n");
1333     ok( b == VARIANT_TRUE, "failed to load XML string\n");
1334     SysFreeString( str );
1335
1336     r = IXMLDOMDocument_get_documentElement( doc, &element );
1337     ok( r == S_OK, "ret %08x\n", r);
1338
1339     r = IXMLDOMElement_get_childNodes( element, &node_list );
1340     ok( r == S_OK, "ret %08x\n", r);
1341
1342     r = IXMLDOMNodeList_get_item( node_list, 3, &node );
1343     ok( r == S_OK, "ret %08x\n", r);
1344  
1345     r = IXMLDOMNode_get_childNodes( node, &node_list2 );
1346     ok( r == S_OK, "ret %08x\n", r);
1347  
1348     r = IXMLDOMNodeList_get_item( node_list, 0, &node4 );
1349     ok( r == S_OK, "ret %08x\n", r);
1350
1351     r = IXMLDOMElement_removeChild( element, NULL, &node2 );
1352     ok( r == E_INVALIDARG, "ret %08x\n", r );
1353
1354     r = IXMLDOMElement_removeChild( element, node4, &node2 );
1355     ok( r == S_OK, "ret %08x\n", r);
1356     ok( node4 == node2, "node %p node2 %p\n", node4, node2 );
1357
1358     r = IXMLDOMNode_get_parentNode( node4, &node3 );
1359     ok( r == S_FALSE, "ret %08x\n", r);
1360     ok( node3 == NULL, "%p\n", node3 );
1361
1362     IXMLDOMNode_Release( node2 );
1363     IXMLDOMNode_Release( node4 );
1364     IXMLDOMNodeList_Release( node_list2 );
1365     IXMLDOMNode_Release( node );
1366     IXMLDOMNodeList_Release( node_list );
1367     IXMLDOMElement_Release( element );
1368     IXMLDOMDocument_Release( doc );
1369 }
1370
1371 static void test_XMLHTTP(void)
1372 {
1373     static const WCHAR wszBody[] = {'m','o','d','e','=','T','e','s','t',0};
1374     static WCHAR wszPOST[] = {'P','O','S','T',0};
1375     static WCHAR wszUrl[] = {'h','t','t','p',':','/','/',
1376         'c','r','o','s','s','o','v','e','r','.','c','o','d','e','w','e','a','v','e','r','s','.','c','o','m','/',
1377         'p','o','s','t','t','e','s','t','.','p','h','p',0};
1378     static const WCHAR wszExpectedResponse[] = {'F','A','I','L','E','D',0};
1379     IXMLHttpRequest *pXMLHttpRequest;
1380     BSTR bstrResponse;
1381     VARIANT dummy;
1382     VARIANT varfalse;
1383     VARIANT varbody;
1384     HRESULT hr = CoCreateInstance(&CLSID_XMLHTTPRequest, NULL,
1385                                   CLSCTX_INPROC_SERVER, &IID_IXMLHttpRequest,
1386                                   (void **)&pXMLHttpRequest);
1387     todo_wine {
1388     ok(hr == S_OK, "CoCreateInstance(CLSID_XMLHTTPRequest) should have succeeded instead of failing with 0x%08x\n", hr);
1389     }
1390     if (hr != S_OK)
1391         return;
1392
1393     VariantInit(&dummy);
1394     V_VT(&dummy) = VT_ERROR;
1395     V_ERROR(&dummy) = DISP_E_MEMBERNOTFOUND;
1396     VariantInit(&varfalse);
1397     V_VT(&varfalse) = VT_BOOL;
1398     V_BOOL(&varfalse) = VARIANT_FALSE;
1399     V_VT(&varbody) = VT_BSTR;
1400     V_BSTR(&varbody) = SysAllocString(wszBody);
1401
1402     hr = IXMLHttpRequest_open(pXMLHttpRequest, wszPOST, wszUrl, varfalse, dummy, dummy);
1403     ok(hr == S_OK, "IXMLHttpRequest_open should have succeeded instead of failing with 0x%08x\n", hr);
1404
1405     hr = IXMLHttpRequest_send(pXMLHttpRequest, varbody);
1406     ok(hr == S_OK, "IXMLHttpRequest_send should have succeeded instead of failing with 0x%08x\n", hr);
1407     VariantClear(&varbody);
1408
1409     hr = IXMLHttpRequest_get_responseText(pXMLHttpRequest, &bstrResponse);
1410     ok(hr == S_OK, "IXMLHttpRequest_get_responseText should have succeeded instead of failing with 0x%08x\n", hr);
1411     /* the server currently returns "FAILED" because the Content-Type header is
1412      * not what the server expects */
1413     ok(!memcmp(bstrResponse, wszExpectedResponse, sizeof(wszExpectedResponse)), "bstrResponse differs from what was expected\n");
1414     SysFreeString(bstrResponse);
1415 }
1416
1417 static void test_IXMLDOMDocument2(void)
1418 {
1419     HRESULT r;
1420     VARIANT_BOOL b;
1421     BSTR str;
1422     IXMLDOMDocument *doc;
1423     IXMLDOMDocument2 *doc2;
1424     VARIANT var;
1425     int ref;
1426
1427     r = CoCreateInstance( &CLSID_DOMDocument, NULL,
1428         CLSCTX_INPROC_SERVER, &IID_IXMLDOMDocument, (LPVOID*)&doc );
1429     if( r != S_OK )
1430         return;
1431
1432     str = SysAllocString( szComplete4 );
1433     r = IXMLDOMDocument_loadXML( doc, str, &b );
1434     ok( r == S_OK, "loadXML failed\n");
1435     ok( b == VARIANT_TRUE, "failed to load XML string\n");
1436     SysFreeString( str );
1437
1438     r = IXMLDOMDocument_QueryInterface( doc, &IID_IXMLDOMDocument2, (void**)&doc2 );
1439     ok( r == S_OK, "ret %08x\n", r );
1440     ok( doc == (IXMLDOMDocument*)doc2, "interfaces differ\n");
1441
1442     /* we will check if the variant got cleared */
1443     ref = IXMLDOMDocument2_AddRef(doc2);
1444     expect_eq(ref, 3, int, "%d");  /* doc, doc2, AddRef*/
1445     V_VT(&var) = VT_UNKNOWN;
1446     V_UNKNOWN(&var) = (IUnknown *)doc2;
1447
1448     /* invalid calls */
1449     ole_expect(IXMLDOMDocument2_getProperty(doc2, _bstr_("askldhfaklsdf"), &var), E_FAIL);
1450     expect_eq(V_VT(&var), VT_UNKNOWN, int, "%x");
1451     ole_expect(IXMLDOMDocument2_getProperty(doc2, _bstr_("SelectionLanguage"), NULL), E_INVALIDARG);
1452
1453     /* valid call */
1454     ole_check(IXMLDOMDocument2_getProperty(doc2, _bstr_("SelectionLanguage"), &var));
1455     expect_eq(V_VT(&var), VT_BSTR, int, "%x");
1456     expect_bstr_eq_and_free(V_BSTR(&var), "XSLPattern");
1457     V_VT(&var) = VT_R4;
1458
1459     /* the variant didn't get cleared*/
1460     expect_eq(IXMLDOMDocument2_Release(doc2), 2, int, "%d");
1461
1462     /* setProperty tests */
1463     ole_expect(IXMLDOMDocument2_setProperty(doc2, _bstr_("askldhfaklsdf"), var), E_FAIL);
1464     ole_expect(IXMLDOMDocument2_setProperty(doc2, _bstr_("SelectionLanguage"), var), E_FAIL);
1465     ole_expect(IXMLDOMDocument2_setProperty(doc2, _bstr_("SelectionLanguage"), _variantbstr_("alskjdh faklsjd hfk")), E_FAIL);
1466     ole_check(IXMLDOMDocument2_setProperty(doc2, _bstr_("SelectionLanguage"), _variantbstr_("XSLPattern")));
1467     ole_check(IXMLDOMDocument2_setProperty(doc2, _bstr_("SelectionLanguage"), _variantbstr_("XPath")));
1468     ole_check(IXMLDOMDocument2_setProperty(doc2, _bstr_("SelectionLanguage"), _variantbstr_("XSLPattern")));
1469
1470     /* contrary to what MSDN calims you can switch back from XPath to XSLPattern */
1471     ole_check(IXMLDOMDocument2_getProperty(doc2, _bstr_("SelectionLanguage"), &var));
1472     expect_eq(V_VT(&var), VT_BSTR, int, "%x");
1473     expect_bstr_eq_and_free(V_BSTR(&var), "XSLPattern");
1474
1475     IXMLDOMDocument2_Release( doc2 );
1476     IXMLDOMDocument_Release( doc );
1477     free_bstrs();
1478 }
1479
1480 static void test_XPath(void)
1481 {
1482     HRESULT r;
1483     VARIANT var;
1484     VARIANT_BOOL b;
1485     IXMLDOMDocument2 *doc;
1486     IXMLDOMNode *rootNode;
1487     IXMLDOMNode *elem1Node;
1488     IXMLDOMNode *node;
1489     IXMLDOMNodeList *list;
1490
1491     r = CoCreateInstance( &CLSID_DOMDocument, NULL,
1492         CLSCTX_INPROC_SERVER, &IID_IXMLDOMDocument2, (LPVOID*)&doc );
1493     if( r != S_OK )
1494         return;
1495
1496     ole_check(IXMLDOMDocument_loadXML(doc, _bstr_(szExampleXML), &b));
1497     ok(b == VARIANT_TRUE, "failed to load XML string\n");
1498
1499     /* switch to XPath */
1500     ole_check(IXMLDOMDocument2_setProperty(doc, _bstr_("SelectionLanguage"), _variantbstr_("XPath")));
1501
1502     /* some simple queries*/
1503     ole_check(IXMLDOMDocument_selectNodes(doc, _bstr_("root"), &list));
1504     ole_check(IXMLDOMNodeList_get_item(list, 0, &rootNode));
1505     ole_check(IXMLDOMNodeList_reset(list));
1506     expect_list_and_release(list, "E2.D1");
1507     if (rootNode == NULL)
1508         return;
1509
1510     ole_check(IXMLDOMDocument_selectNodes(doc, _bstr_("root//c"), &list));
1511     expect_list_and_release(list, "E3.E1.E2.D1 E3.E2.E2.D1");
1512
1513     ole_check(IXMLDOMDocument_selectNodes(doc, _bstr_("//c[@type]"), &list));
1514     expect_list_and_release(list, "E3.E2.E2.D1");
1515
1516     ole_check(IXMLDOMNode_selectNodes(rootNode, _bstr_("elem"), &list));
1517     /* using get_item for query results advances the position */
1518     ole_check(IXMLDOMNodeList_get_item(list, 1, &node));
1519     expect_node(node, "E2.E2.D1");
1520     IXMLDOMNode_Release(node);
1521     ole_check(IXMLDOMNodeList_nextNode(list, &node));
1522     expect_node(node, "E4.E2.D1");
1523     IXMLDOMNode_Release(node);
1524     ole_check(IXMLDOMNodeList_reset(list));
1525     expect_list_and_release(list, "E1.E2.D1 E2.E2.D1 E4.E2.D1");
1526
1527     ole_check(IXMLDOMNode_selectNodes(rootNode, _bstr_("."), &list));
1528     expect_list_and_release(list, "E2.D1");
1529
1530     ole_check(IXMLDOMNode_selectNodes(rootNode, _bstr_("elem[3]/preceding-sibling::*"), &list));
1531     ole_check(IXMLDOMNodeList_get_item(list, 0, &elem1Node));
1532     ole_check(IXMLDOMNodeList_reset(list));
1533     expect_list_and_release(list, "E1.E2.D1 E2.E2.D1 E3.E2.D1");
1534
1535     /* select an attribute */
1536     ole_check(IXMLDOMNode_selectNodes(rootNode, _bstr_(".//@type"), &list));
1537     expect_list_and_release(list, "A'type'.E3.E2.E2.D1");
1538
1539     /* would evaluate to a number */
1540     ole_expect(IXMLDOMNode_selectNodes(rootNode, _bstr_("count(*)"), &list), E_FAIL);
1541     /* would evaluate to a boolean */
1542     ole_expect(IXMLDOMNode_selectNodes(rootNode, _bstr_("position()>0"), &list), E_FAIL);
1543     /* would evaluate to a string */
1544     ole_expect(IXMLDOMNode_selectNodes(rootNode, _bstr_("name()"), &list), E_FAIL);
1545
1546     /* no results */
1547     ole_check(IXMLDOMNode_selectNodes(rootNode, _bstr_("c"), &list));
1548     expect_list_and_release(list, "");
1549     ole_check(IXMLDOMDocument_selectNodes(doc, _bstr_("elem//c"), &list));
1550     expect_list_and_release(list, "");
1551     ole_check(IXMLDOMDocument_selectNodes(doc, _bstr_("//elem[4]"), &list));
1552     expect_list_and_release(list, "");
1553
1554     /* foo undeclared in document node */
1555     ole_expect(IXMLDOMDocument_selectNodes(doc, _bstr_("root//foo:c"), &list), E_FAIL);
1556     /* undeclared in <root> node */
1557     ole_expect(IXMLDOMNode_selectNodes(rootNode, _bstr_(".//foo:c"), &list), E_FAIL);
1558     /* undeclared in <elem> node */
1559     ole_expect(IXMLDOMNode_selectNodes(elem1Node, _bstr_("//foo:c"), &list), E_FAIL);
1560     /* but this trick can be used */
1561     ole_check(IXMLDOMNode_selectNodes(elem1Node, _bstr_("//*[name()='foo:c']"), &list));
1562     expect_list_and_release(list, "E3.E4.E2.D1");
1563
1564     /* it has to be declared in SelectionNamespaces */
1565     todo_wine ole_check(IXMLDOMDocument2_setProperty(doc, _bstr_("SelectionNamespaces"),
1566         _variantbstr_("xmlns:test='urn:uuid:86B2F87F-ACB6-45cd-8B77-9BDB92A01A29'")));
1567
1568     /* now the namespace can be used */
1569     todo_wine ole_check(IXMLDOMDocument_selectNodes(doc, _bstr_("root//test:c"), &list));
1570     todo_wine expect_list_and_release(list, "E3.E3.E2.D1 E3.E4.E2.D1");
1571     todo_wine ole_check(IXMLDOMNode_selectNodes(rootNode, _bstr_(".//test:c"), &list));
1572     todo_wine expect_list_and_release(list, "E3.E3.E2.D1 E3.E4.E2.D1");
1573     todo_wine ole_check(IXMLDOMNode_selectNodes(elem1Node, _bstr_("//test:c"), &list));
1574     todo_wine expect_list_and_release(list, "E3.E3.E2.D1 E3.E4.E2.D1");
1575     todo_wine ole_check(IXMLDOMNode_selectNodes(elem1Node, _bstr_(".//test:x"), &list));
1576     todo_wine expect_list_and_release(list, "E5.E1.E4.E1.E2.D1");
1577
1578     /* SelectionNamespaces syntax error - the namespaces doesn't work anymore but the value is stored */
1579     ole_expect(IXMLDOMDocument2_setProperty(doc, _bstr_("SelectionNamespaces"),
1580         _variantbstr_("xmlns:test='urn:uuid:86B2F87F-ACB6-45cd-8B77-9BDB92A01A29' xmlns:foo=###")), E_FAIL);
1581
1582     ole_expect(IXMLDOMDocument_selectNodes(doc, _bstr_("root//foo:c"), &list), E_FAIL);
1583
1584     todo_wine ole_check(IXMLDOMDocument2_getProperty(doc, _bstr_("SelectionNamespaces"), &var));
1585     todo_wine expect_eq(V_VT(&var), VT_BSTR, int, "%x");
1586     if (V_VT(&var) == VT_BSTR)
1587         expect_bstr_eq_and_free(V_BSTR(&var), "xmlns:test='urn:uuid:86B2F87F-ACB6-45cd-8B77-9BDB92A01A29' xmlns:foo=###");
1588
1589     /* extra attributes - same thing*/
1590     ole_expect(IXMLDOMDocument2_setProperty(doc, _bstr_("SelectionNamespaces"),
1591         _variantbstr_("xmlns:test='urn:uuid:86B2F87F-ACB6-45cd-8B77-9BDB92A01A29' param='test'")), E_FAIL);
1592     ole_expect(IXMLDOMDocument_selectNodes(doc, _bstr_("root//foo:c"), &list), E_FAIL);
1593
1594     IXMLDOMNode_Release(rootNode);
1595     IXMLDOMNode_Release(elem1Node);
1596     IXMLDOMDocument_Release(doc);
1597     free_bstrs();
1598 }
1599
1600 static void test_cloneNode(void )
1601 {
1602     IXMLDOMDocument *doc = NULL;
1603     VARIANT_BOOL b;
1604     IXMLDOMNodeList *pList;
1605     IXMLDOMNamedNodeMap *mapAttr;
1606     long nLength = 0, nLength1 = 0;
1607     long nAttrCnt = 0, nAttrCnt1 = 0;
1608     IXMLDOMNode *node;
1609     IXMLDOMNode *node_clone;
1610     HRESULT r;
1611     BSTR str;
1612     static const WCHAR szSearch[] = { 'l', 'c', '/', 'p', 'r', 0 };
1613
1614     r = CoCreateInstance( &CLSID_DOMDocument, NULL, CLSCTX_INPROC_SERVER, &IID_IXMLDOMDocument2, (LPVOID*)&doc );
1615     if( r != S_OK )
1616         return;
1617
1618     str = SysAllocString( szComplete4 );
1619     ole_check(IXMLDOMDocument_loadXML(doc, str, &b));
1620     ok(b == VARIANT_TRUE, "failed to load XML string\n");
1621     SysFreeString(str);
1622
1623     if(!b)
1624         return;
1625
1626     str = SysAllocString( szSearch);
1627     r = IXMLDOMNode_selectSingleNode(doc, str, &node);
1628     ok( r == S_OK, "ret %08x\n", r );
1629     ok( node != NULL, "node %p\n", node );
1630     SysFreeString(str);
1631
1632     if(!node)
1633     {
1634         IXMLDOMDocument_Release(doc);
1635         return;
1636     }
1637
1638     /* Check invalid parameter */
1639     r = IXMLDOMNode_cloneNode(node, VARIANT_TRUE, NULL);
1640     ok( r == E_INVALIDARG, "ret %08x\n", r );
1641
1642     /* All Children */
1643     r = IXMLDOMNode_cloneNode(node, VARIANT_TRUE, &node_clone);
1644     ok( r == S_OK, "ret %08x\n", r );
1645     ok( node_clone != NULL, "node %p\n", node );
1646
1647     if(!node_clone)
1648     {
1649         IXMLDOMDocument_Release(doc);
1650         IXMLDOMNode_Release(node);
1651         return;
1652     }
1653
1654     r = IXMLDOMNode_get_childNodes(node, &pList);
1655     ok( r == S_OK, "ret %08x\n", r );
1656     if (pList)
1657         {
1658                 IXMLDOMNodeList_get_length(pList, &nLength);
1659                 IXMLDOMNodeList_Release(pList);
1660         }
1661
1662     r = IXMLDOMNode_get_attributes(node, &mapAttr);
1663     ok( r == S_OK, "ret %08x\n", r );
1664     if(mapAttr)
1665     {
1666         IXMLDOMNamedNodeMap_get_length(mapAttr, &nAttrCnt);
1667         IXMLDOMNamedNodeMap_Release(mapAttr);
1668     }
1669
1670     r = IXMLDOMNode_get_childNodes(node_clone, &pList);
1671     ok( r == S_OK, "ret %08x\n", r );
1672     if (pList)
1673         {
1674                 IXMLDOMNodeList_get_length(pList, &nLength1);
1675                 IXMLDOMNodeList_Release(pList);
1676         }
1677
1678     r = IXMLDOMNode_get_attributes(node_clone, &mapAttr);
1679     ok( r == S_OK, "ret %08x\n", r );
1680     if(mapAttr)
1681     {
1682         IXMLDOMNamedNodeMap_get_length(mapAttr, &nAttrCnt1);
1683         IXMLDOMNamedNodeMap_Release(mapAttr);
1684     }
1685
1686     ok(nLength == nLength1, "wrong Child count (%ld, %ld)\n", nLength, nLength1);
1687     ok(nAttrCnt == nAttrCnt1, "wrong Attribute count (%ld, %ld)\n", nAttrCnt, nAttrCnt1);
1688     IXMLDOMNode_Release(node_clone);
1689
1690     /* No Children */
1691     r = IXMLDOMNode_cloneNode(node, VARIANT_FALSE, &node_clone);
1692     ok( r == S_OK, "ret %08x\n", r );
1693     ok( node_clone != NULL, "node %p\n", node );
1694
1695     if(!node_clone)
1696     {
1697         IXMLDOMDocument_Release(doc);
1698         IXMLDOMNode_Release(node);
1699         return;
1700     }
1701
1702     r = IXMLDOMNode_get_childNodes(node_clone, &pList);
1703     ok( r == S_OK, "ret %08x\n", r );
1704     if (pList)
1705         {
1706                 IXMLDOMNodeList_get_length(pList, &nLength1);
1707         ok( nLength1 == 0, "Length should be 0 (%ld)\n", nLength1);
1708                 IXMLDOMNodeList_Release(pList);
1709         }
1710
1711     r = IXMLDOMNode_get_attributes(node_clone, &mapAttr);
1712     ok( r == S_OK, "ret %08x\n", r );
1713     if(mapAttr)
1714     {
1715         IXMLDOMNamedNodeMap_get_length(mapAttr, &nAttrCnt1);
1716         ok( nAttrCnt1 == 3, "Attribute count should be 3 (%ld)\n", nAttrCnt1);
1717         IXMLDOMNamedNodeMap_Release(mapAttr);
1718     }
1719
1720     ok(nLength != nLength1, "wrong Child count (%ld, %ld)\n", nLength, nLength1);
1721     ok(nAttrCnt == nAttrCnt1, "wrong Attribute count (%ld, %ld)\n", nAttrCnt, nAttrCnt1);
1722     IXMLDOMNode_Release(node_clone);
1723
1724
1725     IXMLDOMNode_Release(node);
1726     IXMLDOMDocument_Release(doc);
1727 }
1728
1729 START_TEST(domdoc)
1730 {
1731     HRESULT r;
1732
1733     r = CoInitialize( NULL );
1734     ok( r == S_OK, "failed to init com\n");
1735
1736     test_domdoc();
1737     test_domnode();
1738     test_refs();
1739     test_create();
1740     test_getElementsByTagName();
1741     test_get_text();
1742     test_get_childNodes();
1743     test_removeChild();
1744     test_XMLHTTP();
1745     test_IXMLDOMDocument2();
1746     test_XPath();
1747     test_cloneNode();
1748
1749     CoUninitialize();
1750 }