dom/tests/mochitest/dom-level2-html/test_HTMLSelectElement18.html

branch
TOR_BUG_9701
changeset 9
a63d609f5ebe
equal deleted inserted replaced
-1:000000000000 0:b316abad4678
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/HTMLSelectElement18</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 ['HTMLSelectElement18'];
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", "select");
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 Add a new option at the end of an select using HTMLSelectElement.add.
75
76 * @author Curt Arnold
77 * @see http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-html#ID-14493106
78 */
79 function HTMLSelectElement18() {
80 var success;
81 if(checkInitialization(builder, "HTMLSelectElement18") != null) return;
82 var nodeList;
83 var testNode;
84 var doc;
85 var optLength;
86 var selected;
87 var newOpt;
88 var newOptText;
89 var opt;
90 var optText;
91 var optValue;
92 var retNode;
93 var nullNode = null;
94
95
96 var docRef = null;
97 if (typeof(this.doc) != 'undefined') {
98 docRef = this.doc;
99 }
100 doc = load(docRef, "doc", "select");
101 nodeList = doc.getElementsByTagName("select");
102 assertSize("Asize",3,nodeList);
103 testNode = nodeList.item(0);
104 newOpt = doc.createElement("option");
105 newOptText = doc.createTextNode("EMP31415");
106 retNode = newOpt.appendChild(newOptText);
107 testNode.add(newOpt,nullNode);
108 optLength = testNode.length;
109
110 assertEquals("optLength",6,optLength);
111 selected = testNode.selectedIndex;
112
113 assertEquals("selected",0,selected);
114 opt = testNode.lastChild;
115
116 optText = opt.firstChild;
117
118 optValue = optText.nodeValue;
119
120 assertEquals("lastValue","EMP31415",optValue);
121
122 }
123
124 </script>
125 </head>
126 <body>
127 <h2>Test http://www.w3.org/2001/DOM-Test-Suite/level2/html/HTMLSelectElement18</h2>
128 <p>&lt;test name='HTMLSelectElement18' schemaLocation='http://www.w3.org/2001/DOM-Test-Suite/Level-1 dom1.xsd'&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;metadata&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;title&gt;HTMLSelectElement18&lt;/title&gt;
129 <br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;creator&gt;Curt Arnold&lt;/creator&gt;
130 <br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;description&gt;
131 Add a new option at the end of an select using HTMLSelectElement.add.
132 &lt;/description&gt;
133 <br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;date qualifier='created'&gt;2004-03-18&lt;/date&gt;
134 <br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;subject resource='<a href="http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-html#ID-14493106">http://www.w3.org/TR/1998/REC-DOM-Level-1-19981001/level-one-html#ID-14493106</a>'/&gt;
135 <br>&lt;/metadata&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;var name='nodeList' type='NodeList'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;var name='testNode' type='Node'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;var name='doc' type='Document'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;var name='optLength' type='int'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;var name='selected' type='int'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;var name='newOpt' type='Element'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;var name='newOptText' type='Text'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;var name='opt' type='Element'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;var name='optText' type='Text'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;var name='optValue' type='DOMString'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;var name='retNode' type='Node'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;var name='nullNode' type='Node' isNull='true'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;load var='doc' href='select' willBeModified='true'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;getElementsByTagName interface='Document' obj='doc' var='nodeList' tagname='"select"'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;assertSize collection='nodeList' size='3' <a id="Asize">id='Asize'</a>/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;item interface='NodeList' obj='nodeList' var='testNode' index='0'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;createElement var='newOpt' obj='doc' tagName='"option"'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;createTextNode var='newOptText' obj='doc' data='"EMP31415"'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;appendChild var='retNode' obj='newOpt' newChild='newOptText'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;add interface='HTMLSelectElement' obj='testNode' element='newOpt' before='nullNode'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;length interface='HTMLSelectElement' obj='testNode' var='optLength'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;assertEquals actual='optLength' expected='6' <a id="optLength">id='optLength'</a> ignoreCase='false'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;selectedIndex interface='HTMLSelectElement' obj='testNode' var='selected'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;assertEquals actual='selected' expected='0' <a id="selected">id='selected'</a> ignoreCase='false'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;lastChild var='opt' obj='testNode' interface='Node'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;firstChild var='optText' obj='opt' interface='Node'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;nodeValue var='optValue' obj='optText'/&gt;<br>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&lt;assertEquals actual='optValue' expected='"EMP31415"' <a id="lastValue">id='lastValue'</a> ignoreCase='false'/&gt;<br>&lt;/test&gt;<br>
136 </p>
137 <p>
138 Copyright (c) 2001-2004 World Wide Web Consortium,
139 (Massachusetts Institute of Technology, Institut National de
140 Recherche en Informatique et en Automatique, Keio University). All
141 Rights Reserved. This program is distributed under the W3C's Software
142 Intellectual Property License. This program is distributed in the
143 hope that it will be useful, but WITHOUT ANY WARRANTY; without even
144 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
145 PURPOSE.
146 </p>
147 <p>See W3C License <a href="http://www.w3.org/Consortium/Legal/">http://www.w3.org/Consortium/Legal/</a>
148 for more details.</p>
149 <iframe name="doc" src="files/select.html"></iframe>
150 <br>
151 </body>
152 </html>

mercurial