| <!doctype html> |
| <script src="../../../resources/testharness.js"></script> |
| <script src="../../../resources/testharnessreport.js"></script> |
| <script src="../../assert_selection.js"></script> |
| <script> |
| const isMac = navigator.platform.indexOf('Mac') === 0; |
| const kBehaviors = window.internals ? ['mac', 'win'] : isMac ? ['mac'] : ['win']; |
| for (const behavior of kBehaviors) { |
| if (window.internals) { |
| internals.settings.setEditingBehavior(behavior); |
| internals.settings.setSelectTrailingWhitespaceEnabled(behavior !== 'mac'); |
| } |
| |
| selection_test( |
| '<div contenteditable dir="ltr">|Lorem <span style="direction: ltr">ipsum dolor<div > just a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">|Lorem <span style="direction: ltr">ipsum dolor<div> just a test</div> sit</span> amet</div>', |
| `${behavior} 7-0 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">L|orem <span style="direction: ltr">ipsum dolor<div > just a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">|L^orem <span style="direction: ltr">ipsum dolor<div> just a test</div> sit</span> amet</div>', |
| `${behavior} 7-1 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lo|rem <span style="direction: ltr">ipsum dolor<div > just a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">|Lo^rem <span style="direction: ltr">ipsum dolor<div> just a test</div> sit</span> amet</div>', |
| `${behavior} 7-2 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lor|em <span style="direction: ltr">ipsum dolor<div > just a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">|Lor^em <span style="direction: ltr">ipsum dolor<div> just a test</div> sit</span> amet</div>', |
| `${behavior} 7-3 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lore|m <span style="direction: ltr">ipsum dolor<div > just a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">|Lore^m <span style="direction: ltr">ipsum dolor<div> just a test</div> sit</span> amet</div>', |
| `${behavior} 7-4 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem| <span style="direction: ltr">ipsum dolor<div > just a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">|Lorem^ <span style="direction: ltr">ipsum dolor<div> just a test</div> sit</span> amet</div>', |
| `${behavior} 7-5 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">|ipsum dolor<div > just a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">|Lorem ^<span style="direction: ltr">ipsum dolor<div> just a test</div> sit</span> amet</div>', |
| `${behavior} 7-6 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">i|psum dolor<div > just a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">|i^psum dolor<div> just a test</div> sit</span> amet</div>', |
| `${behavior} 7-7 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ip|sum dolor<div > just a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">|ip^sum dolor<div> just a test</div> sit</span> amet</div>', |
| `${behavior} 7-8 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ips|um dolor<div > just a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">|ips^um dolor<div> just a test</div> sit</span> amet</div>', |
| `${behavior} 7-9 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsu|m dolor<div > just a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">|ipsu^m dolor<div> just a test</div> sit</span> amet</div>', |
| `${behavior} 7-10 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum| dolor<div > just a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">|ipsum^ dolor<div> just a test</div> sit</span> amet</div>', |
| `${behavior} 7-11 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum |dolor<div > just a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">|ipsum ^dolor<div> just a test</div> sit</span> amet</div>', |
| `${behavior} 7-12 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum d|olor<div > just a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum |d^olor<div> just a test</div> sit</span> amet</div>', |
| `${behavior} 7-13 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum do|lor<div > just a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum |do^lor<div> just a test</div> sit</span> amet</div>', |
| `${behavior} 7-14 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dol|or<div > just a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum |dol^or<div> just a test</div> sit</span> amet</div>', |
| `${behavior} 7-15 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolo|r<div > just a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum |dolo^r<div> just a test</div> sit</span> amet</div>', |
| `${behavior} 7-16 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div >| just a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor|<div>^ just a test</div> sit</span> amet</div>', |
| `${behavior} 7-17 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div > |just a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor|<div>^ just a test</div> sit</span> amet</div>', |
| `${behavior} 7-18 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div > j|ust a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div> |j^ust a test</div> sit</span> amet</div>', |
| `${behavior} 7-19 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div > ju|st a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div> |ju^st a test</div> sit</span> amet</div>', |
| `${behavior} 7-20 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div > jus|t a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div> |jus^t a test</div> sit</span> amet</div>', |
| `${behavior} 7-21 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div > just| a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div> |just^ a test</div> sit</span> amet</div>', |
| `${behavior} 7-22 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div > just |a test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div> |just ^a test</div> sit</span> amet</div>', |
| `${behavior} 7-23 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div > just a| test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div> just |a^ test</div> sit</span> amet</div>', |
| `${behavior} 7-24 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div > just a |test</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div> just |a ^test</div> sit</span> amet</div>', |
| `${behavior} 7-25 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div > just a t|est</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div> just a |t^est</div> sit</span> amet</div>', |
| `${behavior} 7-26 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div > just a te|st</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div> just a |te^st</div> sit</span> amet</div>', |
| `${behavior} 7-27 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div > just a tes|t</div> sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div> just a |tes^t</div> sit</span> amet</div>', |
| `${behavior} 7-28 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div > just a test</div>| sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div> just a test|</div>^ sit</span> amet</div>', |
| `${behavior} 7-29 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div > just a test</div> |sit</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div> just a test|</div>^ sit</span> amet</div>', |
| `${behavior} 7-30 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div > just a test</div> s|it</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div> just a test</div> |s^it</span> amet</div>', |
| `${behavior} 7-31 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div > just a test</div> si|t</span> amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div> just a test</div> |si^t</span> amet</div>', |
| `${behavior} 7-32 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div > just a test</div> sit</span>| amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div> just a test</div> |sit^</span> amet</div>', |
| `${behavior} 7-33 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div > just a test</div> sit</span> |amet</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div> just a test</div> |sit</span> ^amet</div>', |
| `${behavior} 7-34 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div > just a test</div> sit</span> a|met</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div> just a test</div> sit</span> |a^met</div>', |
| `${behavior} 7-35 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div > just a test</div> sit</span> am|et</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div> just a test</div> sit</span> |am^et</div>', |
| `${behavior} 7-36 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div > just a test</div> sit</span> ame|t</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div> just a test</div> sit</span> |ame^t</div>', |
| `${behavior} 7-37 ltr left word`); |
| |
| selection_test( |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div > just a test</div> sit</span> amet|</div>', |
| selection => selection.modify('extend', 'left', 'word'), |
| '<div contenteditable dir="ltr">Lorem <span style="direction: ltr">ipsum dolor<div> just a test</div> sit</span> |amet^</div>', |
| `${behavior} 7-38 ltr left word`); |
| } |
| </script> |