From 43a97878ce14b72f0981164f87f2e35e14151312 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 11:22:09 +0200 Subject: Adding upstream version 110.0.1. Signed-off-by: Daniel Baumann --- .../navigation-api/focus-reset/autofocus.html | 185 +++++++++++++++++++++ .../tests/navigation-api/focus-reset/basic.html | 63 +++++++ ...hange-focus-again-in-blur-during-intercept.html | 35 ++++ ...nge-focus-back-to-origial-during-intercept.html | 36 ++++ .../focus-reset/change-focus-during-intercept.html | 34 ++++ .../change-focus-then-remove-during-intercept.html | 40 +++++ .../focus-reset/multiple-intercept.html | 69 ++++++++ .../focus-reset/resources/helpers.mjs | 73 ++++++++ 8 files changed, 535 insertions(+) create mode 100644 testing/web-platform/tests/navigation-api/focus-reset/autofocus.html create mode 100644 testing/web-platform/tests/navigation-api/focus-reset/basic.html create mode 100644 testing/web-platform/tests/navigation-api/focus-reset/change-focus-again-in-blur-during-intercept.html create mode 100644 testing/web-platform/tests/navigation-api/focus-reset/change-focus-back-to-origial-during-intercept.html create mode 100644 testing/web-platform/tests/navigation-api/focus-reset/change-focus-during-intercept.html create mode 100644 testing/web-platform/tests/navigation-api/focus-reset/change-focus-then-remove-during-intercept.html create mode 100644 testing/web-platform/tests/navigation-api/focus-reset/multiple-intercept.html create mode 100644 testing/web-platform/tests/navigation-api/focus-reset/resources/helpers.mjs (limited to 'testing/web-platform/tests/navigation-api/focus-reset') diff --git a/testing/web-platform/tests/navigation-api/focus-reset/autofocus.html b/testing/web-platform/tests/navigation-api/focus-reset/autofocus.html new file mode 100644 index 0000000000..6044447367 --- /dev/null +++ b/testing/web-platform/tests/navigation-api/focus-reset/autofocus.html @@ -0,0 +1,185 @@ + + + + + + + diff --git a/testing/web-platform/tests/navigation-api/focus-reset/basic.html b/testing/web-platform/tests/navigation-api/focus-reset/basic.html new file mode 100644 index 0000000000..f5a30972b0 --- /dev/null +++ b/testing/web-platform/tests/navigation-api/focus-reset/basic.html @@ -0,0 +1,63 @@ + + + + + + + diff --git a/testing/web-platform/tests/navigation-api/focus-reset/change-focus-again-in-blur-during-intercept.html b/testing/web-platform/tests/navigation-api/focus-reset/change-focus-again-in-blur-during-intercept.html new file mode 100644 index 0000000000..a7339c9788 --- /dev/null +++ b/testing/web-platform/tests/navigation-api/focus-reset/change-focus-again-in-blur-during-intercept.html @@ -0,0 +1,35 @@ + + + + + + diff --git a/testing/web-platform/tests/navigation-api/focus-reset/change-focus-back-to-origial-during-intercept.html b/testing/web-platform/tests/navigation-api/focus-reset/change-focus-back-to-origial-during-intercept.html new file mode 100644 index 0000000000..4e5b9dfb6a --- /dev/null +++ b/testing/web-platform/tests/navigation-api/focus-reset/change-focus-back-to-origial-during-intercept.html @@ -0,0 +1,36 @@ + + + + + + diff --git a/testing/web-platform/tests/navigation-api/focus-reset/change-focus-during-intercept.html b/testing/web-platform/tests/navigation-api/focus-reset/change-focus-during-intercept.html new file mode 100644 index 0000000000..0593231a39 --- /dev/null +++ b/testing/web-platform/tests/navigation-api/focus-reset/change-focus-during-intercept.html @@ -0,0 +1,34 @@ + + + + + + diff --git a/testing/web-platform/tests/navigation-api/focus-reset/change-focus-then-remove-during-intercept.html b/testing/web-platform/tests/navigation-api/focus-reset/change-focus-then-remove-during-intercept.html new file mode 100644 index 0000000000..a5d8062ce0 --- /dev/null +++ b/testing/web-platform/tests/navigation-api/focus-reset/change-focus-then-remove-during-intercept.html @@ -0,0 +1,40 @@ + + + + + + diff --git a/testing/web-platform/tests/navigation-api/focus-reset/multiple-intercept.html b/testing/web-platform/tests/navigation-api/focus-reset/multiple-intercept.html new file mode 100644 index 0000000000..75e38c98a4 --- /dev/null +++ b/testing/web-platform/tests/navigation-api/focus-reset/multiple-intercept.html @@ -0,0 +1,69 @@ + + + + + + + diff --git a/testing/web-platform/tests/navigation-api/focus-reset/resources/helpers.mjs b/testing/web-platform/tests/navigation-api/focus-reset/resources/helpers.mjs new file mode 100644 index 0000000000..0a8a0439e1 --- /dev/null +++ b/testing/web-platform/tests/navigation-api/focus-reset/resources/helpers.mjs @@ -0,0 +1,73 @@ +// Usage note: if you use these more than once in a given file, be sure to +// clean up any navigate event listeners, e.g. by using { once: true }, between +// tests. + +const TAB_KEY = "\uE004"; + +export function testFocusWasReset(setupFunc, description) { + promise_test(async t => { + setupFunc(t); + + const button = document.body.appendChild(document.createElement("button")); + const button2 = document.body.appendChild(document.createElement("button")); + button2.tabIndex = 0; + t.add_cleanup(() => { + button.remove(); + button2.remove(); + }); + + assert_equals(document.activeElement, document.body, "Start on body"); + button.focus(); + assert_equals(document.activeElement, button, "focus() worked"); + + const { committed, finished } = navigation.navigate("#" + location.hash.substring(1) + "1"); + + await committed; + assert_equals(document.activeElement, button, "Focus stays on the button during the transition"); + + await finished.catch(() => {}); + assert_equals(document.activeElement, document.body, "Focus reset after the transition"); + + button2.onfocus = t.unreached_func("button2 must not be focused after pressing Tab"); + const focusPromise = waitForFocus(t, button); + await test_driver.send_keys(document.body, TAB_KEY); + await focusPromise; + }, description); +} + +export function testFocusWasNotReset(setupFunc, description) { + promise_test(async t => { + setupFunc(t); + + const button = document.body.appendChild(document.createElement("button")); + const button2 = document.body.appendChild(document.createElement("button")); + button2.tabIndex = 0; + t.add_cleanup(() => { + button.remove(); + button2.remove(); + }); + + assert_equals(document.activeElement, document.body, "Start on body"); + button.focus(); + assert_equals(document.activeElement, button, "focus() worked"); + + const { committed, finished } = navigation.navigate("#" + location.hash.substring(1) + "1"); + + await committed; + assert_equals(document.activeElement, button, "Focus stays on the button during the transition"); + + await finished.catch(() => {}); + assert_equals(document.activeElement, button, "Focus stays on the button after the transition"); + + button.onfocus = t.unreached_func("button must not be focused after pressing Tab"); + const focusPromise = waitForFocus(t, button2); + await test_driver.send_keys(document.body, TAB_KEY); + await focusPromise; + }, description); +} + +function waitForFocus(t, target) { + return new Promise(resolve => { + target.addEventListener("focus", () => resolve(), { once: true }); + }); +} -- cgit v1.2.3