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