gecko-dev/testing/web-platform/tests/eventsource/eventsource-cross-origin.htm
James Graham a1b638d149 Bug 1381842 - Update web-platform-tests to revision 85ae24e3dc80ee63b6dc2ed78a922cff68c6e819, a=testonly
MozReview-Commit-ID: DfvN9mAFYhI


--HG--
rename : testing/web-platform/tests/conformance-checkers/html-svg/animate-elem-77-t-novalid.html => testing/web-platform/tests/conformance-checkers/html-svg/animate-elem-77-t-isvalid.html
rename : testing/web-platform/tests/conformance-checkers/html-svg/linking-a-10-f-novalid.html => testing/web-platform/tests/conformance-checkers/html-svg/linking-a-10-f-isvalid.html
rename : testing/web-platform/tests/conformance-checkers/html/elements/picture/srcset-microsyntax-leading-dot-x-novalid.html => testing/web-platform/tests/conformance-checkers/html/elements/picture/srcset-microsyntax-leading-dot-x-valid.html
rename : testing/web-platform/tests/content-security-policy/_unapproved/script-nonces-hidden.html.headers => testing/web-platform/tests/content-security-policy/nonce-hiding/script-nonces-hidden.tentative.html.headers
rename : testing/web-platform/tests/content-security-policy/_unapproved/svgscript-nonces-hidden.html.headers => testing/web-platform/tests/content-security-policy/nonce-hiding/svgscript-nonces-hidden.tentative.html.headers
rename : testing/web-platform/tests/html/semantics/interactive-elements/context-menus/contextmenu-event-manual.htm => testing/web-platform/tests/html/webappapis/scripting/events/contextmenu-event-manual.htm
2017-07-20 13:05:25 +01:00

65 lines
2.3 KiB
HTML

<!DOCTYPE html>
<html>
<head>
<meta charset=utf-8>
<title>EventSource: cross-origin</title>
<meta name=author title="Odin Hørthe Omdal" href="mailto:odiho@opera.com">
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
</head>
<body>
<div id="log"></div>
<script>
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")
</script>
</body>
</html>