File: anchor-removal.html

package info (click to toggle)
firefox 147.0.3-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,683,320 kB
  • sloc: cpp: 7,607,359; javascript: 6,533,295; ansic: 3,775,223; python: 1,415,500; xml: 634,561; asm: 438,949; java: 186,241; sh: 62,752; makefile: 18,079; objc: 13,092; perl: 12,808; yacc: 4,583; cs: 3,846; pascal: 3,448; lex: 1,720; ruby: 1,003; php: 436; lisp: 258; awk: 247; sql: 66; sed: 54; csh: 10; exp: 6
file content (60 lines) | stat: -rw-r--r-- 2,037 bytes parent folder | download | duplicates (13)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
<!DOCTYPE html>
<html>
<head>
<script src='/resources/testharness.js'></script>
<script src='/resources/testharnessreport.js'></script>
<script src="/resources/testdriver.js"></script>
<script src="/resources/testdriver-actions.js"></script>
<script src="/resources/testdriver-vendor.js"></script>
</head>

<body>
</body>

<script>
async function select_range(t, anchorNode, focusNode) {
  await new test_driver.Actions()
      .pointerMove(0, 0, {origin: anchorNode})
      .pointerDown()
      .pointerMove(focusNode.clientWidth, focusNode.clientHeight, {origin: focusNode})
      .pointerUp()
      .send();
}

const kHTML = `
  <div id=parentDiv>
    <span id=parentParagraph>Parent paragraph</span>
    <div id=childDiv>
      <span id=childParagraph1>Child paragraph one</span>
      <span id=childParagraph2>Paragraph two</span>
    </div>
  </div>
`;

// The two tests below are semantically identical, however after the selection
// is made but before `remove()`:
//  - The first test does nothing
//  - The second test runs asserts on `getSelection()` (before `remove()` is
//    run).
//
// The existence of the `getSelection()` asserts before `remove()` appears to
// have a side-effect in Chromium browsers. See https://crbug.com/379275917.
promise_test(async t => {
  document.body.innerHTML = kHTML;
  getSelection().removeAllRanges();
  await select_range(t, parentParagraph, childParagraph1);

  parentParagraph.remove();
  assert_equals(getSelection().anchorNode, parentDiv, "anchorNode snaps up to parent");
}, "anchorNode snaps up to parent when removed (no asserts)");

promise_test(async t => {
  document.body.innerHTML = kHTML;
  getSelection().removeAllRanges();
  await select_range(t, parentParagraph, childParagraph1);

  assert_equals(getSelection().anchorNode, parentParagraph.firstChild, "anchorNode before move");
  parentParagraph.remove();
  assert_equals(getSelection().anchorNode, parentDiv, "anchorNode snaps up to parent");
}, "anchorNode snaps up to parent when removed (with asserts)");
</script>