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-2003 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 "appendChild(newChild)" method raises a 32 * WRONG_DOCUMENT_ERR DOMException if the "newChild" was 33 * created from a different document than the one that 34 * created this node. 35 * 36 * Retrieve the second employee and attempt to append 37 * a node created from a different document. An attempt 38 * to make such a replacement should raise the desired 39 * exception. 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#xpointer(id('ID-258A00AF')/constant[@name='NOT_FOUND_ERR'])">http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-core#xpointer(id('ID-258A00AF')/constant[@name='NOT_FOUND_ERR'])</a> 43* @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> 44* @see <a href="http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-core#xpointer(id('ID-184E7107')/raises/exception[@name='DOMException']/descr/p[substring-before(.,':')='NOT_FOUND_ERR'])">http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-core#xpointer(id('ID-184E7107')/raises/exception[@name='DOMException']/descr/p[substring-before(.,':')='NOT_FOUND_ERR'])</a> 45* @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> 46* @see <a href="http://www.w3.org/Bugs/Public/show_bug.cgi?id=249">http://www.w3.org/Bugs/Public/show_bug.cgi?id=249</a> 47*/ 48public final class nodeappendchildnewchilddiffdocument extends DOMTestCase { 49 50 /** 51 * Constructor. 52 * @param factory document factory, may not be null 53 * @throws org.w3c.domts.DOMTestIncompatibleException Thrown if test is not compatible with parser configuration 54 */ 55 public nodeappendchildnewchilddiffdocument(final DOMTestDocumentBuilderFactory factory) throws org.w3c.domts.DOMTestIncompatibleException { 56 super(factory); 57 58 // 59 // check if loaded documents are supported for content type 60 // 61 String contentType = getContentType(); 62 preload(contentType, "staff", false); 63 preload(contentType, "staff", true); 64 } 65 66 /** 67 * Runs the test case. 68 * @throws Throwable Any uncaught exception causes test to fail 69 */ 70 public void runTest() throws Throwable { 71 Document doc1; 72 Document doc2; 73 Node newChild; 74 NodeList elementList; 75 Node elementNode; 76 Node appendedChild; 77 doc1 = (Document) load("staff", false); 78 doc2 = (Document) load("staff", true); 79 newChild = doc1.createElement("newChild"); 80 elementList = doc2.getElementsByTagName("employee"); 81 elementNode = elementList.item(1); 82 83 { 84 boolean success = false; 85 try { 86 appendedChild = elementNode.appendChild(newChild); 87 } catch (DOMException ex) { 88 success = (ex.code == DOMException.WRONG_DOCUMENT_ERR); 89 } 90 assertTrue("throw_WRONG_DOCUMENT_ERR", success); 91 } 92} 93 /** 94 * Gets URI that identifies the test. 95 * @return uri identifier of test 96 */ 97 public String getTargetURI() { 98 return "http://www.w3.org/2001/DOM-Test-Suite/level1/core/nodeappendchildnewchilddiffdocument"; 99 } 100 /** 101 * Runs this test from the command line. 102 * @param args command line arguments 103 */ 104 public static void main(final String[] args) { 105 DOMTestCase.doMain(nodeappendchildnewchilddiffdocument.class, args); 106 } 107} 108 109