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 000000000..84d41db4f
--- /dev/null
+++ b/dom/broadcastchannel/tests/test_broadcastchannel_close.html
@@ -0,0 +1,61 @@
+<!DOCTYPE HTML>
+<html>
+<head>
+ <title>Test for BroadcastChannel</title>
+ <script type="application/javascript" 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>