diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 01:47:29 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 01:47:29 +0000 |
commit | 0ebf5bdf043a27fd3dfb7f92e0cb63d88954c44d (patch) | |
tree | a31f07c9bcca9d56ce61e9a1ffd30ef350d513aa /dom/base/test/file_bug503481b_inner.html | |
parent | Initial commit. (diff) | |
download | firefox-esr-0ebf5bdf043a27fd3dfb7f92e0cb63d88954c44d.tar.xz firefox-esr-0ebf5bdf043a27fd3dfb7f92e0cb63d88954c44d.zip |
Adding upstream version 115.8.0esr.upstream/115.8.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'dom/base/test/file_bug503481b_inner.html')
-rw-r--r-- | dom/base/test/file_bug503481b_inner.html | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/dom/base/test/file_bug503481b_inner.html b/dom/base/test/file_bug503481b_inner.html new file mode 100644 index 0000000000..6b34bc47b6 --- /dev/null +++ b/dom/base/test/file_bug503481b_inner.html @@ -0,0 +1,62 @@ +<!DOCTYPE HTML> +<html> +<head> +<!-- Async script that isn't preloaded --> +<script async src="file_bug503481.sjs?blockOn=R&body=runFirst();"></script> +<script> +firstRan = false; +secondRan = false; +thirdRan = false; +forthRan = false; +function runFirst() { + firstRan = true; +} +function runThird() { + parent.is(forthRan, false, "forth should still be blocked"); + unblock("T"); + thirdRan = true; +} +function runForth() { + forthRan = true; +} + +function done() { + parent.is(firstRan, true, "first should have run by onload"); + parent.is(secondRan, true, "second should have run by onload"); + parent.is(thirdRan, true, "third should have run by onload"); + parent.is(forthRan, true, "forth should have run by onload"); + parent.SimpleTest.finish(); +} + +var reqs = []; +function unblock(s) { + xhr = new XMLHttpRequest(); + xhr.open("GET", "file_bug503481.sjs?unblock=" + s); + xhr.send(); + reqs.push(xhr); +} + + +parent.is(firstRan, false, "First async script shouldn't have run"); +unblock("R"); +</script> + +<!-- test that inline async isn't actually async --> +<script async> +secondRan = true; +</script> +<script> +parent.is(secondRan, true, "Second script shouldn't be async"); +</script> + +<!-- test that setting both defer and async treats the script as async --> +<script defer async src="file_bug503481.sjs?blockOn=S&body=runThird();"></script> +<script> +parent.is(thirdRan, false, "third should not have run yet"); +unblock("S"); +</script> +<script src="file_bug503481.sjs?blockOn=T&body=runForth();"></script> + +</head> + +<body onload="done()"> |