Source code
Revision control
Copy as Markdown
Other Tools
Test Info: Warnings
- This test has a WPT meta file that expects 1 subtest issues.
- This WPT test may be referenced by the following Test IDs:
- /html/user-activation/navigation-state-reset-crossorigin.sub.html - WPT Dashboard Interop Dashboard
<!DOCTYPE html>
<html>
<head>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src="/resources/testdriver.js"></script>
<script src="/resources/testdriver-vendor.js"></script>
<script src="resources/utils.js"></script>
</head>
<body>
<h1>Post-navigation activation state in child</h1>
<p>Tests that navigating a cross-origin child frame resets its activation states.</p>
<ol id="instructions">
<li>Click inside the yellow area.
</ol>
<iframe id="child" width="200" height="50">
</iframe>
<script>
async_test(function(t) {
var child = document.getElementById("child");
child.src = "http://{{hosts[alt][]}}:{{ports[http][0]}}/html/user-activation/resources/child-one.html";
window.addEventListener("message", t.step_func(event => {
// Test driver can send messages too...
if (typeof event.data !== "string") return;
var msg = JSON.parse(event.data);
if (msg.type == 'child-one-loaded') {
assert_false(navigator.userActivation.isActive);
assert_false(navigator.userActivation.hasBeenActive);
assert_false(msg.isActive);
assert_false(msg.hasBeenActive);
delayByFrames(() => test_driver.click(child), 5);
} else if (msg.type == 'child-one-clicked') {
assert_true(navigator.userActivation.isActive);
assert_true(navigator.userActivation.hasBeenActive);
assert_true(msg.isActive);
assert_true(msg.hasBeenActive);
child.src = "http://{{hosts[alt][]}}:{{ports[http][1]}}/html/user-activation/resources/child-two.html";
} else if (msg.type == 'child-two-loaded') {
assert_true(navigator.userActivation.isActive);
assert_true(navigator.userActivation.hasBeenActive);
assert_false(msg.isActive);
assert_false(msg.hasBeenActive);
t.done();
}
}));
}, "Post-navigation state reset.");
</script>
</body>
</html>