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 * The "cloneNode(deep)" method returns a copy of the node 32 * and the subtree under it if deep=true. 33 * 34 * Retrieve the second employee and invoke the 35 * "cloneNode(deep)" method with deep=true. The 36 * method should clone this node and the subtree under it. 37 * The NodeName of each child in the returned node is 38 * checked to insure the entire subtree under the second 39 * employee was cloned. 40* @author NIST 41* @author Mary Brady 42* @see <a href="http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-core#ID-3A0ED0A4">http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-core#ID-3A0ED0A4</a> 43*/ 44public final class nodeclonenodetrue extends DOMTestCase { 45 46 /** 47 * Constructor. 48 * @param factory document factory, may not be null 49 * @throws org.w3c.domts.DOMTestIncompatibleException Thrown if test is not compatible with parser configuration 50 */ 51 public nodeclonenodetrue(final DOMTestDocumentBuilderFactory factory) throws org.w3c.domts.DOMTestIncompatibleException { 52 super(factory); 53 54 // 55 // check if loaded documents are supported for content type 56 // 57 String contentType = getContentType(); 58 preload(contentType, "staff", true); 59 } 60 61 /** 62 * Runs the test case. 63 * @throws Throwable Any uncaught exception causes test to fail 64 */ 65 public void runTest() throws Throwable { 66 Document doc; 67 NodeList elementList; 68 Node employeeNode; 69 NodeList childList; 70 Node clonedNode; 71 NodeList clonedList; 72 Node clonedChild; 73 String clonedChildName; 74 int length; 75 java.util.List result = new java.util.ArrayList(); 76 77 java.util.List expectedWhitespace = new java.util.ArrayList(); 78 expectedWhitespace.add("#text"); 79 expectedWhitespace.add("employeeId"); 80 expectedWhitespace.add("#text"); 81 expectedWhitespace.add("name"); 82 expectedWhitespace.add("#text"); 83 expectedWhitespace.add("position"); 84 expectedWhitespace.add("#text"); 85 expectedWhitespace.add("salary"); 86 expectedWhitespace.add("#text"); 87 expectedWhitespace.add("gender"); 88 expectedWhitespace.add("#text"); 89 expectedWhitespace.add("address"); 90 expectedWhitespace.add("#text"); 91 92 java.util.List expectedNoWhitespace = new java.util.ArrayList(); 93 expectedNoWhitespace.add("employeeId"); 94 expectedNoWhitespace.add("name"); 95 expectedNoWhitespace.add("position"); 96 expectedNoWhitespace.add("salary"); 97 expectedNoWhitespace.add("gender"); 98 expectedNoWhitespace.add("address"); 99 100 doc = (Document) load("staff", true); 101 elementList = doc.getElementsByTagName("employee"); 102 employeeNode = elementList.item(1); 103 childList = employeeNode.getChildNodes(); 104 length = (int) childList.getLength(); 105 clonedNode = employeeNode.cloneNode(true); 106 clonedList = clonedNode.getChildNodes(); 107 for (int indexN100AE = 0; indexN100AE < clonedList.getLength(); indexN100AE++) { 108 clonedChild = (Node) clonedList.item(indexN100AE); 109 clonedChildName = clonedChild.getNodeName(); 110 result.add(clonedChildName); 111 } 112 113 if (equals(6, length)) { 114 assertEquals("nowhitespace", expectedNoWhitespace, result); 115 } else { 116 assertEquals("whitespace", expectedWhitespace, result); 117 } 118 119 } 120 /** 121 * Gets URI that identifies the test. 122 * @return uri identifier of test 123 */ 124 public String getTargetURI() { 125 return "http://www.w3.org/2001/DOM-Test-Suite/level1/core/nodeclonenodetrue"; 126 } 127 /** 128 * Runs this test from the command line. 129 * @param args command line arguments 130 */ 131 public static void main(final String[] args) { 132 DOMTestCase.doMain(nodeclonenodetrue.class, args); 133 } 134} 135 136