File: change-src-attribute-after-config-installation-does-not-trigger-navigation.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 (52 lines) | stat: -rw-r--r-- 1,858 bytes parent folder | download | duplicates (18)
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
<!DOCTYPE html>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/common/utils.js"></script>
<script src="/common/get-host-info.sub.js"></script>
<script src="resources/utils.js"></script>
<title>Test changing a fenced frame's src attribute when there has been a config
with url installed already does not trigger navigation.</title>

<body>

<script>
function getTimeoutPromise(t) {
  return new Promise(resolve =>
    t.step_timeout(() => resolve("NOT LOADED"), 2000));
}

promise_test(async (t) => {
  const fenced_frame_loaded_key = token();

  const url = generateURL(
    'resources/fenced-frame-loaded.html', [fenced_frame_loaded_key]);
  const url_string = url.toString();

  // Create a fenced frame and install an inner config constructed with an url.
  const fenced_frame = document.createElement('fencedframe');
  const config = new FencedFrameConfig(url_string);
  fenced_frame.config = config;
  document.body.append(fenced_frame);

  // Installing a config to the fenced frame triggers navigation.
  const load_expected = "fenced frame loaded";
  const load_actual = await nextValueFromServer(fenced_frame_loaded_key);
  assert_equals(load_actual, load_expected,
    "Fenced frame successfully loaded.");

  const src_key = token();
  const src_url = generateURL(
    'resources/fenced-frame-loaded.html', [src_key]);

  // Changing the src attribute, should not trigger navigation.
  fenced_frame.src = src_url;
  const src_loaded_promise = nextValueFromServer(src_key);
  const src_loaded_result = await Promise.any([src_loaded_promise,
    getTimeoutPromise(t)]);
  assert_equals(src_loaded_result, "NOT LOADED");

}, 'Changing the src attribute of a fenced frame when a config with url',
  'has already been installed does not trigger navigation.');
</script>

</body>