Missing cursor/caret showing in search field on google.com
[WebKit-https.git] / LayoutTests / editing / selection / anchor-focus3.html
1 <html> 
2 <head>
3 <script>
4 if (window.testRunner)
5      testRunner.dumpEditingCallbacks();
6 </script>
7
8 <script>
9
10 function log(str) {
11     var li = document.createElement("li");
12     li.appendChild(document.createTextNode(str));
13     var console = document.getElementById("console");
14     console.appendChild(li);
15 }
16
17 function runTest() {
18     var elem = document.getElementById("test");
19     var selection = window.getSelection();
20
21     var anchorNode = selection.anchorNode;
22     var anchorOffset = selection.anchorOffset;
23     var focusNode = selection.focusNode;
24     var focusOffset = selection.focusOffset;
25
26     var anchorString = "Anchor (" + anchorNode + ", " + anchorOffset + ")";
27     var anchorCorrect = anchorNode == elem  && anchorOffset == 1 || anchorNode == elem.firstChild && anchorOffset == elem.firstChild.length;
28     if (anchorCorrect)
29         log(anchorString + " is correct.");
30     else
31         throw(anchorString + " is incorrect.");
32
33     var focusString = "Focus (" + focusNode + ", " + focusOffset + ")";
34     var focusCorrect = (focusNode == elem || focusNode == elem.firstChild) && focusOffset == 0;
35     if (focusCorrect)
36         log(focusString + " is correct.");
37     else
38         throw(focusString + " is incorrect.");
39 }
40
41 function manualTest() {
42     try {
43         runTest();
44     } catch(e) {
45         log("Test Failed.  Error was: " + e);
46     }
47 }
48
49 function automaticTest() {
50     try {
51         if (!window.testRunner)
52             throw("This test does not run interactively.  It uses the testRunner's eventSender to do mouse clicks.  To run it manually, from right to left, select 'text' in the box below, then click the 'Run Test' button.");
53             
54         window.testRunner.dumpAsText();
55         
56         var elem = document.getElementById("test");
57     
58         // (x1, y) to (x2, y) should select the element.
59         // selects the text from right to left.
60         x1 = elem.offsetLeft + elem.offsetWidth;
61         x2 = elem.offsetLeft;
62         y = elem.offsetTop + elem.offsetHeight / 2;
63         
64         eventSender.mouseMoveTo(x1, y);
65         eventSender.mouseDown();
66         eventSender.mouseMoveTo(x1, y);
67         eventSender.mouseMoveTo(x2, y);
68         eventSender.mouseUp();
69         
70         runTest();
71         
72     } catch(e) {
73         log("Test Failed.  Error was: " + e);
74     }
75 }
76
77 </script>
78 </head>
79 <body>
80 <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>
81 <input type="button" onclick="manualTest();" value="Run Test">
82 <div style="border: 1px solid blue;" id="test">text</div>
83 <ul id="console"></ul>
84 <script>automaticTest();</script>
85 </body>
86 </html>