Home | History | Annotate | Download | only in core
      1 
      2 /*
      3 This Java source file was generated by test-to-java.xsl
      4 and is a derived work from the source document.
      5 The source document contained the following notice:
      6 
      7 
      8 Copyright (c) 2001 World Wide Web Consortium,
      9 (Massachusetts Institute of Technology, Institut National de
     10 Recherche en Informatique et en Automatique, Keio University). All
     11 Rights Reserved. This program is distributed under the W3C's Software
     12 Intellectual Property License. This program is distributed in the
     13 hope that it will be useful, but WITHOUT ANY WARRANTY; without even
     14 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
     15 PURPOSE.
     16 See W3C License http://www.w3.org/Consortium/Legal/ for more details.
     17 
     18 */
     19 
     20 package org.w3c.domts.level1.core;
     21 
     22 import org.w3c.dom.*;
     23 
     24 
     25 import org.w3c.domts.DOMTestCase;
     26 import org.w3c.domts.DOMTestDocumentBuilderFactory;
     27 
     28 
     29 
     30 /**
     31  *     The "setAttributeNode(newAttr)" method adds a new
     32  *    attribute to the Element.  If the "newAttr" Attr node is
     33  *    already present in this element, it should replace the
     34  *    existing one.
     35  *
     36  *    Retrieve the last child of the third employee and add a
     37  *    new attribute node by invoking the "setAttributeNode(new
     38  *    Attr)" method.  The new attribute node to be added is
     39  *    "class", which is already present in this element.  The
     40  *    method should replace the existing Attr node with the
     41  *    new one.  This test uses the "createAttribute(name)"
     42  *    method from the Document interface.
     43 * @author Curt Arnold
     44 */
     45 public final class hc_elementreplaceexistingattribute extends DOMTestCase {
     46 
     47    /**
     48     * Constructor.
     49     * @param factory document factory, may not be null
     50     * @throws org.w3c.domts.DOMTestIncompatibleException Thrown if test is not compatible with parser configuration
     51     */
     52    public hc_elementreplaceexistingattribute(final DOMTestDocumentBuilderFactory factory)  throws org.w3c.domts.DOMTestIncompatibleException {
     53       super(factory);
     54 
     55     //
     56     //   check if loaded documents are supported for content type
     57     //
     58     String contentType = getContentType();
     59     preload(contentType, "hc_staff", true);
     60     }
     61 
     62    /**
     63     * Runs the test case.
     64     * @throws Throwable Any uncaught exception causes test to fail
     65     */
     66    public void runTest() throws Throwable {
     67       Document doc;
     68       NodeList elementList;
     69       Element testEmployee;
     70       Attr newAttribute;
     71       String strong;
     72       Attr setAttr;
     73       doc = (Document) load("hc_staff", true);
     74       elementList = doc.getElementsByTagName("acronym");
     75       testEmployee = (Element) elementList.item(2);
     76       newAttribute = doc.createAttribute("class");
     77       setAttr = testEmployee.setAttributeNode(newAttribute);
     78       strong = testEmployee.getAttribute("class");
     79       assertEquals("replacedValue", "", strong);
     80       }
     81    /**
     82     *  Gets URI that identifies the test.
     83     *  @return uri identifier of test
     84     */
     85    public String getTargetURI() {
     86       return "http://www.w3.org/2001/DOM-Test-Suite/level1/core/hc_elementreplaceexistingattribute";
     87    }
     88    /**
     89     * Runs this test from the command line.
     90     * @param args command line arguments
     91     */
     92    public static void main(final String[] args) {
     93         DOMTestCase.doMain(hc_elementreplaceexistingattribute.class, args);
     94    }
     95 }
     96 
     97