blob: 2777e2fb25d234a4db736662cd83efa89817549f [file] [log] [blame]
<script>
function doLog(msg)
{
var d = document.createElement("div");
d.innerHTML = msg;
document.body.appendChild(d);
}
function report(msg, res)
{
if (res)
msg = "<font color=green>PASS:</font>" + msg;
else
msg = "<font color=red>FAIL:</font>" + msg;
doLog(msg);
}
/*
Tree:
a
b
c
d
e
f
g
h
b, c are rejected,
d is skipped.
g is rejected
*/
function kid(parent) {
var newKid = document.createElement("div");
parent.appendChild(newKid);
return newKid;
}
function test() {
if (window.layoutTestController)
layoutTestController.dumpAsText();
var wrapper = document.createElement("div"); // just to have one more level up.
var a = kid(wrapper);
var b = kid(a);
var c = kid(b);
var d = kid(a);
var e = kid(d);
var f = kid(a);
var g = kid(a);
var h = kid(g);
a.setAttribute("id", "a");
b.setAttribute("id", "b");
c.setAttribute("id", "c");
d.setAttribute("id", "d");
e.setAttribute("id", "e");
f.setAttribute("id", "f");
g.setAttribute("id", "g");
h.setAttribute("id", "h");
function filter(node) {
if (node == b || node == c || node == g)
return NodeFilter.FILTER_REJECT;
if (node == d)
return NodeFilter.FILTER_SKIP;
return NodeFilter.FILTER_ACCEPT;
}
var tw = document.createTreeWalker(a, NodeFilter.SHOW_ALL, filter, true);
report("Proper a.firstChild()", tw.firstChild() == e);
tw.currentNode = b;
report("Proper b.firstChild()", tw.firstChild() == null);
// shouldn't move.
report("Shouldn't move", tw.currentNode == b);
tw.currentNode = b;
report("Proper b.nextSibling()", tw.nextSibling() == e);
// This is because we should treat 'b' as skipped when we are under it.
tw.currentNode = c;
report("Proper c.nextSibling()", tw.nextSibling() == e);
tw.currentNode = e;
report("Proper e.nextSibling()", tw.nextSibling() == f);
tw.currentNode = f;
report("Proper f.previousSibling()", tw.previousSibling() == e);
tw.currentNode = e;
report("Proper e.previousSibling()", tw.previousSibling() == null);
report("Shouldn't move", tw.currentNode == e);
tw.currentNode = h;
report("Proper h.previousSibling()", tw.previousSibling() == f);
tw.currentNode = g;
report("Proper g.previousSibling()", tw.previousSibling() == f);
// f is g's previous sibling, but not the other way around :-)
tw.currentNode = f;
report("Proper f.nextSibling()", tw.nextSibling() == null);
report("Proper f.parentNode()", tw.parentNode() == a);
report("Proper a.parentNode()", tw.parentNode() == null);
// Test exit/capture.
tw.currentNode = a.parentNode;
report("Proper a's parent.nextNode()", tw.nextNode() == a);
// Should get caught..
report("Re-capture #1", tw.previousNode() == null);
report("Re-capture #2", tw.parentNode() == null);
report("nextNode from a", tw.nextNode() == e);
report("prevNode to a", tw.previousNode() == a);
doLog("All done!");
}
</script>
<body onload="test()">