blob: cbe13af820798a1a88300cea92ea2bf843b77933 [file] [log] [blame]
<!DOCTYPE html>
<meta charset="utf-8">
<title>A non-isolated child at a given origin causes future children to also be non-isolated even after the iframe is removed</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<div id="log"></div>
<script type="module">
import {
insertIframe,
testSameAgentCluster,
testDifferentAgentClusters,
testGetter
} from "./resources/helpers.mjs";
let frame1;
promise_setup(async () => {
frame1 = await insertIframe("{{hosts[][www]}}");
});
// Since they're different-origin, the parent's isolation request is respected,
// as is the child's non-request. So the parent ends up in the origin-keyed
// agent cluster and the child ends up in the site-keyed one.
testDifferentAgentClusters([self, 0], "Before");
testGetter(self, true, "parent");
testGetter(0, false, "child1");
promise_test(async () => {
frame1.remove();
await insertIframe("{{hosts[][www]}}", "?1");
await insertIframe("{{hosts[][www1]}}");
}, "Remove the iframe and insert new ones");
// Because of the historical presence of a non-isolated {{hosts[][www]}} iframe,
// the origin isolation request for child 2 will be ignored. So,
// child 2 and child 3 both end up in the site-keyed agent cluster.
testDifferentAgentClusters([self, 0], "Parent to child2");
testDifferentAgentClusters([self, 1], "Parent to child3");
testSameAgentCluster([0, 1], "child2 to child3");
testSameAgentCluster([1, 0], "child3 to child2");
testGetter(0, false, "child2");
testGetter(1, false, "child3");
</script>