Source code

Revision control

Copy as Markdown

Other Tools

Test Info:

// META: title=EventSource: cross-origin
const crossdomain = location.href.replace('://', '://élève.').replace(/\/[^\/]*$/, '/'),
origin = location.origin.replace('://', '://xn--lve-6lad.');
function doCORS(url, title) {
async_test(document.title + " " + title).step(function() {
var source = new EventSource(url, { withCredentials: true })
source.onmessage = this.step_func_done(e => {
assert_equals(e.data, "data");
assert_equals(e.origin, origin);
source.close();
})
})
}
doCORS(crossdomain + "resources/cors.py?run=message",
"basic use")
doCORS(crossdomain + "resources/cors.py?run=redirect&location=/eventsource/resources/cors.py?run=message",
"redirect use")
doCORS(crossdomain + "resources/cors.py?run=status-reconnect&status=200",
"redirect use recon")
function failCORS(url, title) {
async_test(document.title + " " + title).step(function() {
var source = new EventSource(url)
source.onerror = this.step_func(function(e) {
assert_equals(source.readyState, source.CLOSED, 'readyState')
assert_false(e.hasOwnProperty('data'))
source.close()
this.done()
})
/* Shouldn't happen */
source.onmessage = this.step_func(function(e) {
assert_unreached("shouldn't fire message event")
})
source.onopen = this.step_func(function(e) {
assert_unreached("shouldn't fire open event")
})
})
}
failCORS(crossdomain + "resources/cors.py?run=message&origin=http://example.org",
"allow-origin: http://example.org should fail")
failCORS(crossdomain + "resources/cors.py?run=message&origin=",
"allow-origin:'' should fail")
failCORS(crossdomain + "resources/message.py",
"No allow-origin should fail")