summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/html/user-activation/consumption-crossorigin.sub.tentative.html
diff options
context:
space:
mode:
Diffstat (limited to 'testing/web-platform/tests/html/user-activation/consumption-crossorigin.sub.tentative.html')
-rw-r--r--testing/web-platform/tests/html/user-activation/consumption-crossorigin.sub.tentative.html129
1 files changed, 129 insertions, 0 deletions
diff --git a/testing/web-platform/tests/html/user-activation/consumption-crossorigin.sub.tentative.html b/testing/web-platform/tests/html/user-activation/consumption-crossorigin.sub.tentative.html
new file mode 100644
index 0000000000..ebb1661559
--- /dev/null
+++ b/testing/web-platform/tests/html/user-activation/consumption-crossorigin.sub.tentative.html
@@ -0,0 +1,129 @@
+<!DOCTYPE html>
+<!--
+ Tentative due to:
+ https://github.com/web-platform-tests/wpt/issues/36727
+-->
+<html>
+<head>
+ <meta name="timeout" content="long">
+ <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>
+ <script>
+ // Frame layout:
+ // top=origin0:this-file [
+ // child1=origin1:child-one.html,
+ // child-xo=origin2:consumption-crossorigin-child.html [
+ // gchild=origin3:child-two.html
+ // ]
+ // ]
+ let consumption_test = async_test("Consumption test");
+
+ let num_children_to_load = 3;
+ let num_children_to_report = 3;
+
+ function finishLoadPhase() {
+ assert_equals(num_children_to_load, 0);
+
+ test(() => {
+ assert_false(navigator.userActivation.isActive);
+ assert_false(navigator.userActivation.hasBeenActive);
+ }, "Parent frame initial state");
+
+ delayByFrames(() => test_driver.click(document.getElementById("child1")), 5);
+ // The click at "child-xo" happens after receiving "child-one-clicked" msg.
+ }
+
+ function finishReportPhase() {
+ assert_equals(num_children_to_report, 0);
+
+ test(() => {
+ assert_false(navigator.userActivation.isActive);
+ assert_true(navigator.userActivation.hasBeenActive);
+ }, "Parent frame final state");
+
+ consumption_test.done();
+ }
+
+ window.addEventListener("message", 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') {
+ test(() => {
+ assert_false(msg.isActive);
+ assert_false(msg.hasBeenActive);
+ }, "Child1 frame initial state");
+ } else if (msg.type == 'child-crossorigin-loaded') {
+ test(() => {
+ assert_false(msg.isActive);
+ assert_false(msg.hasBeenActive);
+ }, "Child2 frame initial state");
+ } else if (msg.type == 'child-two-loaded') {
+ test(() => {
+ assert_false(msg.isActive);
+ assert_false(msg.hasBeenActive);
+ }, "Grandchild frame initial state");
+ } else if (msg.type == 'child-one-clicked') {
+ test_driver.click(document.getElementById("child-xo"));
+ } else if (msg.type == 'child-one-report') {
+ test(() => {
+ assert_false(msg.isActive, "Child1 frame isActive");
+ assert_true(msg.hasBeenActive, "Child1 frame hasBeenActive");
+ }, "Child1 frame final state");
+ } else if (msg.type == 'child-crossorigin-report') {
+ // This msg was triggered by a user click followed by a window.open().
+ test(() => {
+ assert_false(msg.isActive);
+ assert_true(msg.hasBeenActive);
+ }, "Child2 frame final state");
+
+ // Ask remaining frames to report states.
+ let ask_report = JSON.stringify({"type": "report"});
+ frames[0].postMessage(ask_report, "*");
+ frames[1].frames[0].postMessage(ask_report, "*");
+ } else if (msg.type == 'child-two-report') {
+ test(() => {
+ assert_false(msg.isActive, "isActive");
+ assert_false(msg.hasBeenActive, "hasBeenActive");
+ }, "Grand child frame final state");
+ }
+
+ // Phase switching.
+ if (msg.type.endsWith("-loaded")) {
+ if (--num_children_to_load == 0)
+ finishLoadPhase();
+ } else if (msg.type.endsWith("-report")) {
+ if (--num_children_to_report == 0)
+ finishReportPhase();
+ }
+ });
+ async function createIframes() {
+ const child1 = document.createElement("iframe");
+ child1.src = "http://{{hosts[alt][]}}:{{ports[http][0]}}/html/user-activation/resources/child-one.html";
+ child1.id = "child1";
+ await new Promise((resolve) => {
+ child1.onload = resolve;
+ document.body.appendChild(child1);
+ });
+ const childXO = document.createElement("iframe");
+ childXO.id = "child-xo";
+ childXO.src = "http://{{hosts[alt][]}}:{{ports[http][1]}}/html/user-activation/resources/consumption-crossorigin-child.sub.html";
+ document.body.appendChild(childXO);
+ }
+ </script>
+</head>
+<body onload="createIframes()">
+ <h1>User activation consumption across cross-origin frame boundary</h1>
+ <p>Tests that user activation consumption resets the transient states in all cross-origin frames.</p>
+ <ol id="instructions">
+ <li>Click anywhere on the yellow area.
+ <li>Click anywhere on the green area (child frame).
+ </ol>
+</body>
+</html>