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 /testing/web-platform/tests/xhr/abort-during-readystatechange.any.js | |
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 'testing/web-platform/tests/xhr/abort-during-readystatechange.any.js')
-rw-r--r-- | testing/web-platform/tests/xhr/abort-during-readystatechange.any.js | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/testing/web-platform/tests/xhr/abort-during-readystatechange.any.js b/testing/web-platform/tests/xhr/abort-during-readystatechange.any.js new file mode 100644 index 0000000000..a036376c6c --- /dev/null +++ b/testing/web-platform/tests/xhr/abort-during-readystatechange.any.js @@ -0,0 +1,19 @@ +"use strict"; +setup({ single_test: true }); + +const xhr = new XMLHttpRequest(); + +// In jsdom's implementation, this would cause a crash, as after firing readystatechange for HEADERS_RECEIVED, it would +// try to manipulate internal state. But that internal state got cleared during abort(). So jsdom needed to be modified +// to check if that internal state had gone away as a result of firing readystatechange, and if so, bail out. + +xhr.addEventListener("readystatechange", () => { + if (xhr.readyState === xhr.HEADERS_RECEIVED) { + xhr.abort(); + } else if (xhr.readyState === xhr.DONE) { + done(); + } +}); + +xhr.open("GET", "/common/blank.html"); +xhr.send(); |