test_HTMLOptionsCollection03.html (7554B)
1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> 2 <html> 3 <head> 4 <META http-equiv="Content-Type" content="text/html; charset=UTF-8"> 5 <meta content="text/html; charset=UTF-8" http-equiv="Content-Type"> 6 <title>http://www.w3.org/2001/DOM-Test-Suite/level2/html/HTMLOptionsCollection03</title> 7 <link type="text/css" rel="stylesheet" href="/tests/SimpleTest/test.css"> 8 <script src="/tests/SimpleTest/SimpleTest.js" type="text/javascript"></script> 9 <script src="DOMTestCase.js" type="text/javascript"></script> 10 <script type="text/javascript"> 11 // expose test function names 12 function exposeTestFunctionNames() 13 { 14 return ['HTMLOptionsCollection03']; 15 } 16 17 var docsLoaded = -1000000; 18 var builder = null; 19 20 // 21 // This function is called by the testing framework before 22 // running the test suite. 23 // 24 // If there are no configuration exceptions, asynchronous 25 // document loading is started. Otherwise, the status 26 // is set to complete and the exception is immediately 27 // raised when entering the body of the test. 28 // 29 function setUpPage() { 30 setUpPageStatus = 'running'; 31 try { 32 // 33 // creates test document builder, may throw exception 34 // 35 builder = createConfiguredBuilder(); 36 37 docsLoaded = 0; 38 39 var docRef = null; 40 if (typeof(this.doc) != 'undefined') { 41 docRef = this.doc; 42 } 43 docsLoaded += preload(docRef, "doc", "optionscollection"); 44 45 if (docsLoaded == 1) { 46 setUpPage = 'complete'; 47 } 48 } catch(ex) { 49 catchInitializationError(builder, ex); 50 setUpPage = 'complete'; 51 } 52 } 53 54 55 56 // 57 // This method is called on the completion of 58 // each asychronous load started in setUpTests. 59 // 60 // When every synchronous loaded document has completed, 61 // the page status is changed which allows the 62 // body of the test to be executed. 63 function loadComplete() { 64 if (++docsLoaded == 1) { 65 setUpPageStatus = 'complete'; 66 runJSUnitTests(); 67 SimpleTest.finish(); 68 } 69 } 70 71 72 /** 73 * 74 An HTMLOptionsCollection is a list of nodes representing HTML option 75 element. 76 An individual node may be accessed by either ordinal index, the node's 77 name or id attributes. (Test node name). 78 The namedItem method retrieves a Node using a name. It first searches 79 for a node with a matching id attribute. If it doesn't find one, it 80 then searches for a Node with a matching name attribute, but only 81 those elements that are allowed a name attribute. 82 83 Retrieve the first FORM element. Create a HTMLCollection of the elements. 84 Search for an element that has select1 as the value for the name attribute. 85 Get the nodeName of that element. 86 87 * @author NIST 88 * @author Rick Rivello 89 * @see http://www.w3.org/TR/DOM-Level-2-HTML/html#HTMLOptionsCollection-namedItem 90 */ 91 function HTMLOptionsCollection03() { 92 var success; 93 if(checkInitialization(builder, "HTMLOptionsCollection03") != null) return; 94 var nodeList; 95 var testNode; 96 var optionsNode; 97 var formsnodeList; 98 var vname; 99 var doc; 100 101 var docRef = null; 102 if (typeof(this.doc) != 'undefined') { 103 docRef = this.doc; 104 } 105 doc = load(docRef, "doc", "optionscollection"); 106 nodeList = doc.getElementsByTagName("form"); 107 assertSize("Asize",1,nodeList); 108 testNode = nodeList.item(0); 109 formsnodeList = testNode.elements; 110 111 optionsNode = formsnodeList.namedItem("select1"); 112 vname = optionsNode.nodeName; 113 114 assertEqualsAutoCase("element", "nameIndexLink","select",vname); 115 116 } 117 118 </script> 119 </head> 120 <body> 121 <h2>Test http://www.w3.org/2001/DOM-Test-Suite/level2/html/HTMLOptionsCollection03</h2> 122 <p><test name='HTMLOptionsCollection03' schemaLocation='http://www.w3.org/2001/DOM-Test-Suite/Level-2 dom2.xsd'><br> <metadata><br> <title>HTMLOptionsCollection03</title> 123 <br> <creator>NIST</creator> 124 <br> <description> 125 An HTMLOptionsCollection is a list of nodes representing HTML option 126 element. 127 An individual node may be accessed by either ordinal index, the node's 128 name or id attributes. (Test node name). 129 The namedItem method retrieves a Node using a name. It first searches 130 for a node with a matching id attribute. If it doesn't find one, it 131 then searches for a Node with a matching name attribute, but only 132 those elements that are allowed a name attribute. 133 134 Retrieve the first FORM element. Create a HTMLCollection of the elements. 135 Search for an element that has select1 as the value for the name attribute. 136 Get the nodeName of that element. 137 </description> 138 <br> <contributor>Rick Rivello</contributor> 139 <br> <date qualifier='created'>2002-08-01</date> 140 <br> <subject resource='<a href="http://www.w3.org/TR/DOM-Level-2-HTML/html#HTMLOptionsCollection-namedItem">http://www.w3.org/TR/DOM-Level-2-HTML/html#HTMLOptionsCollection-namedItem</a>'/> 141 <br></metadata><br> <var name='nodeList' type='NodeList'/><br> <var name='testNode' type='Node'/><br> <var name='optionsNode' type='Node'/><br> <var name='formsnodeList' type='HTMLCollection'/><br> <var name='vname' type='DOMString'/><br> <var name='doc' type='Document'/><br> <load var='doc' href='optionscollection' willBeModified='false'/><br> <getElementsByTagName interface='Document' obj='doc' var='nodeList' tagname='"form"'/><br> <assertSize collection='nodeList' size='1' <a id="Asize">id='Asize'</a>/><br> <item interface='NodeList' obj='nodeList' var='testNode' index='0'/><br> <elements interface='HTMLFormElement' obj='testNode' var='formsnodeList'/><br> <namedItem interface='HTMLOptionsCollection' obj='formsnodeList' var='optionsNode' name='"select1"'/><br> <nodeName obj='optionsNode' var='vname'/><br> <assertEquals actual='vname' expected='"select"' <a id="nameIndexLink">id='nameIndexLink'</a> ignoreCase='auto'/><br></test><br> 142 </p> 143 <p> 144 Copyright (c) 2001-2004 World Wide Web Consortium, 145 (Massachusetts Institute of Technology, Institut National de 146 Recherche en Informatique et en Automatique, Keio University). All 147 Rights Reserved. This program is distributed under the W3C's Software 148 Intellectual Property License. This program is distributed in the 149 hope that it will be useful, but WITHOUT ANY WARRANTY; without even 150 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR 151 PURPOSE. 152 </p> 153 <p>See W3C License <a href="http://www.w3.org/Consortium/Legal/">http://www.w3.org/Consortium/Legal/</a> 154 for more details.</p> 155 <iframe name="doc" src="files/optionscollection.html"></iframe> 156 <br> 157 </body> 158 </html>