Source code
Revision control
Copy as Markdown
Other Tools
Test Info:
- This WPT test may be referenced by the following Test IDs:
            
- /selection/move-by-word-with-symbol.html - WPT Dashboard Interop Dashboard
 
 
<!DOCTYPE html>
<meta charset="utf-8">
<title>Include symbols while moving forward/backward by word</title>
<script src=/resources/testharness.js></script>
<script src=/resources/testharnessreport.js></script>
<script src="/resources/testdriver.js"></script>
<script src="/resources/testdriver-vendor.js"></script>
<script src="/resources/testdriver-actions.js"></script>
<script src="../editing/include/editor-test-utils.js"></script>
<div contenteditable id="target">~>>>>>p+++</div>
<textarea id="textareaTarget">$$$$q~~~</textarea>
<input id="inputTarget" value="||||r=====">
<script>
  const selection = getSelection();
  const textNode = document.getElementById("target").childNodes[0];
  const textareaNode = document.getElementById("textareaTarget");
  const inputNode = document.getElementById("inputTarget");
  test(() => {
    selection.collapse(textNode, 6); // Start just before 'p'
    selection.modify("move", "backward", "word");
    assert_equals(selection.focusNode, textNode);
    assert_equals(selection.focusOffset, 0, "Caret should move to the beginning");
  }, "Symbols should be included while moving backward by word");
  test(() => {
    selection.collapse(textNode, 7); // Start just after 'p'
    selection.modify("move", "forward", "word");
    assert_equals(selection.focusNode, textNode);
    assert_equals(selection.focusOffset, 10, "Caret should move to the end");
  }, "Symbols should be included while moving forward by word");
  promise_test(async () => {
    textareaNode.focus();
    textareaNode.setSelectionRange(4, 4); // Start just before 'q'
    const utils = new EditorTestUtils(textareaNode);
    await utils.sendMoveWordLeftKey();
    assert_equals(textareaNode.selectionStart, 0, "Caret should move to the beginning");
  }, "Symbols should be included while moving backward by word in textarea element");
  promise_test(async () => {
    textareaNode.focus();
    textareaNode.setSelectionRange(5, 5); // Start just after 'q'
    const utils = new EditorTestUtils(textareaNode);
    await utils.sendMoveWordRightKey();
    assert_equals(textareaNode.selectionStart, 8, "Caret should move to the end");
  }, "Symbols should be included while moving forward by word in textarea element");
  promise_test(async () => {
    inputNode.focus();
    inputNode.setSelectionRange(4, 4); // Start just before 'r'
    const utils = new EditorTestUtils(inputNode);
    await utils.sendMoveWordLeftKey();
    assert_equals(inputNode.selectionStart, 0, "Caret should move to the beginning");
  }, "Symbols should be included while moving backward by word in input element");
  promise_test(async () => {
    inputNode.focus();
    inputNode.setSelectionRange(5, 5); // Start just after 'r'
    const utils = new EditorTestUtils(inputNode);
    await utils.sendMoveWordRightKey();
    assert_equals(inputNode.selectionStart, 10, "Caret should move to the end");
  }, "Symbols should be included while moving forward by word in input element");
</script>