2007-03-22 10:30:00 -07:00
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN""http://www.w3.org/TR/html4/strict.dtd">
< html >
< head >
< META http-equiv = "Content-Type" content = "text/html; charset=UTF-8" >
< meta http-equiv = "Content-Type" content = "text/html; charset=UTF-8" >
< title > http://www.w3.org/2001/DOM-Test-Suite/level2/core/elementsetattributenodens02< / title >
< link rel = "stylesheet" type = "text/css" href = "/tests/SimpleTest/test.css" >
2011-08-12 09:21:42 -07:00
< script type = "text/javascript" src = "/tests/SimpleTest/SimpleTest.js" > < / script >
< script type = "text/javascript" src = "DOMTestCase.js" > < / script >
< script type = "text/javascript" src = "exclusions.js" > < / script >
< script type = "text/javascript" >
2007-03-22 10:30:00 -07:00
// expose test function names
function exposeTestFunctionNames()
{
return ['elementsetattributenodens02'];
}
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();
setImplementationAttribute("namespaceAware", true);
docsLoaded = 0;
var docRef = null;
if (typeof(this.doc) != 'undefined') {
docRef = this.doc;
}
docsLoaded += preload(docRef, "doc", "staffNS");
if (docsLoaded == 1) {
setUpPage = 'complete';
}
} catch(ex) {
catchInitializationError(builder, ex);
setUpPage = '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';
runJSUnitTests();
markTodos();
SimpleTest.finish();
}
}
var docName = 'elementsetattributenodens02';
/**
*
Test the setAttributeNodeNS method.
Retreive the street attribute from the second address element node.
Clone it and add it to the first address node. The INUSE_ATTRIBUTE_ERR exception
should not be thrown. Check the name and value of the newly added node.
* @author IBM
* @author Neil Delima
* @see http://www.w3.org/TR/DOM-Level-2-Core/core#ID-ElSetAtNodeNS
* @see http://www.w3.org/Bugs/Public/show_bug.cgi?id=259
*/
function elementsetattributenodens02() {
var success;
if(checkInitialization(builder, "elementsetattributenodens02") != null) return;
var doc;
var element;
var element2;
var attribute;
var attributeCloned;
var newAttr;
var elementList;
var attrName;
var attrValue;
var nullNS = null;
var docRef = null;
if (typeof(this.doc) != 'undefined') {
docRef = this.doc;
}
doc = load(docRef, "doc", "staffNS");
elementList = doc.getElementsByTagNameNS("http://www.nist.gov","address");
element = elementList.item(1);
attribute = element.getAttributeNodeNS(nullNS,"street");
attributeCloned = attribute.cloneNode(true);
element2 = elementList.item(2);
newAttr = element2.setAttributeNodeNS(attributeCloned);
attrName = newAttr.nodeName;
attrValue = newAttr.nodeValue;
assertEquals("elementsetattributenodens02_attrName","street",attrName);
assertEquals("elementsetattributenodens02_attrValue","Yes",attrValue);
}
< / script >
< / head >
< body >
< h2 > Test http://www.w3.org/2001/DOM-Test-Suite/level2/core/elementsetattributenodens02< / h2 >
< p > < / p >
< p >
Copyright (c) 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 < a href = "http://www.w3.org/Consortium/Legal/2002/copyright-software-20021231" > W3C(r) Software License< / a > 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.
< / p >
< / body >
< / html >