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 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 "setAttributeNode(newAttr)" method replaces an 32 * existing Attr node with the same name, then it should 33 * return the previously existing Attr node. 34 * Retrieve the last child of the third employee and add a 35 * new attribute node. The new attribute node is "street", 36 * which is already present in this Element. The method 37 * should return the existing Attr node(old "street" Attr). 38 * This test uses the "createAttribute(name)" method 39 * from the Document interface. 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-887236154">http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-core#ID-887236154</a> 43*/ 44public final class elementreplaceexistingattributegevalue 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 elementreplaceexistingattributegevalue(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 Element testEmployee; 69 Attr newAttribute; 70 Attr streetAttr; 71 String value; 72 doc = (Document) load("staff", true); 73 elementList = doc.getElementsByTagName("address"); 74 testEmployee = (Element) elementList.item(2); 75 newAttribute = doc.createAttribute("street"); 76 streetAttr = testEmployee.setAttributeNode(newAttribute); 77 value = streetAttr.getValue(); 78 assertEquals("streetNo", "No", value); 79 } 80 /** 81 * Gets URI that identifies the test. 82 * @return uri identifier of test 83 */ 84 public String getTargetURI() { 85 return "http://www.w3.org/2001/DOM-Test-Suite/level1/core/elementreplaceexistingattributegevalue"; 86 } 87 /** 88 * Runs this test from the command line. 89 * @param args command line arguments 90 */ 91 public static void main(final String[] args) { 92 DOMTestCase.doMain(elementreplaceexistingattributegevalue.class, args); 93 } 94} 95 96