70 lines
2.2 KiB
JavaScript
70 lines
2.2 KiB
JavaScript
// META: title=EventSource: close()
|
|
|
|
var test = async_test()
|
|
test.step(function() {
|
|
var source = new EventSource("resources/message.py")
|
|
assert_equals(source.readyState, source.CONNECTING, "connecting readyState");
|
|
source.onopen = this.step_func(function() {
|
|
assert_equals(source.readyState, source.OPEN, "open readyState");
|
|
source.close()
|
|
assert_equals(source.readyState, source.CLOSED, "closed readyState");
|
|
this.done()
|
|
})
|
|
})
|
|
|
|
var test2 = async_test(document.title + ", test events");
|
|
test2.step(function() {
|
|
var count = 0, reconnected = false,
|
|
source = new EventSource("resources/reconnect-fail.py?id=" + new Date().getTime());
|
|
|
|
source.onerror = this.step_func(function(e) {
|
|
assert_equals(e.type, 'error');
|
|
switch(count) {
|
|
// reconnecting after first message
|
|
case 1:
|
|
assert_equals(source.readyState, source.CONNECTING, "reconnecting readyState");
|
|
|
|
reconnected = true;
|
|
break;
|
|
|
|
// one more reconnect to get to the closing
|
|
case 2:
|
|
assert_equals(source.readyState, source.CONNECTING, "last reconnecting readyState");
|
|
count++;
|
|
break;
|
|
|
|
// close
|
|
case 3:
|
|
assert_equals(source.readyState, source.CLOSED, "closed readyState");
|
|
|
|
// give some time for errors to hit us
|
|
test2.step_timeout(function() { this.done(); }, 100);
|
|
break;
|
|
|
|
default:
|
|
assert_unreached("Error handler with msg count " + count);
|
|
}
|
|
|
|
});
|
|
|
|
source.onmessage = this.step_func(function(e) {
|
|
switch(count) {
|
|
case 0:
|
|
assert_true(!reconnected, "no error event run");
|
|
assert_equals(e.data, "opened", "data");
|
|
break;
|
|
|
|
case 1:
|
|
assert_true(reconnected, "have reconnected");
|
|
assert_equals(e.data, "reconnected", "data");
|
|
break;
|
|
|
|
default:
|
|
assert_unreached("Dunno what to do with message number " + count);
|
|
}
|
|
|
|
count++;
|
|
});
|
|
|
|
});
|
|
|