// META: timeout=long // META: global=window,dedicatedworker,sharedworker // META: script=/common/get-host-info.sub.js const host = get_host_info(); const path = "/fetch/cross-origin-resource-policy/"; const localBaseURL = host.HTTP_ORIGIN + path; const sameSiteBaseURL = "http://" + host.ORIGINAL_HOST + ":" + host.HTTP_PORT2 + path; const notSameSiteBaseURL = host.HTTP_NOTSAMESITE_ORIGIN + path; const httpsBaseURL = host.HTTPS_ORIGIN + path; promise_test(async () => { const response = await fetch("./resources/hello.py?corp=same-origin"); assert_equals(await response.text(), "hello"); }, "Same-origin fetch with a 'Cross-Origin-Resource-Policy: same-origin' response header."); promise_test(async () => { const response = await fetch("./resources/hello.py?corp=same-site"); assert_equals(await response.text(), "hello"); }, "Same-origin fetch with a 'Cross-Origin-Resource-Policy: same-site' response header."); promise_test(async (test) => { const response = await fetch(notSameSiteBaseURL + "resources/hello.py?corp=same-origin"); assert_equals(await response.text(), "hello"); }, "Cross-origin cors fetch with a 'Cross-Origin-Resource-Policy: same-origin' response header."); promise_test(async (test) => { const response = await fetch(notSameSiteBaseURL + "resources/hello.py?corp=same-site"); assert_equals(await response.text(), "hello"); }, "Cross-origin cors fetch with a 'Cross-Origin-Resource-Policy: same-site' response header."); promise_test((test) => { const remoteURL = notSameSiteBaseURL + "resources/hello.py?corp=same-origin"; return promise_rejects_js(test, TypeError, fetch(remoteURL, { mode : "no-cors" })); }, "Cross-origin no-cors fetch with a 'Cross-Origin-Resource-Policy: same-origin' response header."); promise_test((test) => { const remoteURL = notSameSiteBaseURL + "resources/hello.py?corp=same-site"; return promise_rejects_js(test, TypeError, fetch(remoteURL, { mode: "no-cors" })); }, "Cross-origin no-cors fetch with a 'Cross-Origin-Resource-Policy: same-site' response header."); promise_test((test) => { const remoteURL = httpsBaseURL + "resources/hello.py?corp=same-site"; return promise_rejects_js(test, TypeError, fetch(remoteURL, { mode: "no-cors" })); }, "Cross-scheme (HTTP to HTTPS) no-cors fetch to a same-site URL with a 'Cross-Origin-Resource-Policy: same-site' response header."); promise_test((test) => { const remoteURL = httpsBaseURL + "resources/hello.py?corp=same-origin"; return promise_rejects_js(test, TypeError, fetch(remoteURL, { mode : "no-cors" })); }, "Cross-origin no-cors fetch to a same-site URL with a 'Cross-Origin-Resource-Policy: same-origin' response header."); promise_test(async (test) => { const remoteSameSiteURL = sameSiteBaseURL + "resources/hello.py?corp=same-site"; await fetch(remoteSameSiteURL, { mode: "no-cors" }); return promise_rejects_js(test, TypeError, fetch(sameSiteBaseURL + "resources/hello.py?corp=same-origin", { mode: "no-cors" })); }, "Valid cross-origin no-cors fetch with a 'Cross-Origin-Resource-Policy: same-site' response header."); promise_test((test) => { const finalURL = notSameSiteBaseURL + "resources/hello.py?corp=same-origin"; return promise_rejects_js(test, TypeError, fetch("resources/redirect.py?redirectTo=" + encodeURIComponent(finalURL), { mode: "no-cors" })); }, "Cross-origin no-cors fetch with a 'Cross-Origin-Resource-Policy: same-origin' response header after a redirection."); promise_test((test) => { const finalURL = localBaseURL + "resources/hello.py?corp=same-origin"; return fetch(notSameSiteBaseURL + "resources/redirect.py?redirectTo=" + encodeURIComponent(finalURL), { mode: "no-cors" }); }, "Cross-origin no-cors fetch with a 'Cross-Origin-Resource-Policy: same-origin' response header after a cross-origin redirection."); promise_test(async (test) => { const finalURL = localBaseURL + "resources/hello.py?corp=same-origin"; await fetch(finalURL, { mode: "no-cors" }); return promise_rejects_js(test, TypeError, fetch(notSameSiteBaseURL + "resources/redirect.py?corp=same-origin&redirectTo=" + encodeURIComponent(finalURL), { mode: "no-cors" })); }, "Cross-origin no-cors fetch with a 'Cross-Origin-Resource-Policy: same-origin' redirect response header.");