|  | <!doctype html> | 
|  | <title>Range.isPointInRange() tests</title> | 
|  | <link rel="author" title="Aryeh Gregor" href=ayg@aryeh.name> | 
|  | <meta name=timeout content=long> | 
|  | <div id=log></div> | 
|  | <script src=/resources/testharness.js></script> | 
|  | <script src=/resources/testharnessreport.js></script> | 
|  | <script src=../common.js></script> | 
|  | <script> | 
|  | "use strict"; | 
|  |  | 
|  | var testRangesCached = []; | 
|  | test(function() { | 
|  | for (var j = 0; j < testRanges.length; j++) { | 
|  | test(function() { | 
|  | testRangesCached[j] = rangeFromEndpoints(eval(testRanges[j])); | 
|  | }, "Set up for range " + j + " " + testRanges[j]); | 
|  | } | 
|  | var detachedRange = document.createRange(); | 
|  | detachedRange.detach(); | 
|  | testRanges.push("detached"); | 
|  | testRangesCached.push(detachedRange); | 
|  | }, "Setup"); | 
|  |  | 
|  | for (var i = 0; i < testPoints.length; i++) { | 
|  | var node = eval(testPoints[i])[0]; | 
|  | var offset = eval(testPoints[i])[1]; | 
|  |  | 
|  | // isPointInRange is an unsigned long, so per WebIDL, we need to treat it | 
|  | // as though it wrapped to an unsigned 32-bit integer. | 
|  | var normalizedOffset = offset % Math.pow(2, 32); | 
|  | if (normalizedOffset < 0) { | 
|  | normalizedOffset += Math.pow(2, 32); | 
|  | } | 
|  |  | 
|  | for (var j = 0; j < testRanges.length; j++) { | 
|  | test(function() { | 
|  | var range = testRangesCached[j].cloneRange(); | 
|  |  | 
|  | // "If node's root is different from the context object's root, | 
|  | // return false and terminate these steps." | 
|  | if (furthestAncestor(node) !== furthestAncestor(range.startContainer)) { | 
|  | assert_false(range.isPointInRange(node, offset), | 
|  | "Must return false if node has a different root from the context object"); | 
|  | return; | 
|  | } | 
|  |  | 
|  | // "If node is a doctype, throw an "InvalidNodeTypeError" exception | 
|  | // and terminate these steps." | 
|  | if (node.nodeType == Node.DOCUMENT_TYPE_NODE) { | 
|  | assert_throws("INVALID_NODE_TYPE_ERR", function() { | 
|  | range.isPointInRange(node, offset); | 
|  | }, "Must throw InvalidNodeTypeError if node is a doctype"); | 
|  | return; | 
|  | } | 
|  |  | 
|  | // "If offset is greater than node's length, throw an | 
|  | // "IndexSizeError" exception and terminate these steps." | 
|  | if (normalizedOffset > nodeLength(node)) { | 
|  | assert_throws("INDEX_SIZE_ERR", function() { | 
|  | range.isPointInRange(node, offset); | 
|  | }, "Must throw IndexSizeError if offset is greater than  length"); | 
|  | return; | 
|  | } | 
|  |  | 
|  | // "If (node, offset) is before start or after end, return false | 
|  | // and terminate these steps." | 
|  | if (getPosition(node, normalizedOffset, range.startContainer, range.startOffset) === "before" | 
|  | || getPosition(node, normalizedOffset, range.endContainer, range.endOffset) === "after") { | 
|  | assert_false(range.isPointInRange(node, offset), | 
|  | "Must return false if point is before start or after end"); | 
|  | return; | 
|  | } | 
|  |  | 
|  | // "Return true." | 
|  | assert_true(range.isPointInRange(node, offset), | 
|  | "Must return true if point is not before start, after end, or in different tree"); | 
|  | }, "Point " + i + " " + testPoints[i] + ", range " + j + " " + testRanges[j]); | 
|  | } | 
|  | } | 
|  |  | 
|  | testDiv.style.display = "none"; | 
|  | </script> |