// META: script=/common/get-host-info.sub.js
// META: script=/common/utils.js
// META: script=/common/dispatcher/dispatcher.js
// META: script=./resources/common.js
window.onload = function() {
promise_test_parallel(async test => {
const same_origin = get_host_info().HTTPS_ORIGIN;
const cross_origin = get_host_info().HTTPS_REMOTE_ORIGIN;
const cookie_key = "coep_credentialless_script";
const cookie_same_origin = "same_origin";
const cookie_cross_origin = "cross_origin";
await Promise.all([
setCookie(same_origin, cookie_key, cookie_same_origin +
cookie_same_site_none),
setCookie(cross_origin, cookie_key, cookie_cross_origin +
cookie_same_site_none),
]);
// One window with COEP:none. (control)
const w_control_token = token();
const w_control_url = same_origin + executor_path +
coep_none + `&uuid=${w_control_token}`
const w_control = window.open(w_control_url);
add_completion_callback(() => w_control.close());
// One window with COEP:credentialless. (experiment)
const w_credentialless_token = token();
const w_credentialless_url = same_origin + executor_path +
coep_credentialless + `&uuid=${w_credentialless_token}`;
const w_credentialless = window.open(w_credentialless_url);
add_completion_callback(() => w_credentialless.close());
let scriptTest = function(
description, origin, mode,
expected_cookies_control,
expected_cookies_credentialless)
{
promise_test_parallel(async test => {
const token_1 = token();
const token_2 = token();
send(w_control_token, `
let script = document.createElement("script");
script.src = "${showRequestHeaders(origin, token_1)}";
${mode};
document.body.appendChild(script);
`);
send(w_credentialless_token, `
let script = document.createElement("script");
script.src = "${showRequestHeaders(origin, token_2)}";
${mode};
document.body.appendChild(script);
`);
const headers_control = JSON.parse(await receive(token_1));
const headers_credentialless = JSON.parse(await receive(token_2));
assert_equals(parseCookies(headers_control)[cookie_key],
expected_cookies_control,
"coep:none => ");
assert_equals(parseCookies(headers_credentialless)[cookie_key],
expected_cookies_credentialless,
"coep:credentialless => ");
}, `script ${description}`)
};
// Same-origin request always contains Cookies:
scriptTest("same-origin + undefined",
same_origin, '',
cookie_same_origin,
cookie_same_origin);
scriptTest("same-origin + anonymous",
same_origin, 'script.crossOrigin="anonymous"',
cookie_same_origin,
cookie_same_origin);
scriptTest("same-origin + use-credentials",
same_origin, 'script.crossOrigin="use-credentials"',
cookie_same_origin,
cookie_same_origin);
// Cross-origin request contains cookies in the following cases:
// - COEP:credentialless is not set.
// - script.crossOrigin is `use-credentials`.
scriptTest("cross-origin + undefined",
cross_origin, '',
cookie_cross_origin,
undefined);
scriptTest("cross-origin + anonymous",
cross_origin, 'script.crossOrigin="anonymous"',
undefined,
undefined);
scriptTest("cross-origin + use-credentials",
cross_origin, 'script.crossOrigin="use-credentials"',
cookie_cross_origin,
cookie_cross_origin);
}, "Main");
}