| // META: script=/common/get-host-info.sub.js |
| // META: script=/common/dispatcher/dispatcher.js |
| // META: script=/html/cross-origin-embedder-policy/credentialless/resources/common.js |
| |
| const {ORIGIN} = get_host_info(); |
| |
| promise_test_parallel(async t => { |
| const iframe = document.createElement("iframe"); |
| iframe.src = ORIGIN + "/common/blank.html?pipe=status(204)"; |
| iframe.credentialless = false; |
| document.body.appendChild(iframe); |
| iframe.credentialless = true; |
| iframe.contentWindow.modified = true; |
| iframe.src = ORIGIN + "/common/blank.html"; |
| // Wait for navigation to complete. |
| await new Promise(resolve => iframe.onload = resolve); |
| assert_true(iframe.credentialless); |
| assert_true(iframe.contentWindow.credentialless); |
| assert_equals(undefined, iframe.contentWindow.modified); |
| }, "Credentialless (false => true) => window not reused."); |
| |
| promise_test_parallel(async t => { |
| const iframe = document.createElement("iframe"); |
| iframe.src = ORIGIN + "/common/blank.html?pipe=status(204)"; |
| iframe.credentialless = true; |
| document.body.appendChild(iframe); |
| iframe.credentialless = false; |
| iframe.contentWindow.modified = true; |
| iframe.src = ORIGIN + "/common/blank.html"; |
| // Wait for navigation to complete. |
| await new Promise(resolve => iframe.onload = resolve); |
| assert_false(iframe.credentialless); |
| assert_false(iframe.contentWindow.credentialless); |
| assert_equals(undefined, iframe.contentWindow.modified); |
| }, "Credentialless (true => false) => window not reused."); |
| |
| promise_test_parallel(async t => { |
| const iframe = document.createElement("iframe"); |
| iframe.credentialless = true; |
| iframe.src = ORIGIN + "/common/blank.html?pipe=status(204)"; |
| document.body.appendChild(iframe); |
| iframe.credentialless = true; |
| iframe.contentWindow.modified = true; |
| iframe.src = ORIGIN + "/common/blank.html"; |
| // Wait for navigation to complete. |
| await new Promise(resolve => iframe.onload = resolve); |
| assert_true(iframe.credentialless); |
| assert_true(iframe.contentWindow.credentialless); |
| assert_true(iframe.contentWindow.modified); |
| }, "Credentialless (true => true) => window reused."); |