Source code

Revision control

Copy as Markdown

Other Tools

Test Info:

<!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">
<link href="activity-home.css" rel="stylesheet" type="text/css">
<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css">
<script 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">
// expose test function names
function exposeTestFunctionNames()
{
return ['nodeinsertbefore'];
}
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", "staff");
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 = 'nodeinsertbefore';
window.doc = window;
SimpleTest.waitForExplicitFinish();
addLoadEvent(setUpPage);
/**
*
The "insertBefore(newChild,refChild)" method inserts the
node "newChild" before the node "refChild".
Insert a newly created Element node before the eigth
child of the second employee and check the "newChild"
and "refChild" after insertion for correct placement.
* @author NIST
* @author Mary Brady
*/
function nodeinsertbefore() {
var success;
if(checkInitialization(builder, "nodeinsertbefore") != null) return;
var doc;
var elementList;
var employeeNode;
var childList;
var refChild;
var newChild;
var child;
var childName;
var length;
var insertedNode;
var actual = new Array();
expectedWithWhitespace = new Array();
expectedWithWhitespace[0] = "#text";
expectedWithWhitespace[1] = "employeeId";
expectedWithWhitespace[2] = "#text";
expectedWithWhitespace[3] = "name";
expectedWithWhitespace[4] = "#text";
expectedWithWhitespace[5] = "position";
expectedWithWhitespace[6] = "#text";
expectedWithWhitespace[7] = "newChild";
expectedWithWhitespace[8] = "salary";
expectedWithWhitespace[9] = "#text";
expectedWithWhitespace[10] = "gender";
expectedWithWhitespace[11] = "#text";
expectedWithWhitespace[12] = "address";
expectedWithWhitespace[13] = "#text";
expectedWithoutWhitespace = new Array();
expectedWithoutWhitespace[0] = "employeeId";
expectedWithoutWhitespace[1] = "name";
expectedWithoutWhitespace[2] = "position";
expectedWithoutWhitespace[3] = "newChild";
expectedWithoutWhitespace[4] = "salary";
expectedWithoutWhitespace[5] = "gender";
expectedWithoutWhitespace[6] = "address";
var expected = new Array();
var docRef = null;
if (typeof(this.doc) != 'undefined') {
docRef = this.doc;
}
doc = load(docRef, "doc", "staff");
elementList = doc.getElementsByTagName("employee");
employeeNode = elementList.item(1);
childList = employeeNode.childNodes;
length = childList.length;
if(
(6 == length)
) {
refChild = childList.item(3);
expected = expectedWithoutWhitespace;
}
else {
refChild = childList.item(7);
expected = expectedWithWhitespace;
}
newChild = doc.createElement("newChild");
insertedNode = employeeNode.insertBefore(newChild,refChild);
for(var indexN65756 = 0;indexN65756 < childList.length; indexN65756++) {
child = childList.item(indexN65756);
childName = child.nodeName;
actual[actual.length] = childName;
}
assertEqualsList("nodeNames",expected,actual);
}
</script>
</head>
<body>
<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>