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
|
"use strict";
const BASE = "https://example.com/browser/dom/xslt/tests/browser";
const SERVER_SCRIPT = `${BASE}/bug1309630.sjs`;
function resetCounter() {
return fetch(`${SERVER_SCRIPT}?reset_counter`);
}
function recordCounter() {
return fetch(`${SERVER_SCRIPT}?record_counter`);
}
// Returns a promise that resolves to true if the counter in
// bug1309630.sjs changed by more than 'value' since last calling
// recordCounter(), or false if it doesn't and we time out.
function waitForCounterChangeAbove(value) {
return TestUtils.waitForCondition(() =>
fetch(`${SERVER_SCRIPT}?get_counter_change`).then(response =>
response.ok
? response.text().then(str => Number(str) > value)
: Promise.reject()
)
).then(
() => true,
() => false
);
}
add_task(async function test_eternal_xslt() {
await resetCounter();
await BrowserTestUtils.withNewTab(
{ gBrowser, url: SERVER_SCRIPT, waitForLoad: false },
async function (browser) {
info("Waiting for XSLT to keep loading");
ok(
await waitForCounterChangeAbove(1),
"We should receive at least a request from the document function call."
);
info("Navigating to about:blank");
BrowserTestUtils.startLoadingURIString(browser, "about:blank");
await BrowserTestUtils.browserLoaded(browser);
info("Check to see if XSLT stops loading");
await recordCounter();
ok(
!(await waitForCounterChangeAbove(0)),
"We shouldn't receive more requests to the XSLT file within the timeout period."
);
}
);
await resetCounter();
await BrowserTestUtils.withNewTab(
{ gBrowser, url: `${BASE}/file_bug1309630.html` },
async function (browser) {
ok(
await waitForCounterChangeAbove(1),
"We should receive at least a request from the document function call."
);
info("Navigating to about:blank");
BrowserTestUtils.startLoadingURIString(browser, "about:blank");
await BrowserTestUtils.browserLoaded(browser);
info("Check to see if XSLT stops loading");
await recordCounter();
ok(
!(await waitForCounterChangeAbove(0)),
"We shouldn't receive more requests to the XSLT file within the timeout period."
);
}
);
});
|