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 *     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 *    "street", 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 NIST
44* @author Mary Brady
45*/
46public final class elementreplaceexistingattribute extends DOMTestCase {
47
48   /**
49    * Constructor.
50    * @param factory document factory, may not be null
51    * @throws org.w3c.domts.DOMTestIncompatibleException Thrown if test is not compatible with parser configuration
52    */
53   public elementreplaceexistingattribute(final DOMTestDocumentBuilderFactory factory)  throws org.w3c.domts.DOMTestIncompatibleException {
54      super(factory);
55
56    //
57    //   check if loaded documents are supported for content type
58    //
59    String contentType = getContentType();
60    preload(contentType, "staff", true);
61    }
62
63   /**
64    * Runs the test case.
65    * @throws Throwable Any uncaught exception causes test to fail
66    */
67   public void runTest() throws Throwable {
68      Document doc;
69      NodeList elementList;
70      Element testEmployee;
71      Attr newAttribute;
72      String name;
73      Attr setAttr;
74      doc = (Document) load("staff", true);
75      elementList = doc.getElementsByTagName("address");
76      testEmployee = (Element) elementList.item(2);
77      newAttribute = doc.createAttribute("street");
78      setAttr = testEmployee.setAttributeNode(newAttribute);
79      name = testEmployee.getAttribute("street");
80      assertEquals("elementReplaceExistingAttributeAssert", "", name);
81      }
82   /**
83    *  Gets URI that identifies the test.
84    *  @return uri identifier of test
85    */
86   public String getTargetURI() {
87      return "http://www.w3.org/2001/DOM-Test-Suite/level1/core/elementreplaceexistingattribute";
88   }
89   /**
90    * Runs this test from the command line.
91    * @param args command line arguments
92    */
93   public static void main(final String[] args) {
94        DOMTestCase.doMain(elementreplaceexistingattribute.class, args);
95   }
96}
97
98