blob: 5ff92ec5df18d22f6a3fcb164ffb19ee8f636fa7 [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">|\n Just\n <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
behavior === 'mac'
? '<div contenteditable dir="ltr">\n ^Just|\n <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>'
: '<div contenteditable dir="ltr">\n ^Just\n| <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
`${behavior} 14-0 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n| Just\n <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
behavior === 'mac'
? '<div contenteditable dir="ltr">\n ^Just|\n <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>'
: '<div contenteditable dir="ltr">\n ^Just\n| <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
`${behavior} 14-1 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n |Just\n <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
behavior === 'mac'
? '<div contenteditable dir="ltr">\n ^Just|\n <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>'
: '<div contenteditable dir="ltr">\n ^Just\n| <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
`${behavior} 14-2 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n J|ust\n <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
behavior === 'mac'
? '<div contenteditable dir="ltr">\n J^ust|\n <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>'
: '<div contenteditable dir="ltr">\n J^ust\n| <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
`${behavior} 14-3 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Ju|st\n <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
behavior === 'mac'
? '<div contenteditable dir="ltr">\n Ju^st|\n <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>'
: '<div contenteditable dir="ltr">\n Ju^st\n| <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
`${behavior} 14-4 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Jus|t\n <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
behavior === 'mac'
? '<div contenteditable dir="ltr">\n Jus^t|\n <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>'
: '<div contenteditable dir="ltr">\n Jus^t\n| <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
`${behavior} 14-5 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Just|\n <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
behavior === 'mac'
? '<div contenteditable dir="ltr">\n Just^\n <span>testing| \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>'
: '<div contenteditable dir="ltr">\n Just^\n| <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
`${behavior} 14-6 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Just\n| <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
behavior === 'mac'
? '<div contenteditable dir="ltr">\n Just\n <span>^testing| \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>'
: '<div contenteditable dir="ltr">\n Just\n <span>^testing |\u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
`${behavior} 14-7 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Just\n <span>|testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
behavior === 'mac'
? '<div contenteditable dir="ltr">\n Just\n <span>^testing| \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>'
: '<div contenteditable dir="ltr">\n Just\n <span>^testing |\u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
`${behavior} 14-8 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Just\n <span>t|esting \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
behavior === 'mac'
? '<div contenteditable dir="ltr">\n Just\n <span>t^esting| \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>'
: '<div contenteditable dir="ltr">\n Just\n <span>t^esting |\u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
`${behavior} 14-9 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Just\n <span>te|sting \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
behavior === 'mac'
? '<div contenteditable dir="ltr">\n Just\n <span>te^sting| \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>'
: '<div contenteditable dir="ltr">\n Just\n <span>te^sting |\u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
`${behavior} 14-10 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Just\n <span>tes|ting \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
behavior === 'mac'
? '<div contenteditable dir="ltr">\n Just\n <span>tes^ting| \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>'
: '<div contenteditable dir="ltr">\n Just\n <span>tes^ting |\u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
`${behavior} 14-11 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Just\n <span>test|ing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
behavior === 'mac'
? '<div contenteditable dir="ltr">\n Just\n <span>test^ing| \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>'
: '<div contenteditable dir="ltr">\n Just\n <span>test^ing |\u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
`${behavior} 14-12 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Just\n <span>testi|ng \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
behavior === 'mac'
? '<div contenteditable dir="ltr">\n Just\n <span>testi^ng| \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>'
: '<div contenteditable dir="ltr">\n Just\n <span>testi^ng |\u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
`${behavior} 14-13 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Just\n <span>testin|g \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
behavior === 'mac'
? '<div contenteditable dir="ltr">\n Just\n <span>testin^g| \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>'
: '<div contenteditable dir="ltr">\n Just\n <span>testin^g |\u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
`${behavior} 14-14 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Just\n <span>testing| \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
behavior === 'mac'
? '<div contenteditable dir="ltr">\n Just\n <span>testing^ \u05E8\u05E7|</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>'
: '<div contenteditable dir="ltr">\n Just\n <span>testing^ |\u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
`${behavior} 14-15 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Just\n <span>testing |\u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
behavior === 'mac'
? '<div contenteditable dir="ltr">\n Just\n <span>testing ^\u05E8\u05E7|</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>'
: '<div contenteditable dir="ltr">\n Just\n <span>testing ^\u05E8\u05E7</span>\n| \u05D1\u05D5\u05D3\u05E7\n</div>',
`${behavior} 14-16 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Just\n <span>testing \u05E8|\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
behavior === 'mac'
? '<div contenteditable dir="ltr">\n Just\n <span>testing \u05E8^\u05E7|</span>\n \u05D1\u05D5\u05D3\u05E7\n</div>'
: '<div contenteditable dir="ltr">\n Just\n <span>testing \u05E8^\u05E7</span>\n| \u05D1\u05D5\u05D3\u05E7\n</div>',
`${behavior} 14-17 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Just\n <span>testing \u05E8\u05E7</span>|\n \u05D1\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
behavior === 'mac'
? '<div contenteditable dir="ltr">\n Just\n <span>testing \u05E8\u05E7</span>^\n \u05D1\u05D5\u05D3\u05E7|\n</div>'
: '<div contenteditable dir="ltr">\n Just\n <span>testing \u05E8\u05E7</span>^\n| \u05D1\u05D5\u05D3\u05E7\n</div>',
`${behavior} 14-18 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Just\n <span>testing \u05E8\u05E7</span>\n| \u05D1\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
'<div contenteditable dir="ltr">\n Just\n <span>testing \u05E8\u05E7</span>\n ^\u05D1\u05D5\u05D3\u05E7|\n</div>',
`${behavior} 14-19 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Just\n <span>testing \u05E8\u05E7</span>\n |\u05D1\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
'<div contenteditable dir="ltr">\n Just\n <span>testing \u05E8\u05E7</span>\n ^\u05D1\u05D5\u05D3\u05E7|\n</div>',
`${behavior} 14-20 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Just\n <span>testing \u05E8\u05E7</span>\n \u05D1|\u05D5\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
'<div contenteditable dir="ltr">\n Just\n <span>testing \u05E8\u05E7</span>\n \u05D1^\u05D5\u05D3\u05E7|\n</div>',
`${behavior} 14-21 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Just\n <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5|\u05D3\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
'<div contenteditable dir="ltr">\n Just\n <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5^\u05D3\u05E7|\n</div>',
`${behavior} 14-22 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Just\n <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3|\u05E7\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
'<div contenteditable dir="ltr">\n Just\n <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3^\u05E7|\n</div>',
`${behavior} 14-23 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Just\n <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7|\n</div>',
selection => selection.modify('extend', 'forward', 'word'),
'<div contenteditable dir="ltr">\n Just\n <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7|\n</div>',
`${behavior} 14-24 ltr forward word`);
selection_test(
'<div contenteditable dir="ltr">\n Just\n <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7\n|</div>',
selection => selection.modify('extend', 'forward', 'word'),
'<div contenteditable dir="ltr">\n Just\n <span>testing \u05E8\u05E7</span>\n \u05D1\u05D5\u05D3\u05E7|\n</div>',
`${behavior} 14-25 ltr forward word`);
}
</script>