-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[renderblocking] Don't cancel implicit render-blocking when blocking …
…attribute is removed 1. This patch adds tests for whatwg/html#7857. When `blocking=render` is removed, if the element is implicitly render-blocking, we shouldn't unblock rendering for it. 2. This patch fixes how <link> element respond to `blocking` attribute changes. Previously, the element simply reprocesses (cancel and then restart) on every `blocking` attribute change, causing unnecessary work and also some bugs on stylesheets. This patch changes that into unblock rendering if needed to match the spec. Bug: 1271296 Change-Id: I54a2f33dc1ed9971eaeceeb677a165d598d5d4d1 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/3608747 Reviewed-by: Mason Freed <masonf@chromium.org> Commit-Queue: Xiaocheng Hu <xiaochengh@chromium.org> Reviewed-by: Joey Arhar <jarhar@chromium.org> Cr-Commit-Position: refs/heads/main@{#998568} NOKEYCHECK=True GitOrigin-RevId: 831456d6a2d55d251875cdf15de4066e66d817e9
- Loading branch information
1 parent
d6620ac
commit 2b86e00
Showing
10 changed files
with
134 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
25 changes: 25 additions & 0 deletions
25
...ts/external/wpt/html/dom/render-blocking/remove-attr-script-keeps-blocking.tentative.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
<!DOCTYPE html> | ||
<title>Synchronous script element still blocks rendering after removing `blocking=render`</title> | ||
<script src="/resources/testharness.js"></script> | ||
<script src="/resources/testharnessreport.js"></script> | ||
<script src="support/test-render-blocking.js"></script> | ||
|
||
<script> | ||
// Test script must be added before the synchronous script because the | ||
// synchronous script is parser-blocking. | ||
|
||
promise_setup(async () => { | ||
let script = await nodeInserted(document.head, node => node.id === 'script'); | ||
script.blocking = ''; | ||
|
||
// Also inserts some contents for non-compliant UA to render | ||
document.body = document.createElement('body'); | ||
document.body.appendChild(document.createTextNode('Some text')); | ||
}); | ||
|
||
test_render_blocking( | ||
() => assert_equals(window.dummy, 1), | ||
'Render-blocking script is loaded and evaluated'); | ||
</script> | ||
|
||
<script id="script" blocking="render" src="support/dummy-1.js?pipe=trickle(d1)"></script> |
28 changes: 28 additions & 0 deletions
28
...sts/external/wpt/html/dom/render-blocking/remove-attr-style-keeps-blocking.tentative.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
<!DOCTYPE html> | ||
<title>Parser-inserted style element still blocks rendering after removing `blocking=render`</title> | ||
<script src="/resources/testharness.js"></script> | ||
<script src="/resources/testharnessreport.js"></script> | ||
<script src="support/test-render-blocking.js"></script> | ||
|
||
<script> | ||
// Test script must be added before the style element because the style | ||
// element is script-blocking. | ||
|
||
promise_setup(async () => { | ||
let sheet = await nodeInserted(document.head, node => node.id === 'sheet'); | ||
sheet.blocking = ''; | ||
}); | ||
|
||
test_render_blocking( | ||
() => { | ||
let color = getComputedStyle(document.querySelector('.target')).color; | ||
assert_equals(color, 'rgb(255, 0, 0)'); | ||
}, | ||
'Render-blocking stylesheet is applied'); | ||
</script> | ||
|
||
<style id="sheet" blocking="render"> | ||
@import url("support/target-red.css?pipe=trickle(d1)"); | ||
</style> | ||
|
||
<div class="target">Some text</div> |
27 changes: 27 additions & 0 deletions
27
...al/wpt/html/dom/render-blocking/remove-attr-stylesheet-link-keeps-blocking.tentative.html
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
<!DOCTYPE html> | ||
<title>Parser-inserted stylesheet link still blocks rendering after removing `blocking=render`</title> | ||
<script src="/resources/testharness.js"></script> | ||
<script src="/resources/testharnessreport.js"></script> | ||
<script src="support/test-render-blocking.js"></script> | ||
|
||
<script> | ||
// Test script must be added before the stylesheet link because the stylesheet | ||
// link is script-blocking. | ||
|
||
promise_setup(async () => { | ||
let sheet = await nodeInserted(document.head, node => node.id === 'sheet'); | ||
sheet.blocking = ''; | ||
}); | ||
|
||
test_render_blocking( | ||
() => { | ||
let color = getComputedStyle(document.querySelector('.target')).color; | ||
assert_equals(color, 'rgb(255, 0, 0)'); | ||
}, | ||
'Render-blocking stylesheet is applied'); | ||
</script> | ||
|
||
<link id="sheet" rel="stylesheet" blocking="render" | ||
href="support/target-red.css?pipe=trickle(d1)"> | ||
|
||
<div class="target">Some text</div> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters