File: test_synthmousemove_after_dnd.html

package info (click to toggle)
firefox 141.0.3-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,550,588 kB
  • sloc: cpp: 7,426,506; javascript: 6,367,238; ansic: 3,707,351; python: 1,369,002; xml: 623,983; asm: 426,918; java: 184,324; sh: 64,488; makefile: 19,203; objc: 13,059; perl: 12,955; yacc: 4,583; cs: 3,846; pascal: 3,352; lex: 1,720; ruby: 1,071; exp: 762; php: 436; lisp: 258; awk: 247; sql: 66; sed: 54; csh: 10
file content (76 lines) | stat: -rw-r--r-- 2,093 bytes parent folder | download | duplicates (2)
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name=viewport content="width=device-width,initial-scale=1">
<title>Test synthesized mouse move after drag and drop</title>
<link rel="stylesheet" href="/tests/SimpleTest/test.css">
<script src="/tests/SimpleTest/SimpleTest.js"></script>
<script src="/tests/SimpleTest/EventUtils.js"></script>
<script>
"use strict";

SimpleTest.waitForExplicitFinish();
SimpleTest.waitForFocus(async () => {
  const source = document.getElementById("source");
  const target = document.getElementById("target");

  for (const type of ["dragover", "dragenter"]) {
    target.addEventListener(type, event => {
      event.dataTransfer.dropEffect = "copy";
      event.preventDefault();
    });
  }

  await (async function test_basic() {
    const promiseDrop = new Promise(resolve => {
      target.addEventListener("drop", event => {
        event.preventDefault();
        isnot(
          document.querySelector("span:hover"),
          target,
          "The target should not have hover state during the drop event propagation"
        );
        info("Waiting for mouseover event after drop event...");
        target.addEventListener("mouseover", () => {
          info("Got mouseover event");
          resolve();
        }, {once: true});
      }, { once: true });
    });
    info("Dragging selection is the source element and drop it to the target...");
    getSelection().selectAllChildren(source);
    synthesizePlainDragAndDrop({
      srcSelection: getSelection(),
      destElement: target,
    });
    await promiseDrop;
    await new Promise(resolve =>
      requestAnimationFrame(() => requestAnimationFrame(resolve))
    );
    is(
      document.querySelector("span:hover"),
      target,
      "test_basic: The drop target should have hover state"
    );
  })();

  document.querySelector("style").remove();
  SimpleTest.finish();
});
</script>
<style>
* {
  font-size: 48px;
}
</style>
</head>
<body>
  <div>
    <span id="source">Drag me!</span>
  </div>
  <div>
    <span id="target">Drop here!</span>
  </div>
</body>
</html>