summaryrefslogtreecommitdiffstats
path: root/toolkit/components/alerts/test/test_image.html
blob: 3928529c13d9da244e4f5952fd857cfbe733e89a (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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
<!DOCTYPE HTML>
<html>
<head>
  <title>Test for Bug 1233086</title>
  <script src="/tests/SimpleTest/SimpleTest.js"></script>
  <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
</head>

<body>
<p id="display"></p>

<pre id="test">
<script class="testbody" type="text/javascript">

const Cc = SpecialPowers.Cc;
const Ci = SpecialPowers.Ci;
const Services = SpecialPowers.Services;

const imageServerURL = "http://mochi.test:8888/tests/toolkit/components/alerts/test/image_server.sjs";

function makeAlert(...params) {
  var alert = Cc["@mozilla.org/alert-notification;1"]
                .createInstance(Ci.nsIAlertNotification);
  alert.init(...params);
  return alert;
}

function promiseImage(alert, timeout = 0, userData = null) {
  return new Promise(resolve => {
    var isDone = false;
    function done(value) {
      ok(!isDone, "Should call the image listener once");
      isDone = true;
      resolve(value);
    }
    alert.loadImage(timeout, SpecialPowers.wrapCallbackObject({
      onImageReady(aUserData, aRequest) {
        done([true, aRequest, aUserData]);
      },
      onImageMissing(aUserData) {
        done([false, aUserData]);
      },
    }), SpecialPowers.wrap(userData));
  });
}

add_task(async function testContext() {
  var inUserData = Cc["@mozilla.org/supports-PRInt64;1"]
                     .createInstance(Ci.nsISupportsPRInt64);
  inUserData.data = 123;

  var alert = makeAlert(null, imageServerURL + "?f=image.png");
  var [ready, , userData] = await promiseImage(alert, 0, inUserData);
  ok(ready, "Should load requested image");
  is(userData.QueryInterface(Ci.nsISupportsPRInt64).data, 123,
     "Should pass user data for loaded image");

  alert = makeAlert(null, imageServerURL + "?s=404");
  [ready, userData] = await promiseImage(alert, 0, inUserData);
  ok(!ready, "Should not load missing image");
  is(userData.QueryInterface(Ci.nsISupportsPRInt64).data, 123,
     "Should pass user data for missing image");
});

add_task(async function testTimeout() {
  var alert = makeAlert(null, imageServerURL + "?f=image.png&t=3");
  var [ready] = await promiseImage(alert, 1000);
  ok(!ready, "Should cancel request if timeout fires");

  [ready] = await promiseImage(alert, 45000);
  ok(ready, "Should load image if request finishes before timeout");
});

add_task(async function testAnimatedGIF() {
  var alert = makeAlert(null, imageServerURL + "?f=image.gif");
  var [ready, request] = await promiseImage(alert);
  ok(ready, "Should load first animated GIF frame");
  is(request.mimeType, "image/gif", "Should report correct GIF MIME type");
  is(request.image.width, 256, "GIF width should be 256px");
  is(request.image.height, 256, "GIF height should be 256px");
});

add_task(async function testCancel() {
  var alert = makeAlert(null, imageServerURL + "?f=image.gif&t=180");
  await new Promise((resolve, reject) => {
    var request = alert.loadImage(0, SpecialPowers.wrapCallbackObject({
      onImageReady() {
        reject(new Error("Should not load cancelled request"));
      },
      onImageMissing() {
        resolve();
      },
    }), null);
    request.cancel(SpecialPowers.Cr.NS_BINDING_ABORTED);
  });
});

add_task(async function testMixedContent() {
  // Loading principal is HTTPS; image URL is HTTP.
  var origin = "https://mochi.test:8888";
  var principal = Services.scriptSecurityManager
                          .createContentPrincipalFromOrigin(origin);

  var alert = makeAlert(null, imageServerURL + "?f=image.png",
                        null, null, false, null, null, null,
                        null, principal);
  var [ready, request] = await promiseImage(alert);
  ok(ready, "Should load cross-protocol image");
  is(request.mimeType, "image/png", "Should report correct MIME type");
  is(request.image.width, 32, "Width should be 32px");
  is(request.image.height, 32, "Height should be 32px");
});

</script>
</pre>
</body>
</html>