5 testRunner
.dumpEditingCallbacks();
13 var li
= document
.createElement("li");
14 li
.appendChild(document
.createTextNode(str
));
15 var console
= document
.getElementById("console");
16 console
.appendChild(li
);
20 var elem
= document
.getElementById("test");
21 var selection
= window
.getSelection();
23 var anchorNode
= selection
.anchorNode
;
24 var anchorOffset
= selection
.anchorOffset
;
25 var focusNode
= selection
.focusNode
;
26 var focusOffset
= selection
.focusOffset
;
28 var anchorString
= "Anchor (" + anchorNode
+ ", " + anchorOffset
+ ")";
29 var anchorCorrect
= (anchorNode
== elem
|| anchorNode
== elem
.firstChild
) && anchorOffset
== 0;
31 log(anchorString
+ " is correct.");
33 throw(anchorString
+ " is incorrect.");
35 var focusString
= "Focus (" + focusNode
+ ", " + focusOffset
+ ")";
36 var focusCorrect
= (focusNode
== elem
&& focusOffset
== 1 || focusNode
== elem
.firstChild
&& focusOffset
== elem
.firstChild
.length
);
38 log(focusString
+ " is correct.");
40 throw(focusString
+ " is incorrect.");
43 function manualTest() {
47 log("Test Failed. Error was: " + e
);
51 function automaticTest() {
53 if (!window
.testRunner
)
54 throw("This test uses the testRunner's eventSender to do mouse clicks. To run it manually, from left to right, select 'text' in the box below, then click the 'Run Test' button.");
56 window
.testRunner
.dumpAsText();
58 var elem
= document
.getElementById("test");
60 // (x1, y) to (x2, y) should select the element.
61 // selects the text from left to right.
63 x2
= elem
.offsetLeft
+ elem
.offsetWidth
;
64 y
= elem
.offsetTop
+ elem
.offsetHeight
/ 2;
66 eventSender
.mouseMoveTo(x1
, y
);
67 eventSender
.mouseDown();
68 eventSender
.mouseMoveTo(x1
, y
);
69 eventSender
.mouseMoveTo(x2
, y
);
70 eventSender
.mouseUp();
74 log("Test Failed. Error was: " + e
);
81 <p>This tests the anchorNode, anchorOffset, focusNode and focusOffset properties of the Selection object. These properties are part of Mozilla's Selection object API, and so their values should be consistent in both browsers.
</p>
82 <input type=
"button" onclick=
"manualTest();" value=
"Run Test">
83 <div style=
"border: 1px solid blue;" id=
"test">text
</div>
84 <ul id=
"console"></ul>
85 <script>automaticTest();</script>