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>
|