File: setting-null-config-navigates-to-about-blank.https.html

package info (click to toggle)
firefox 143.0.3-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,617,328 kB
  • sloc: cpp: 7,478,492; javascript: 6,417,157; ansic: 3,720,058; python: 1,396,372; xml: 627,523; asm: 438,677; java: 186,156; sh: 63,477; makefile: 19,171; objc: 13,059; perl: 12,983; yacc: 4,583; cs: 3,846; pascal: 3,405; lex: 1,720; ruby: 1,003; exp: 762; php: 436; lisp: 258; awk: 247; sql: 66; sed: 53; csh: 10
file content (51 lines) | stat: -rw-r--r-- 2,058 bytes parent folder | download | duplicates (14)
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>