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