summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/workers/WorkerGlobalScope-close.html
diff options
context:
space:
mode:
Diffstat (limited to 'testing/web-platform/tests/workers/WorkerGlobalScope-close.html')
-rw-r--r--testing/web-platform/tests/workers/WorkerGlobalScope-close.html81
1 files changed, 81 insertions, 0 deletions
diff --git a/testing/web-platform/tests/workers/WorkerGlobalScope-close.html b/testing/web-platform/tests/workers/WorkerGlobalScope-close.html
new file mode 100644
index 0000000000..08ab1ca515
--- /dev/null
+++ b/testing/web-platform/tests/workers/WorkerGlobalScope-close.html
@@ -0,0 +1,81 @@
+<!DOCTYPE html>
+<title>Test WorkerGlobalScope.close functionality.</title>
+<script src="/resources/testharness.js"></script>
+<script src="/resources/testharnessreport.js"></script>
+<script>
+setup({ allow_uncaught_exception: true });
+
+async_test(function(t) {
+ var worker = new Worker('support/WorkerGlobalScope-close.js');
+ worker.postMessage("typeofClose");
+ worker.onmessage = t.step_func_done(function(evt) {
+ assert_equals(evt.data, "typeof close: function");
+ });
+}, 'Test type of close function.');
+
+async_test(function(t) {
+ var worker = new Worker('support/WorkerGlobalScope-close.js');
+ worker.postMessage("ping");
+ worker.onmessage = t.step_func(function(evt) {
+ assert_equals(evt.data, "pong");
+ // Tell the worker to close, then send a followup message.
+ worker.postMessage("close");
+
+ // The worker may or may not be closing/closed by this call. If it is, the
+ // message won't be enqueued on the worker's event loop. If it isn't, the
+ // message will be enqueued but shouldn't be handled by the worker because
+ // the prior postMessage will cause the worker to close. In either case,
+ // the worker shouldn't postMessage back "pong".
+ //
+ // This also means that at this point we can't confidently test
+ // postMessage-ing a worker that will close nor a worker that is already
+ // closing/closed.
+ worker.postMessage("ping");
+
+ worker.onmessage = t.step_func(function(evt) {
+ assert_not_equals(evt.data, "pong");
+
+ // The worker should definitely be closed by now, so we can confidently
+ // test postMessage-ing a closed worker. This postMessage shouldn't throw
+ // or cause the worker to postMessage back "pong" (it shouldn't receive
+ // any events after closing).
+ worker.postMessage("ping");
+
+ t.step_timeout(function() { t.done(); }, 500);
+ });
+ });
+}, 'Test sending a message after closing.');
+
+async_test(function(t) {
+ var worker = new Worker('support/WorkerGlobalScope-close.js');
+ worker.postMessage("closeWithError");
+ worker.onerror = function(event) {
+ t.done()
+ };
+}, 'Test errors are delivered after close.');
+
+async_test(function(t) {
+ var worker = new Worker('support/WorkerGlobalScope-close.js');
+ worker.postMessage("closeWithPendingEvents");
+ worker.onmessage = t.step_func(function(evt) {
+ assert_unreached("Pending events should not fire: " + evt.data);
+ });
+ worker.onerror = t.step_func(function(evt) {
+ assert_unreached("Pending events should not fire:" + evt.message);
+ });
+ t.step_timeout(function() { t.done(); }, 500);
+}, 'Test workers do not deliver pending events.');
+
+async_test(function(t) {
+ var worker = new Worker('support/WorkerGlobalScope-close.js');
+ worker.postMessage("close");
+ worker.onmessage = function(evt) {
+ assert_equals(evt.data, "Should be delivered");
+ // Give worker a chance to close first, then terminate it.
+ t.step_timeout(function() {
+ worker.terminate();
+ t.done();
+ }, 500);
+ };
+}, 'Test terminating a worker after close.');
+</script>