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
|
<!DOCTYPE HTML>
<html>
<head>
<title>Bug 1702001: Https-only mode does not reload pages after clicking "Continue to HTTP Site", when url contains navigation </title>
<script src="/tests/SimpleTest/SimpleTest.js"></script>
<link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css" />
</head>
<body>
<script class="testbody" type="text/javascript">
"use strict";
/*
* Description of the test:
*
* Load a page including a fragment portion which does not support https and make
* sure that exempting the page from https-only-mode does not result in a fragment
* navigation.
*/
function resolveAfter6Seconds() {
return new Promise(resolve => {
setTimeout(() => {
resolve();
}, 6000);
});
}
SimpleTest.requestFlakyTimeout("We need to wait for the HTTPS-Only error page to appear");
SimpleTest.waitForExplicitFinish();
let winTest = null;
let TEST_URL = "http://example.com/tests/dom/security/test/https-only/file_insecure_reload.sjs#nav";
// verify that https-only page appeared
async function verifyErrorPage() {
let errorPageL10nId = "about-httpsonly-title-alert";
let innerHTML = content.document.body.innerHTML;
ok(innerHTML.includes(errorPageL10nId), "the error page should be shown for ");
let button = content.document.getElementById("openInsecure");
// Click "Continue to HTTP Site"
ok(button, "button exist");
if(button) {
button.click();
}
}
// verify that you entered the page and are not still displaying
// the https-only error page
async function receiveMessage(event) {
// read event
let { result, historyLength } = event.data;
is(result, "you entered the http page", "The requested page should be shown");
is(historyLength, 1, "History should contain one item");
window.removeEventListener("message",receiveMessage);
winTest.close();
SimpleTest.finish();
}
async function runTest() {
//Test: With https-only mode activated
await SpecialPowers.pushPrefEnv({ set: [
["dom.security.https_only_mode", true],
]});
winTest = window.open(TEST_URL);
await resolveAfter6Seconds();
await SpecialPowers.spawn(winTest,[],verifyErrorPage);
}
window.addEventListener("message", receiveMessage);
runTest();
</script>
</body>
</html>
|