Owen Rudge : wsdapi/tests: Add tests for WSDXMLAddSibling.

Alexandre Julliard julliard at winehq.org
Mon May 8 17:21:23 CDT 2017


Module: wine
Branch: master
Commit: e90aaaabe66019903832731c49274466f1b6aed1
URL:    http://source.winehq.org/git/wine.git/?a=commit;h=e90aaaabe66019903832731c49274466f1b6aed1

Author: Owen Rudge <orudge at codeweavers.com>
Date:   Wed May  3 23:55:58 2017 +0100

wsdapi/tests: Add tests for WSDXMLAddSibling.

Signed-off-by: Owen Rudge <orudge at codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard at winehq.org>

---

 dlls/wsdapi/tests/xml.c | 89 +++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 89 insertions(+)

diff --git a/dlls/wsdapi/tests/xml.c b/dlls/wsdapi/tests/xml.c
index 4af81af..fd8ac03 100644
--- a/dlls/wsdapi/tests/xml.c
+++ b/dlls/wsdapi/tests/xml.c
@@ -194,8 +194,97 @@ static void AddChild_tests(void)
     WSDFreeLinkedMemory(parent);
 }
 
+static void AddSibling_tests(void)
+{
+    WSDXML_ELEMENT *parent, *child1, *child2, *child3;
+    WSDXML_NAME parentName, child1Name, child2Name;
+    WSDXML_NAMESPACE ns;
+    WCHAR parentNameText[] = {'D','a','d',0};
+    WCHAR child1NameText[] = {'T','i','m',0};
+    WCHAR child2NameText[] = {'B','o','b',0};
+    static const WCHAR uri[] = {'h','t','t','p',':','/','/','t','e','s','t','.','t','e','s','t','/',0};
+    static const WCHAR prefix[] = {'t',0};
+    HRESULT hr;
+
+    /* Test invalid values */
+    hr = WSDXMLAddSibling(NULL, NULL);
+    ok(hr == E_INVALIDARG, "WSDXMLAddSibling failed with %08x\n", hr);
+
+    hr = WSDXMLAddSibling(child1, NULL);
+    ok(hr == E_INVALIDARG, "WSDXMLAddSibling failed with %08x\n", hr);
+
+    hr = WSDXMLAddSibling(NULL, child2);
+    ok(hr == E_INVALIDARG, "WSDXMLAddSibling failed with %08x\n", hr);
+
+    /* Populate structures */
+    ns.Uri = uri;
+    ns.PreferredPrefix = prefix;
+
+    parentName.LocalName = parentNameText;
+    parentName.Space = &ns;
+
+    child1Name.LocalName = child1NameText;
+    child1Name.Space = &ns;
+
+    child2Name.LocalName = child2NameText;
+    child2Name.Space = &ns;
+
+    /* Create some elements */
+    hr = WSDXMLBuildAnyForSingleElement(&parentName, NULL, &parent);
+    ok(hr == S_OK, "BuildAnyForSingleElement failed with %08x\n", hr);
+
+    hr = WSDXMLBuildAnyForSingleElement(&child1Name, child1NameText, &child1);
+    ok(hr == S_OK, "BuildAnyForSingleElement failed with %08x\n", hr);
+
+    hr = WSDXMLBuildAnyForSingleElement(&child2Name, NULL, &child2);
+    ok(hr == S_OK, "BuildAnyForSingleElement failed with %08x\n", hr);
+
+    hr = WSDXMLBuildAnyForSingleElement(&child2Name, NULL, &child3);
+    ok(hr == S_OK, "BuildAnyForSingleElement failed with %08x\n", hr);
+
+    /* Add child1 to parent */
+    hr = WSDXMLAddChild(parent, child1);
+    ok(hr == S_OK, "WSDXMLAddChild failed with %08x\n", hr);
+
+    ok(parent->Node.Parent == NULL, "parent->Node.Parent == %p\n", parent->Node.Parent);
+    ok(parent->FirstChild == (WSDXML_NODE *)child1, "parent->FirstChild == %p\n", parent->FirstChild);
+    ok(parent->Node.Next == NULL, "parent->Node.Next == %p\n", parent->Node.Next);
+    ok(child1->Node.Parent == parent, "child1->Node.Parent == %p\n", child1->Node.Parent);
+    ok(child1->FirstChild != NULL, "child1->FirstChild == NULL\n");
+    ok(child1->FirstChild->Type == TextType, "child1->FirstChild.Type == %d\n", child1->FirstChild->Type);
+    ok(child1->Node.Next == NULL, "child1->Node.Next == %p\n", child1->Node.Next);
+    ok(child2->Node.Parent == NULL, "child2->Node.Parent == %p\n", child2->Node.Parent);
+    ok(child2->FirstChild == NULL, "child2->FirstChild == %p\n", child2->FirstChild);
+    ok(child2->Node.Next == NULL, "child2->Node.Next == %p\n", child2->Node.Next);
+
+    /* Try to add child2 as sibling of child1 */
+    hr = WSDXMLAddSibling(child1, child2);
+    ok(hr == S_OK, "WSDXMLAddSibling failed with %08x\n", hr);
+
+    ok(child1->Node.Parent == parent, "child1->Node.Parent == %p\n", child1->Node.Parent);
+    ok(child1->Node.Next == (WSDXML_NODE *)child2, "child1->Node.Next == %p\n", child1->Node.Next);
+    ok(child2->Node.Parent == parent, "child2->Node.Parent == %p\n", child2->Node.Parent);
+    ok(child2->Node.Next == NULL, "child2->Node.Next == %p\n", child2->Node.Next);
+    ok(parent->FirstChild == (WSDXML_NODE *)child1, "parent->FirstChild == %p\n", parent->FirstChild);
+
+    /* Try to add child3 as sibling of child1 */
+    hr = WSDXMLAddSibling(child1, child3);
+    ok(hr == S_OK, "WSDXMLAddSibling failed with %08x\n", hr);
+
+    ok(child1->Node.Parent == parent, "child1->Node.Parent == %p\n", child1->Node.Parent);
+    ok(child1->Node.Next == (WSDXML_NODE *)child2, "child1->Node.Next == %p\n", child1->Node.Next);
+    ok(child2->Node.Parent == parent, "child2->Node.Parent == %p\n", child2->Node.Parent);
+    ok(child2->Node.Next == (WSDXML_NODE *)child3, "child2->Node.Next == %p\n", child2->Node.Next);
+    ok(child3->Node.Parent == parent, "child2->Node.Parent == %p\n", child2->Node.Parent);
+    ok(child3->Node.Next == NULL, "child2->Node.Next == %p\n", child2->Node.Next);
+    ok(parent->FirstChild == (WSDXML_NODE *)child1, "parent->FirstChild == %p\n", parent->FirstChild);
+
+    WSDFreeLinkedMemory(parent);
+}
+
 START_TEST(xml)
 {
     BuildAnyForSingleElement_tests();
     AddChild_tests();
+    AddSibling_tests();
 }




More information about the wine-cvs mailing list