// 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++; }); });