Merge Chromium + Blink git repositories
[chromium-blink-merge.git] / third_party / WebKit / LayoutTests / editing / selection / collapse-selection-in-bidi.html
blob325f529edf016827e630686718fc87794802ee76
1 <!DOCTYPE html>
2 <html>
3 <head>
4 <script src="../../resources/js-test.js"></script>
5 <script src="resources/js-test-selection-shared.js"></script>
6 </head>
7 <body>
8 <p>This tests collapsing directionless selection on text in a block with the opposite text direction.
9 To manually test, on Mac, select text below by mouse and use arrow keys (without pressing shift) to collapse the selection.
10 The selection should collapse to the left if you pressed the left arrow key and to the right if you pressed the right arrow key.</p>
11 <div id="tests" contenteditable><span dir="ltr">&#x05d0;&#x05d1;&#x05d2;&#x05d3;&#x05d4;</span
12 ><span dir="rtl">hello</span></div>
13 <pre id="console"></pre>
14 <script>
16 if (window.internals) {
17 internals.settings.setEditingBehavior('mac');
19 function selectTarget(target) {
20 eventSender.mouseMoveTo(target.offsetLeft + target.offsetWidth * 2 / 5, target.offsetTop + 5);
21 eventSender.mouseDown();
22 eventSender.leapForward(200);
23 eventSender.mouseMoveTo(target.offsetLeft + target.offsetWidth * 4 / 5, target.offsetTop + 5);
24 eventSender.leapForward(200);
25 eventSender.mouseUp();
28 var selection = window.getSelection();
29 var tests = document.getElementById('tests').getElementsByTagName('span');
30 for (var i = 0; i < tests.length; i++) {
31 var isLTR = tests[i].dir == 'ltr';
33 selectTarget(tests[i]);
34 var expectedOffset = isLTR ? window.getSelection().getRangeAt(0).endOffset : window.getSelection().getRangeAt(0).startOffset;
35 window.getSelection().modify('move', 'left', 'character');
36 assertSelectionAt(tests[i].firstChild, expectedOffset);
38 selectTarget(tests[i]);
39 expectedOffset = isLTR ? window.getSelection().getRangeAt(0).startOffset : window.getSelection().getRangeAt(0).endOffset;
40 window.getSelection().modify('move', 'right', 'character');
41 assertSelectionAt(tests[i].firstChild, expectedOffset);
44 document.getElementById('tests').style.display = 'none';
48 </script>
49 </body>
50 </html>