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
118
119
|
<!DOCTYPE HTML>
<html>
<!--
https://bugzilla.mozilla.org/show_bug.cgi?id=607529
-->
<head>
<title>Test for Bug 607529</title>
<script src="/tests/SimpleTest/SimpleTest.js"></script>
<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
</head>
<body>
<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=607529">Mozilla Bug 607529</a>
<p id="display"></p>
<div id="content" style="display: none">
</div>
<pre id="test">
<script type="application/javascript">
SimpleTest.waitForExplicitFinish();
/* General idea: Open a new window (needed because we don't bfcache
subframes) that uses requestAnimationFrame, navigate it, navigate it
back, and verify that the animations are still running. */
function executeTest() {
/** Test for Bug 607529 **/
var doneOneLoad = false;
var done = false;
var bc = new BroadcastChannel("bug607529");
var bc_1 = new BroadcastChannel("bug607529_1");
bc.onmessage = (msgEvent) => {
var msg = msgEvent.data;
isnot(msg, "notcached", "Should never end up not being cached");
if (msg == "loaded") {
if (!doneOneLoad) {
doneOneLoad = true;
bc.postMessage("navigateToPage");
} else {
// This is unexpected, but it can happen on Android, probably when
// bfcache gets purged due to memory pressure. Hence, "soft fail" there.
var message = "onload handler shouldn't fire on restore from bfcache";
if (navigator.appVersion.includes("Android")) {
todo(false, message);
} else {
ok(false, message);
}
// In any case, more messages aren't coming, so finish up.
closeWindowAndFinish();
}
}
else if (msg == "revived") {
bc.postMessage("report");
}
else if (msg == "callbackHappened") {
// We might get this message more than once, if the other page queues up
// more than one callbackHappened message before we manage to close it.
// Protect against calling SimpleTest.finish() more than once.
if (!done) {
closeWindowAndFinish();
done = true;
}
} else if (msg == "closed") {
bc.close();
bc_1.close();
SimpleTest.finish();
} else {
try {
var jsonMsg = JSON.parse(msg);
} catch (ex) {
// In case JSON.parse throws, we pause to print the string that it
// choked on, and then resume throwing the exception.
ok(false, "JSON.parse threw, when passed string '" + jsonMsg + "'");
throw ex;
}
if (jsonMsg.error) {
window.onerror(jsonMsg.msg, jsonMsg.url, jsonMsg.line);
}
}
}
bc_1.onmessage = (msgEvent) => {
if (msgEvent.data == "goback") {
bc_1.postMessage("navigateBack");
}
}
function closeWindowAndFinish() {
bc.postMessage("close");
}
// If Fission is disabled, the pref is no-op.
SpecialPowers.pushPrefEnv({set: [["fission.bfcacheInParent", true]]}, () => {
window.open("file_bug607529.html", "", "noopener");
});
}
if (isXOrigin) {
// Bug 1746646: Make mochitests work with TCP enabled (cookieBehavior = 5)
// Acquire storage access permission here so that the BroadcastChannel used to
// communicate with the opened windows works in xorigin tests. Otherwise,
// the iframe containing this page is isolated from first-party storage access,
// which isolates BroadcastChannel communication.
SpecialPowers.wrap(document).notifyUserGestureActivation();
SpecialPowers.pushPrefEnv({
set: [["privacy.partition.always_partition_third_party_non_cookie_storage", false]],
}).then(() => {
SpecialPowers.addPermission("storageAccessAPI", true, window.location.href).then(() => {
SpecialPowers.wrap(document).requestStorageAccess().then(() => {
executeTest();
});
});
});
} else {
executeTest();
}
</script>
</pre>
</body>
</html>
|