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