/*
Copyright © 2001-2004 World Wide Web Consortium,
(Massachusetts Institute of Technology, European Research Consortium
for Informatics and Mathematics, Keio University). All
Rights Reserved. This work is distributed under the W3C® Software License [1] in the
hope that it will be useful, but WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
[1] http://www.w3.org/Consortium/Legal/2002/copyright-software-20021231
*/
/**
* Gets URI that identifies the test.
* @return uri identifier of test
*/
function getTargetURI() {
return "http://www.w3.org/2001/DOM-Test-Suite/level2/html/HTMLOptionsCollection04";
}
var docsLoaded = -1000000;
var builder = null;
//
// This function is called by the testing framework before
// running the test suite.
//
// If there are no configuration exceptions, asynchronous
// document loading is started. Otherwise, the status
// is set to complete and the exception is immediately
// raised when entering the body of the test.
//
function setUpPage() {
setUpPageStatus = 'running';
try {
//
// creates test document builder, may throw exception
//
builder = createConfiguredBuilder();
docsLoaded = 0;
var docRef = null;
if (typeof(this.doc) != 'undefined') {
docRef = this.doc;
}
docsLoaded += preload(docRef, "doc", "optionscollection");
if (docsLoaded == 1) {
setUpPageStatus = 'complete';
}
} catch(ex) {
catchInitializationError(builder, ex);
setUpPageStatus = 'complete';
}
}
//
// This method is called on the completion of
// each asychronous load started in setUpTests.
//
// When every synchronous loaded document has completed,
// the page status is changed which allows the
// body of the test to be executed.
function loadComplete() {
if (++docsLoaded == 1) {
setUpPageStatus = 'complete';
}
}
/**
*
An HTMLOptionsCollection is a list of nodes representing HTML option
element.
An individual node may be accessed by either ordinal index, the node's
name or id attributes. (Test node name).
The namedItem method retrieves a Node using a name. It first searches
for a node with a matching id attribute. If it doesn't find one, it
then searches for a Node with a matching name attribute, but only
those elements that are allowed a name attribute.
Retrieve the first FORM element. Create a HTMLCollection of the elements.
Search for an element that has selectId as the value for the id attribute.
Get the nodeName of that element.
* @author NIST
* @author Rick Rivello
* @see http://www.w3.org/TR/DOM-Level-2-HTML/html#HTMLOptionsCollection-namedItem
*/
function HTMLOptionsCollection04() {
var success;
if(checkInitialization(builder, "HTMLOptionsCollection04") != null) return;
var nodeList;
var testNode;
var optionsNode;
var formsnodeList;
var vname;
var doc;
var docRef = null;
if (typeof(this.doc) != 'undefined') {
docRef = this.doc;
}
doc = load(docRef, "doc", "optionscollection");
nodeList = doc.getElementsByTagName("form");
assertSize("Asize",1,nodeList);
testNode = nodeList.item(0);
formsnodeList = testNode.elements;
optionsNode = formsnodeList.namedItem("selectId");
vname = optionsNode.nodeName;
assertEqualsAutoCase("element", "nameIndexLink","select",vname);
}
function runTest() {
HTMLOptionsCollection04();
}