LibWeb: Port some manually async tests to use asyncTest

These tests were mostly async tests written in a manual way. This ports
them to use the standard asyncTest() infrastructure.

This is mostly just to reduce calls to internals.signalTextTestIsDone,
which will have a required parameter in an upcoming test.
This commit is contained in:
Timothy Flynn 2024-10-02 12:31:42 -04:00 committed by Tim Flynn
commit 96082d6ae1
Notes: github-actions[bot] 2024-10-03 11:08:43 +00:00
5 changed files with 64 additions and 54 deletions

View file

@ -1,16 +1,18 @@
<!DOCTYPE html>
<script src="../include.js"></script>
<script>
asyncTest(done => {
let reloaded = false;
window.addEventListener('message', event => {
window.addEventListener("message", event => {
switch (event.data.action) {
case "loaded":
println("iframe is loaded");
if (!reloaded) {
event.source.postMessage({ action: 'reload' });
event.source.postMessage({ action: "reload" });
reloaded = true;
} else {
internals.signalTextTestIsDone();
done();
}
break;
case "acknowledge-asked-to-reload":
@ -21,9 +23,8 @@
}
});
document.addEventListener("DOMContentLoaded", () => {
const iframe = document.createElement('iframe');
iframe.src = "../../data/iframe-reload.html"
const iframe = document.createElement("iframe");
iframe.src = "../../data/iframe-reload.html";
document.body.appendChild(iframe);
});
</script>

View file

@ -2,15 +2,17 @@
<script src="../include.js"></script>
<script>
let reloaded = false;
window.addEventListener('message', event => {
asyncTest(done => {
window.addEventListener("message", event => {
switch (event.data.action) {
case "loaded":
println("iframe is loaded");
if (!reloaded) {
event.source.postMessage({ action: 'reload' });
event.source.postMessage({ action: "reload" });
reloaded = true;
} else {
internals.signalTextTestIsDone();
done();
}
break;
case "acknowledge-asked-to-reload":
@ -33,8 +35,7 @@
});
`;
document.addEventListener("DOMContentLoaded", () => {
const iframe = document.createElement('iframe');
const iframe = document.createElement("iframe");
iframe.srcdoc = "<script>" + iframeScript + "<\/script>";
document.body.appendChild(iframe);
});

View file

@ -2,11 +2,13 @@
<div id="foo">
<iframe></iframe>
<script>
asyncTest(done => {
setTimeout(function () {
foo.remove();
// Pass (didn't crash)
internals.signalTextTestIsDone();
done();
}, 0);
});
</script>
</div>
<iframe></iframe>

View file

@ -1,5 +1,11 @@
<body><script>
<body>
<script>
window.scrollTo(200, 200);
if (window.internals !== undefined)
window.internals.signalTextTestIsDone();
</script>PASS (didn't crash)
</script>
<script src="include.js"></script>
<script>
test(() => {
println("PASS (didn't crash)");
});
</script>
</body>