From 7394a2fe26213f475bb993f7ed942c740e19c649 Mon Sep 17 00:00:00 2001 From: Blink WPT Bot Date: Tue, 22 Oct 2024 13:42:50 +0000 Subject: [PATCH] Bug 1925636 [wpt PR 48701] - Reland "Fenced frame: Fix some WPTs in headless mode.", a=testonly Automatic update from web-platform-tests Reland "Fenced frame: Fix some WPTs in headless mode." (#48701) The original CL was crashing in an instance where multiClick() was invoked without an await. This fixes the crash by awaiting the clicks instead of continuing with/finishing the test before all the clicks have propagated inside navigate-ancestor-test-runner.https.html. Original change's description: > Fenced frame: Fix some WPTs in headless mode. > > There is currently a push to allow Chromium web platform tests to run > in headless mode (i.e. without a content shell). This requires some > changes to how fenced frame tests work. Headless mode does not support > test_driver functions from inside of fenced frames, as those require > access to the main frame's window to pass the message onto, which > fenced frames deliberately block for privacy reasons. This CL fixes > some of the tests that fail in headless mode by moving those > test_driver calls to the main frame, specifically clicking actions > (which we already have multiClick() to handle this in main frames), > and set_permission(). > > See the headless mode explainer: > https://chromium.googlesource.com/chromium/src/+/HEAD/headless/README.md > > Change-Id: Iab82a581b67f8f8851c7716a2d72caf566f3b2ae > Bug: 366257368 > Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5935060 > Reviewed-by: Andrew Verge > Commit-Queue: Liam Brady > Cr-Commit-Position: refs/heads/main@{#1370151} Bug: 366257368 Change-Id: Id998687c2f3de41a7b0dcd5197ba74fb22ef979e Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5938155 Reviewed-by: Andrew Verge Commit-Queue: Liam Brady Cr-Commit-Position: refs/heads/main@{#1370703} Co-authored-by: Liam Brady -- wpt-commits: f50cf7fbd84ccdf90f6973b8ce7d75175adb3dc1 wpt-pr: 48701 --- ...tomatic-beacon-two-events-clear.https.html | 7 ++-- ...matic-beacon-two-events-persist.https.html | 7 ++-- ...ument-picture-in-picture-denied.https.html | 2 +- .../tests/fenced-frame/download.https.html | 10 ++++- .../tests/fenced-frame/hid.https.html | 2 +- .../notify-event-prevent-caching.https.html | 4 +- .../permission-geolocation.https.html | 1 + .../resources/download-inner.html | 8 ++-- .../navigate-ancestor-helper.https.html | 4 -- .../navigate-ancestor-test-runner.https.html | 15 ++++++-- .../permission-geolocation-test-runner.html | 1 - .../sandboxed-features-inner.sub.html | 3 -- .../resources/sandboxed-features.js | 8 +++- .../tests/fenced-frame/resources/utils.js | 17 +++------ .../resources/web-bluetooth-inner.html | 38 +++++++++---------- .../resources/web-share-inner.html | 20 +++++----- .../sandboxed-features-pointerlock.https.html | 3 ++ .../show-directory-picker.https.html | 2 +- .../show-open-file-picker.https.html | 2 +- .../fenced-frame/web-bluetooth.https.html | 5 ++- .../tests/fenced-frame/web-share.https.html | 5 ++- 21 files changed, 88 insertions(+), 76 deletions(-) diff --git a/testing/web-platform/tests/fenced-frame/automatic-beacon-two-events-clear.https.html b/testing/web-platform/tests/fenced-frame/automatic-beacon-two-events-clear.https.html index 3533cf58c00aa..076911861a504 100644 --- a/testing/web-platform/tests/fenced-frame/automatic-beacon-two-events-clear.https.html +++ b/testing/web-platform/tests/fenced-frame/automatic-beacon-two-events-clear.https.html @@ -14,7 +14,6 @@ + + + @@ -26,11 +29,16 @@ // The download link is clicked inside the fenced frame after the loading const fenced_frame_url = generateURL("resources/download-inner.html", [download_key, download_ack_key]) + `&type=${type}`; - attachFencedFrame(fenced_frame_url); + const fenced_frame = attachFencedFrame(fenced_frame_url); const response = await nextValueFromServer(download_ack_key); assert_equals(response, 'Triggered the action for download'); + // Clicks must originate from the primary frame. + if (type === "anchor") { + await multiClick(20, 20, fenced_frame); + } + const result = await VerifyDownload(t, download_key); assert_false(result, 'Expect no download to happen'); }, description); diff --git a/testing/web-platform/tests/fenced-frame/hid.https.html b/testing/web-platform/tests/fenced-frame/hid.https.html index 762ed6715a6a1..7b3dc8f990037 100644 --- a/testing/web-platform/tests/fenced-frame/hid.https.html +++ b/testing/web-platform/tests/fenced-frame/hid.https.html @@ -14,8 +14,8 @@ - - - + + + - - - diff --git a/testing/web-platform/tests/fenced-frame/resources/sandboxed-features.js b/testing/web-platform/tests/fenced-frame/resources/sandboxed-features.js index 1cbd4a48f3092..9770dd22a92ce 100644 --- a/testing/web-platform/tests/fenced-frame/resources/sandboxed-features.js +++ b/testing/web-platform/tests/fenced-frame/resources/sandboxed-features.js @@ -16,6 +16,12 @@ const run_in_fenced_frame = (func_name, description, is_nested) => { frame.remove(); }); document.body.appendChild(frame); + // The test_pointer_lock() function expects the frame to be user activated. + // This is done at this point because headless mode WPTs do not support + // testdriver functions from within fenced frames. + if (func_name == "test_pointer_lock") { + await multiClick(10, 10, document.body); + } assert_equals(await nextValueFromServer(key), 'done'); }, description); }; @@ -105,8 +111,6 @@ async function test_screen_orientation_lock() { } async function test_pointer_lock() { - await simulateGesture(); - const canvas = document.createElement('canvas'); document.body.appendChild(canvas); const pointerlockerror_promise = new Promise(resolve => { diff --git a/testing/web-platform/tests/fenced-frame/resources/utils.js b/testing/web-platform/tests/fenced-frame/resources/utils.js index c4807c58aee02..bf0cb2f53c51a 100644 --- a/testing/web-platform/tests/fenced-frame/resources/utils.js +++ b/testing/web-platform/tests/fenced-frame/resources/utils.js @@ -520,9 +520,11 @@ async function stringToStashKey(string) { // Create a fenced frame. Then navigate it using the given `target`, which can // be either an urn:uuid or a fenced frame config object. function attachFencedFrame(target) { - assert_implements( - window.HTMLFencedFrameElement, - 'The HTMLFencedFrameElement should be exposed on the window object'); + if (window.test_driver) { + assert_implements( + window.HTMLFencedFrameElement, + 'The HTMLFencedFrameElement should be exposed on the window object'); + } const fenced_frame = document.createElement('fencedframe'); @@ -628,15 +630,6 @@ async function writeValueToServer(key, value, origin = '') { await fetch(serverURL, {"mode": "no-cors"}); } -// Simulates a user gesture. -async function simulateGesture() { - // Wait until the window size is initialized. - while (window.innerWidth == 0) { - await new Promise(resolve => requestAnimationFrame(resolve)); - } - await test_driver.bless('simulate gesture'); -} - // Fenced frames are always put in the public IP address space which is the // least privileged. In case a navigation to a local data: URL or blob: URL // resource is allowed, they would only be able to fetch things that are *also* diff --git a/testing/web-platform/tests/fenced-frame/resources/web-bluetooth-inner.html b/testing/web-platform/tests/fenced-frame/resources/web-bluetooth-inner.html index 3236886b97899..a490bc2127df1 100644 --- a/testing/web-platform/tests/fenced-frame/resources/web-bluetooth-inner.html +++ b/testing/web-platform/tests/fenced-frame/resources/web-bluetooth-inner.html @@ -1,7 +1,4 @@ - - - Fenced frame content to test Web Bluetooth @@ -9,25 +6,26 @@ diff --git a/testing/web-platform/tests/fenced-frame/resources/web-share-inner.html b/testing/web-platform/tests/fenced-frame/resources/web-share-inner.html index aada6f04e1a6c..eb80587b78257 100644 --- a/testing/web-platform/tests/fenced-frame/resources/web-share-inner.html +++ b/testing/web-platform/tests/fenced-frame/resources/web-share-inner.html @@ -1,21 +1,19 @@ - - - Fenced frame content to test Web Share diff --git a/testing/web-platform/tests/fenced-frame/sandboxed-features-pointerlock.https.html b/testing/web-platform/tests/fenced-frame/sandboxed-features-pointerlock.https.html index af598798b2eb6..9a7f21c1044a2 100644 --- a/testing/web-platform/tests/fenced-frame/sandboxed-features-pointerlock.https.html +++ b/testing/web-platform/tests/fenced-frame/sandboxed-features-pointerlock.https.html @@ -5,6 +5,9 @@ + + + + @@ -13,8 +14,10 @@ promise_test(async t => { const bluetooth_request_device_key = token(); - attachFencedFrame(generateURL('resources/web-bluetooth-inner.html', + const fenced_frame = attachFencedFrame( + generateURL('resources/web-bluetooth-inner.html', [bluetooth_request_device_key])); + await multiClick(10, 10, fenced_frame); const result = await nextValueFromServer(bluetooth_request_device_key); assert_equals( diff --git a/testing/web-platform/tests/fenced-frame/web-share.https.html b/testing/web-platform/tests/fenced-frame/web-share.https.html index 13d182b2d1097..f2644f58fd6e1 100644 --- a/testing/web-platform/tests/fenced-frame/web-share.https.html +++ b/testing/web-platform/tests/fenced-frame/web-share.https.html @@ -4,6 +4,7 @@ + @@ -13,8 +14,10 @@ promise_test(async t => { const navigator_share_key = token(); - attachFencedFrame(generateURL('resources/web-share-inner.html', + const fenced_frame = attachFencedFrame( + generateURL('resources/web-share-inner.html', [navigator_share_key])); + await multiClick(10, 10, fenced_frame); const result = await nextValueFromServer(navigator_share_key); assert_equals(