summaryrefslogtreecommitdiffstats
path: root/dom/broadcastchannel/tests/test_broadcastchannel_close.html
diff options
context:
space:
mode:
Diffstat (limited to 'dom/broadcastchannel/tests/test_broadcastchannel_close.html')
-rw-r--r--dom/broadcastchannel/tests/test_broadcastchannel_close.html61
1 files changed, 61 insertions, 0 deletions
diff --git a/dom/broadcastchannel/tests/test_broadcastchannel_close.html b/dom/broadcastchannel/tests/test_broadcastchannel_close.html
new file mode 100644
index 0000000000..91cb9c92a4
--- /dev/null
+++ b/dom/broadcastchannel/tests/test_broadcastchannel_close.html
@@ -0,0 +1,61 @@
+<!DOCTYPE HTML>
+<html>
+<head>
+ <title>Test for BroadcastChannel</title>
+ <script src="/tests/SimpleTest/SimpleTest.js"></script>
+ <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
+</head>
+<body>
+
+<div id="content"></div>
+
+<script type="application/javascript">
+
+function runTest() {
+ var receiver = new BroadcastChannel("foo");
+ var sequence = [ "2", "done" ];
+ receiver.onmessage = function(e) {
+ if (!sequence.length) {
+ ok(false, "No more data is expected");
+ return;
+ }
+
+ var data = sequence.shift();
+ is(e.data, data);
+
+ if (!sequence.length) {
+ SimpleTest.executeSoon(function() {
+ SimpleTest.finish();
+ });
+ }
+ };
+
+ var x = new BroadcastChannel("foo");
+ x.close();
+ try {
+ x.postMessage("1");
+ ok(false, "PostMessage should throw if called after a close().");
+ } catch (e) {
+ ok(true, "PostMessage should throw if called after a close().");
+ }
+
+ var y = new BroadcastChannel("foo");
+ y.postMessage("2");
+ y.close();
+ try {
+ y.postMessage("3");
+ ok(false, "PostMessage should throw if called after a close().");
+ } catch (e) {
+ ok(true, "PostMessage should throw if called after a close().");
+ }
+
+ var z = new BroadcastChannel("foo");
+ z.postMessage("done");
+}
+
+SimpleTest.waitForExplicitFinish();
+runTest();
+
+</script>
+</body>
+</html>