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