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
8
9Copyright (c) 2001 World Wide Web Consortium,
10(Massachusetts Institute of Technology, Institut National de
11Recherche en Informatique et en Automatique, Keio University).  All
12Rights Reserved.  This program is distributed under the W3C's Software
13Intellectual Property License.  This program is distributed in the
14hope that it will be useful, but WITHOUT ANY WARRANTY; without even
15the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
16PURPOSE.
17
18See W3C License http://www.w3.org/Consortium/Legal/ for more details.
19
20
21*/
22
23package org.w3c.domts.level2.core;
24
25import org.w3c.dom.*;
26
27
28import org.w3c.domts.DOMTestCase;
29import org.w3c.domts.DOMTestDocumentBuilderFactory;
30
31
32
33/**
34 *     The "setAttributeNS(namespaceURI,qualifiedName,Value)" method raises a
35 *    INVALID_CHARACTER_ERR DOMException if the specified
36 *    prefix contains an illegal character.
37 *
38 *    Attempt to add a new attribute on the first employee node.
39 *    An exception should be raised since the "qualifiedName" has an invalid
40 *    character.
41* @author NIST
42* @author Mary Brady
43* @see <a href="http://www.w3.org/TR/DOM-Level-2-Core/core#xpointer(id('ID-258A00AF')/constant[@name='INVALID_CHARACTER_ERR'])">http://www.w3.org/TR/DOM-Level-2-Core/core#xpointer(id('ID-258A00AF')/constant[@name='INVALID_CHARACTER_ERR'])</a>
44* @see <a href="http://www.w3.org/TR/DOM-Level-2-Core/core#ID-ElSetAttrNS">http://www.w3.org/TR/DOM-Level-2-Core/core#ID-ElSetAttrNS</a>
45* @see <a href="http://www.w3.org/TR/DOM-Level-2-Core/core#xpointer(id('ID-ElSetAttrNS')/raises/exception[@name='DOMException']/descr/p[substring-before(.,':')='INVALID_CHARACTER_ERR'])">http://www.w3.org/TR/DOM-Level-2-Core/core#xpointer(id('ID-ElSetAttrNS')/raises/exception[@name='DOMException']/descr/p[substring-before(.,':')='INVALID_CHARACTER_ERR'])</a>
46*/
47public final class setAttributeNS01 extends DOMTestCase {
48
49   /**
50    * Constructor.
51    * @param factory document factory, may not be null
52    * @throws org.w3c.domts.DOMTestIncompatibleException Thrown if test is not compatible with parser configuration
53    */
54   public setAttributeNS01(final DOMTestDocumentBuilderFactory factory)  throws org.w3c.domts.DOMTestIncompatibleException {
55      super(factory);
56
57    //
58    //   check if loaded documents are supported for content type
59    //
60    String contentType = getContentType();
61    preload(contentType, "staffNS", true);
62    }
63
64   /**
65    * Runs the test case.
66    * @throws Throwable Any uncaught exception causes test to fail
67    */
68   public void runTest() throws Throwable {
69      String namespaceURI = "http://www.nist.gov";
70      String qualifiedName = "emp:qual?name";
71      Document doc;
72      NodeList elementList;
73      Node testAddr;
74      doc = (Document) load("staffNS", true);
75      elementList = doc.getElementsByTagName("employee");
76      testAddr = elementList.item(0);
77
78      {
79         boolean success = false;
80         try {
81            ((Element) /*Node */testAddr).setAttributeNS(namespaceURI, qualifiedName, "newValue");
82          } catch (DOMException ex) {
83            success = (ex.code == DOMException.INVALID_CHARACTER_ERR);
84         }
85         assertTrue("throw_INVALID_CHARACTER_ERR", success);
86      }
87}
88   /**
89    *  Gets URI that identifies the test.
90    *  @return uri identifier of test
91    */
92   public String getTargetURI() {
93      return "http://www.w3.org/2001/DOM-Test-Suite/level2/core/setAttributeNS01";
94   }
95   /**
96    * Runs this test from the command line.
97    * @param args command line arguments
98    */
99   public static void main(final String[] args) {
100        DOMTestCase.doMain(setAttributeNS01.class, args);
101   }
102}
103
104