| <!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="rtl">|Lorem <span dir="rtl">ipsum dolor sit</span> amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">|Lorem <span dir="rtl">ipsum dolor sit</span> amet</div>', |
| `${behavior} 2-0 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">L|orem <span dir="rtl">ipsum dolor sit</span> amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">|L^orem <span dir="rtl">ipsum dolor sit</span> amet</div>', |
| `${behavior} 2-1 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lo|rem <span dir="rtl">ipsum dolor sit</span> amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">|Lo^rem <span dir="rtl">ipsum dolor sit</span> amet</div>', |
| `${behavior} 2-2 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lor|em <span dir="rtl">ipsum dolor sit</span> amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">|Lor^em <span dir="rtl">ipsum dolor sit</span> amet</div>', |
| `${behavior} 2-3 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lore|m <span dir="rtl">ipsum dolor sit</span> amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">|Lore^m <span dir="rtl">ipsum dolor sit</span> amet</div>', |
| `${behavior} 2-4 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem| <span dir="rtl">ipsum dolor sit</span> amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">|Lorem^ <span dir="rtl">ipsum dolor sit</span> amet</div>', |
| `${behavior} 2-5 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">|ipsum dolor sit</span> amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">|Lorem ^<span dir="rtl">ipsum dolor sit</span> amet</div>', |
| `${behavior} 2-6 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">i|psum dolor sit</span> amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">|i^psum dolor sit</span> amet</div>', |
| `${behavior} 2-7 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ip|sum dolor sit</span> amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">|ip^sum dolor sit</span> amet</div>', |
| `${behavior} 2-8 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ips|um dolor sit</span> amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">|ips^um dolor sit</span> amet</div>', |
| `${behavior} 2-9 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsu|m dolor sit</span> amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">|ipsu^m dolor sit</span> amet</div>', |
| `${behavior} 2-10 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum| dolor sit</span> amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">|ipsum^ dolor sit</span> amet</div>', |
| `${behavior} 2-11 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum |dolor sit</span> amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">|ipsum ^dolor sit</span> amet</div>', |
| `${behavior} 2-12 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum d|olor sit</span> amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum |d^olor sit</span> amet</div>', |
| `${behavior} 2-13 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum do|lor sit</span> amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum |do^lor sit</span> amet</div>', |
| `${behavior} 2-14 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum dol|or sit</span> amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum |dol^or sit</span> amet</div>', |
| `${behavior} 2-15 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum dolo|r sit</span> amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum |dolo^r sit</span> amet</div>', |
| `${behavior} 2-16 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum dolor| sit</span> amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum |dolor^ sit</span> amet</div>', |
| `${behavior} 2-17 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum dolor |sit</span> amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum |dolor ^sit</span> amet</div>', |
| `${behavior} 2-18 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum dolor s|it</span> amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum dolor |s^it</span> amet</div>', |
| `${behavior} 2-19 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum dolor si|t</span> amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum dolor |si^t</span> amet</div>', |
| `${behavior} 2-20 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum dolor sit</span>| amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum dolor |sit^</span> amet</div>', |
| `${behavior} 2-21 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum dolor sit</span> |amet</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum dolor |sit</span> ^amet</div>', |
| `${behavior} 2-22 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum dolor sit</span> a|met</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum dolor sit</span> |a^met</div>', |
| `${behavior} 2-23 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum dolor sit</span> am|et</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum dolor sit</span> |am^et</div>', |
| `${behavior} 2-24 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum dolor sit</span> ame|t</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum dolor sit</span> |ame^t</div>', |
| `${behavior} 2-25 rtl backward word`); |
| |
| selection_test( |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum dolor sit</span> amet|</div>', |
| selection => selection.modify('extend', 'backward', 'word'), |
| '<div contenteditable dir="rtl">Lorem <span dir="rtl">ipsum dolor sit</span> |amet^</div>', |
| `${behavior} 2-26 rtl backward word`); |
| } |
| </script> |