summaryrefslogtreecommitdiffstats
path: root/dom/events/test/test_drag_image_file.html
blob: 13e6996693b79a8ca45f25e4794f02fcd5401443 (plain)
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
<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>Test that dragging an image produces a File</title>
  <script src="/tests/SimpleTest/SimpleTest.js"></script>
  <script src="/tests/SimpleTest/EventUtils.js"></script>
  <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
</head>
<body>

<img id="green-png" src="green.png">

<script>
async function runTest() {
  await SpecialPowers.pushPrefEnv({
    set: [["dom.events.dataTransfer.imageAsFile.enabled", true]],
  });

  let dt = await synthesizePlainDragAndCancel({
      srcElement: document.getElementById('green-png'),
      finalY: 20,
  }, null);

  info(`DataTransfer types: ${dt.types}`);

  for (let type of dt.types) {
    info(`getData(${type}) = ${dt.getData(type)}`)
  }

  ok(dt.types.includes("Files"), "types should contains 'Files'");
  is(dt.files.length, 1, "files contains one File");

  let fileItem = null;
  for (let item of dt.items) {
    if (item.kind === "file") {
      fileItem = item;
      break;
    }
  }

  is(fileItem.kind, "file", "Is a file");
  is(fileItem.type, "image/png", "Is a PNG file");

  let file = fileItem.getAsFile();
  is(file.name, "image.png", "Has generic image name")
  ok(file.size > 100, "Is not empty");

  SimpleTest.finish();
}

SimpleTest.waitForExplicitFinish();
SimpleTest.waitForFocus(runTest);
</script>
</body>
</html>