blob: c8322dab1996ccabc5ee980fd63bc52c57df9d05 (
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
|
<!DOCTYPE html>
<meta name=timeout content=long>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/common/utils.js"></script>
<script src="/common/dispatcher/dispatcher.js"></script>
<script src="/common/get-host-info.sub.js"></script>
<script src="resources/utils.js"></script>
<title>Test fenced frame null config installation triggers about:blank navigation.</title>
<body>
<script>
promise_test(async (t) => {
var frame_context = await attachFencedFrameContext();
// Ensure remote context responds.
let alive_indicator = await Promise.race([
frame_context.execute(() => 'alive'),
new Promise((resolve, reject) => t.step_timeout(
() => reject('timed_out'), 1500))
]);
assert_equals(alive_indicator, 'alive');
assert_not_equals(frame_context.element.config, null);
// Navigates to about:blank. Because this navigates away from the page
// that the frame_context.element.config is currently pointing to, the
// FencedFrame's portion of the remote context handling code will be
// removed.
frame_context.element.config = null;
let fenced_frame_alive_promise = async (resolve) => {
await frame_context.execute(() => {});
resolve('alive');
};
// This call should not succeed, because we should have navigated to
// about:blank. Note that because the code has been deleted as described
// above, we can't actually inspect the URL to determine it is
// about:blank; we have to use our timeout as a proxy.
let timeout_indicator = await Promise.any([
new Promise(resolve => t.step_timeout(
() => fenced_frame_alive_promise(resolve), 500)),
new Promise(resolve => t.step_timeout(
() => resolve('timed_out'), 1500))
]);
assert_equals(timeout_indicator, 'timed_out');
}, "Test that a fenced frame with a config explicitly set to null navigates to about:blank");
</script>
</body>
|