1
2/*
3This Java source file was generated by test-to-java.xsl
4and is a derived work from the source document.
5The source document contained the following notice:
6
7
8Copyright (c) 2001-2004 World Wide Web Consortium,
9(Massachusetts Institute of Technology, Institut National de
10Recherche en Informatique et en Automatique, Keio University). All
11Rights Reserved. This program is distributed under the W3C's Software
12Intellectual Property License. This program is distributed in the
13hope that it will be useful, but WITHOUT ANY WARRANTY; without even
14the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
15PURPOSE.
16See W3C License http://www.w3.org/Consortium/Legal/ for more details.
17
18*/
19
20package org.w3c.domts.level1.core;
21
22import org.w3c.dom.*;
23
24
25import org.w3c.domts.DOMTestCase;
26import org.w3c.domts.DOMTestDocumentBuilderFactory;
27
28
29
30/**
31 *     If the "newChild" is already in the tree, it is first
32 *     removed before the new one is appended.
33 *
34 *     Retrieve the first child of the second employee and
35 *     append the first child to the end of the list.   After
36 *     the "appendChild(newChild)" method is invoked the first
37 *     child should be the one that was second and the last
38 *     child should be the one that was first.
39* @author NIST
40* @author Mary Brady
41* @see <a href="http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-core#ID-184E7107">http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-core#ID-184E7107</a>
42*/
43public final class nodeappendchildchildexists extends DOMTestCase {
44
45   /**
46    * Constructor.
47    * @param factory document factory, may not be null
48    * @throws org.w3c.domts.DOMTestIncompatibleException Thrown if test is not compatible with parser configuration
49    */
50   public nodeappendchildchildexists(final DOMTestDocumentBuilderFactory factory)  throws org.w3c.domts.DOMTestIncompatibleException {
51      super(factory);
52
53    //
54    //   check if loaded documents are supported for content type
55    //
56    String contentType = getContentType();
57    preload(contentType, "staff", true);
58    }
59
60   /**
61    * Runs the test case.
62    * @throws Throwable Any uncaught exception causes test to fail
63    */
64   public void runTest() throws Throwable {
65      Document doc;
66      NodeList elementList;
67      Node childNode;
68      Node newChild;
69      Node lchild;
70      Node fchild;
71      String lchildName;
72      String fchildName;
73      Node appendedChild;
74      String initialName;
75      doc = (Document) load("staff", true);
76      elementList = doc.getElementsByTagName("employee");
77      childNode = elementList.item(1);
78      newChild = childNode.getFirstChild();
79      initialName = newChild.getNodeName();
80      appendedChild = childNode.appendChild(newChild);
81      fchild = childNode.getFirstChild();
82      fchildName = fchild.getNodeName();
83      lchild = childNode.getLastChild();
84      lchildName = lchild.getNodeName();
85
86      if (equals("employeeId", initialName)) {
87          assertEquals("assert1_nowhitespace", "name", fchildName);
88      assertEquals("assert2_nowhitespace", "employeeId", lchildName);
89      } else {
90          assertEquals("assert1", "employeeId", fchildName);
91      assertEquals("assert2", "#text", lchildName);
92      }
93
94    }
95   /**
96    *  Gets URI that identifies the test.
97    *  @return uri identifier of test
98    */
99   public String getTargetURI() {
100      return "http://www.w3.org/2001/DOM-Test-Suite/level1/core/nodeappendchildchildexists";
101   }
102   /**
103    * Runs this test from the command line.
104    * @param args command line arguments
105    */
106   public static void main(final String[] args) {
107        DOMTestCase.doMain(nodeappendchildchildexists.class, args);
108   }
109}
110
111