mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-09-04 16:46:08 +00:00
LibWeb: Don't prepare script when src attribute is removed
This commit is contained in:
parent
63b451cb46
commit
08b5cae199
Notes:
github-actions[bot]
2025-02-22 10:40:37 +00:00
Author: https://github.com/tcl3
Commit: 08b5cae199
Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/3658
Reviewed-by: https://github.com/gmta ✅
3 changed files with 46 additions and 0 deletions
|
@ -0,0 +1,35 @@
|
|||
<!doctype html>
|
||||
<meta charset=utf-8>
|
||||
<link rel=help href=https://github.com/whatwg/html/pull/10188/files#r1685905457>
|
||||
<title>Remove src attribute does not "prepare the script"</title>
|
||||
<script src="../../../../resources/testharness.js"></script>
|
||||
<script src="../../../../resources/testharnessreport.js"></script>
|
||||
|
||||
<body>
|
||||
<script>
|
||||
test(() => {
|
||||
// Flags that the script element in this test will change, if it incorrectly
|
||||
// executes.
|
||||
window.didExecute = false;
|
||||
window.innerTextExecuted = false;
|
||||
|
||||
const script = document.createElement('script');
|
||||
// Invalid type, so the script won't execute upon insertion.
|
||||
script.type = 'invalid';
|
||||
script.src = 'resources/flag-setter.js';
|
||||
script.innerText = 'window.innerTextExecuted = true';
|
||||
document.body.append(script);
|
||||
assert_false(window.didExecute);
|
||||
assert_false(window.innerTextExecuted);
|
||||
|
||||
// Make script valid, but don't immediately execute it.
|
||||
script.type = '';
|
||||
|
||||
// Removing the `src` content attribute does not trigger the "prepare a
|
||||
// script" algorithm on the script.
|
||||
script.removeAttribute('src');
|
||||
assert_false(window.didExecute);
|
||||
assert_false(window.innerTextExecuted);
|
||||
}, "Removing the `src` content attribute does not 'prepare' the script");
|
||||
</script>
|
||||
</body>
|
Loading…
Add table
Add a link
Reference in a new issue