summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/html/semantics/embedded-content/the-iframe-element/iframe-loading-lazy-base-url-3.html
blob: 611221d8014dcac289bf0fde361c792872ce3e89 (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
<!DOCTYPE html>
<head>
  <title>Deferred iframes with loading='lazy' changed to eager later
         use the document's base URL computed at parse-time</title>
  <link rel="author" title="Oliver Medhurst" href="mailto:omedhurst@mozilla.com">
  <script src="/resources/testharness.js"></script>
  <script src="/resources/testharnessreport.js"></script>
  <script src="../resources/common.js"></script>
  <base href='/html/semantics/embedded-content/the-iframe-element/resources/'>
</head>

<script>
  const below_viewport_iframe = new ElementLoadPromise("below-viewport");

  let has_window_loaded = false;

  async_test(t => {
    // Change the base URL and scroll down to load the deferred iframe.
    window.addEventListener("load", t.step_func(() => {
      const base = document.querySelector('base');
      base.href = '/invalid-url-where-no-subresources-exist/';
      has_window_loaded = true;
      below_viewport_iframe.element().loading = 'eager';
    }));

    below_viewport_iframe.promise.then(
      t.step_func_done(() => {
        assert_true(has_window_loaded,
                    "Below-viewport loading=lazy iframes do not block the " +
                    "window load event");
        assert_true(below_viewport_iframe.element().contentDocument.body.
                    innerHTML.includes("<p>Subframe</p>"),
                    "The loading=lazy iframe's content is accessible upon loading");
    }));

  }, "When a loading=lazy iframe is changed to eager later before loading, it loads relative to the " +
     "document's base URL computed at parse-time.");
</script>

<body>
  <div style="height:1000vh"></div>
  <iframe id="below-viewport" src="subframe.html" loading="lazy"
          width="200px" height="100px" onload="below_viewport_iframe.resolve()">
  </iframe>
</body>