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-done.window.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-done.window.js')
-rw-r--r-- | testing/web-platform/tests/xhr/abort-during-done.window.js | 78 |
1 files changed, 78 insertions, 0 deletions
diff --git a/testing/web-platform/tests/xhr/abort-during-done.window.js b/testing/web-platform/tests/xhr/abort-during-done.window.js new file mode 100644 index 0000000000..f885e59af1 --- /dev/null +++ b/testing/web-platform/tests/xhr/abort-during-done.window.js @@ -0,0 +1,78 @@ +// META: title=XMLHttpRequest: abort() during DONE + + async_test(test => { + var client = new XMLHttpRequest(), + result = [], + expected = [1, 4] // open() -> 1, send() -> 4 + client.onreadystatechange = test.step_func(function() { + result.push(client.readyState) + }) + client.open("GET", "resources/well-formed.xml", false) + client.send(null) + assert_equals(client.readyState, 4) + assert_equals(client.status, 200) + assert_equals(client.statusText, "OK") + assert_equals(client.responseXML.documentElement.localName, "html") + client.abort() + assert_equals(client.readyState, 0) + assert_equals(client.status, 0) + assert_equals(client.statusText, "") + assert_equals(client.responseXML, null) + assert_equals(client.getAllResponseHeaders(), "") + assert_array_equals(result, expected) + test.done() + }, document.title + " (sync)") + + async_test(test => { + var client = new XMLHttpRequest(), + result = [], + expected = [1, 4] // open() -> 1, send() -> 4 + client.onreadystatechange = test.step_func(function() { + result.push(client.readyState); + if (client.readyState === 4) { + assert_equals(client.readyState, 4) + assert_equals(client.status, 200) + assert_equals(client.statusText, "OK") + assert_equals(client.responseXML.documentElement.localName, "html") + client.abort(); + assert_equals(client.readyState, 0) + assert_equals(client.status, 0) + assert_equals(client.statusText, "") + assert_equals(client.responseXML, null) + assert_equals(client.getAllResponseHeaders(), "") + test.done() + } + }) + client.open("GET", "resources/well-formed.xml", false) + client.send(null) + assert_equals(client.readyState, 0) + assert_equals(client.status, 200) + assert_equals(client.statusText, "OK") + assert_equals(client.responseXML.documentElement.localName, "html") + }, document.title + " (sync aborted in readystatechange)") + + async_test(test => { + var client = new XMLHttpRequest(), + result = [], + expected = [1, 2, 3, 4] + client.onreadystatechange = test.step_func(function() { + result.push(client.readyState); + if (client.readyState === 4) { + assert_equals(client.readyState, 4) + assert_equals(client.status, 200) + assert_equals(client.responseXML.documentElement.localName, "html") + client.abort(); + assert_equals(client.readyState, 0) + assert_equals(client.status, 0) + assert_equals(client.statusText, "") + assert_equals(client.responseXML, null) + assert_equals(client.getAllResponseHeaders(), "") + test.step_timeout(function() { + assert_array_equals(result, expected) + test.done(); + }, 100); // wait a bit in case XHR timeout causes spurious event + } + }) + client.open("GET", "resources/well-formed.xml") + client.send(null) + }, document.title + " (async)") |