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 9 Copyright (c) 2001 World Wide Web Consortium, 10 (Massachusetts Institute of Technology, Institut National de 11 Recherche en Informatique et en Automatique, Keio University). All 12 Rights Reserved. This program is distributed under the W3C's Software 13 Intellectual Property License. This program is distributed in the 14 hope that it will be useful, but WITHOUT ANY WARRANTY; without even 15 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR 16 PURPOSE. 17 18 See W3C License http://www.w3.org/Consortium/Legal/ for more details. 19 20 21 */ 22 23 package org.w3c.domts.level2.core; 24 25 import org.w3c.dom.*; 26 27 28 import org.w3c.domts.DOMTestCase; 29 import org.w3c.domts.DOMTestDocumentBuilderFactory; 30 31 32 33 /** 34 * The "createDocumentType(qualifiedName,publicId,systemId)" method for a 35 * DOMImplementation should raise INVALID_CHARACTER_ERR DOMException if 36 * qualifiedName contains an illegal character. 37 * 38 * Invoke method createDocumentType(qualifiedName,publicId,systemId) on 39 * this domimplementation with qualifiedName containing an illegal character 40 * from illegalChars[]. Method should raise INVALID_CHARACTER_ERR 41 * DOMException for all characters in illegalChars[]. 42 * @author NIST 43 * @author Mary Brady 44 * @see <a href="http://www.w3.org/TR/DOM-Level-2-Core/core#Level-2-Core-DOM-createDocType">http://www.w3.org/TR/DOM-Level-2-Core/core#Level-2-Core-DOM-createDocType</a> 45 * @see <a href="http://www.w3.org/TR/DOM-Level-2-Core/core#xpointer(id('Level-2-Core-DOM-createDocType')/raises/exception[@name='DOMException']/descr/p[substring-before(.,':')='INVALID_CHARACTER_ERR'])">http://www.w3.org/TR/DOM-Level-2-Core/core#xpointer(id('Level-2-Core-DOM-createDocType')/raises/exception[@name='DOMException']/descr/p[substring-before(.,':')='INVALID_CHARACTER_ERR'])</a> 46 */ 47 public final class createDocumentType02 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 createDocumentType02(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", false); 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 publicId = "http://www.localhost.com/"; 70 String systemId = "myDoc.dtd"; 71 String qualifiedName; 72 Document doc; 73 DocumentType docType = null; 74 75 DOMImplementation domImpl; 76 java.util.List illegalQNames = new java.util.ArrayList(); 77 illegalQNames.add("edi:{"); 78 illegalQNames.add("edi:}"); 79 illegalQNames.add("edi:~"); 80 illegalQNames.add("edi:'"); 81 illegalQNames.add("edi:!"); 82 illegalQNames.add("edi:@"); 83 illegalQNames.add("edi:#"); 84 illegalQNames.add("edi:$"); 85 illegalQNames.add("edi:%"); 86 illegalQNames.add("edi:^"); 87 illegalQNames.add("edi:&"); 88 illegalQNames.add("edi:*"); 89 illegalQNames.add("edi:("); 90 illegalQNames.add("edi:)"); 91 illegalQNames.add("edi:+"); 92 illegalQNames.add("edi:="); 93 illegalQNames.add("edi:["); 94 illegalQNames.add("edi:]"); 95 illegalQNames.add("edi:\\"); 96 illegalQNames.add("edi:/"); 97 illegalQNames.add("edi:;"); 98 illegalQNames.add("edi:`"); 99 illegalQNames.add("edi:<"); 100 illegalQNames.add("edi:>"); 101 illegalQNames.add("edi:,"); 102 illegalQNames.add("edi:a "); 103 illegalQNames.add("edi:\""); 104 105 doc = (Document) load("staffNS", false); 106 for (int indexN1009A = 0; indexN1009A < illegalQNames.size(); indexN1009A++) { 107 qualifiedName = (String) illegalQNames.get(indexN1009A); 108 domImpl = doc.getImplementation(); 109 110 { 111 boolean success = false; 112 try { 113 docType = domImpl.createDocumentType(qualifiedName, publicId, systemId); 114 } catch (DOMException ex) { 115 success = (ex.code == DOMException.INVALID_CHARACTER_ERR); 116 } 117 assertTrue("throw_INVALID_CHARACTER_ERR", success); 118 } 119 } 120 } 121 /** 122 * Gets URI that identifies the test. 123 * @return uri identifier of test 124 */ 125 public String getTargetURI() { 126 return "http://www.w3.org/2001/DOM-Test-Suite/level2/core/createDocumentType02"; 127 } 128 /** 129 * Runs this test from the command line. 130 * @param args command line arguments 131 */ 132 public static void main(final String[] args) { 133 DOMTestCase.doMain(createDocumentType02.class, args); 134 } 135 } 136 137