summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/wai-aria/scripts/aria-utils.js
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-07 19:33:14 +0000
commit36d22d82aa202bb199967e9512281e9a53db42c9 (patch)
tree105e8c98ddea1c1e4784a60a5a6410fa416be2de /testing/web-platform/tests/wai-aria/scripts/aria-utils.js
parentInitial commit. (diff)
downloadfirefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.tar.xz
firefox-esr-36d22d82aa202bb199967e9512281e9a53db42c9.zip
Adding upstream version 115.7.0esr.upstream/115.7.0esr
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'testing/web-platform/tests/wai-aria/scripts/aria-utils.js')
-rw-r--r--testing/web-platform/tests/wai-aria/scripts/aria-utils.js117
1 files changed, 117 insertions, 0 deletions
diff --git a/testing/web-platform/tests/wai-aria/scripts/aria-utils.js b/testing/web-platform/tests/wai-aria/scripts/aria-utils.js
new file mode 100644
index 0000000000..e6411a9a0e
--- /dev/null
+++ b/testing/web-platform/tests/wai-aria/scripts/aria-utils.js
@@ -0,0 +1,117 @@
+/* Utilities related to WAI-ARIA */
+
+const AriaUtils = {
+
+ /*
+ Tests simple role assignment: <div role="alert">x</div>
+ Not intended for nested, context-dependent, or other complex role tests.
+
+ Ex: AriaUtils.assignAndVerifyRolesByRoleNames(["group", "main", "button"])
+
+ */
+ assignAndVerifyRolesByRoleNames: function(roleNames) {
+ if (!Array.isArray(roleNames) || !roleNames.length) {
+ throw `Param roleNames of assignAndVerifyRolesByRoleNames("${roleNames}") should be an array containing at least one role string.`;
+ }
+ for (const role of roleNames) {
+ promise_test(async t => {
+ let el = document.createElement("div");
+ el.appendChild(document.createTextNode("x"));
+ el.setAttribute("role", role); // el.role not yet supported by Gecko.
+ el.id = `role_${role}`;
+ document.body.appendChild(el);
+ const computedRole = await test_driver.get_computed_role(document.getElementById(el.id));
+ assert_equals(computedRole, role, el.outerHTML);
+ }, `role: ${role}`);
+ }
+ },
+
+
+ /*
+ Tests computed ROLE of all elements matching selector
+ against the string value of their data-expectedrole attribute.
+
+ Ex: <div role="list"
+ data-testname="optional unique test name"
+ data-expectedrole="list"
+ class="ex">
+
+ AriaUtils.verifyRolesBySelector(".ex")
+
+ */
+ verifyRolesBySelector: function(selector) {
+ const els = document.querySelectorAll(selector);
+ if (!els.length) {
+ throw `Selector passed in verifyRolesBySelector("${selector}") should match at least one element.`;
+ }
+ for (const el of els) {
+ let role = el.getAttribute("data-expectedrole");
+ let testName = el.getAttribute("data-testname") || role; // data-testname optional if role is unique per test file
+ promise_test(async t => {
+ const expectedRole = el.getAttribute("data-expectedrole");
+
+ // ensure ID existence and uniqueness for the webdriver callback
+ if (!el.id) {
+ let roleCount = 1;
+ let elID = `${expectedRole}${roleCount}`;
+ while(document.getElementById(elID)) {
+ roleCount++;
+ elID = `${expectedRole}${roleCount}`;
+ }
+ el.id = elID;
+ }
+
+ const computedRole = await test_driver.get_computed_role(document.getElementById(el.id));
+ assert_equals(computedRole, expectedRole, el.outerHTML);
+ }, `${testName}`);
+ }
+ },
+
+
+ /*
+ Tests computed LABEL of all elements matching selector
+ against the string value of their data-expectedlabel attribute.
+
+ Ex: <div aria-label="foo"
+ data-testname="optional unique test name"
+ data-expectedlabel="foo"
+ class="ex">
+
+ AriaUtils.verifyLabelsBySelector(".ex")
+
+ */
+ verifyLabelsBySelector: function(selector) {
+ const els = document.querySelectorAll(selector);
+ if (!els.length) {
+ throw `Selector passed in verifyLabelsBySelector("${selector}") should match at least one element.`;
+ }
+ for (const el of els) {
+ let label = el.getAttribute("data-expectedlabel");
+ let testName = el.getAttribute("data-testname") || label; // data-testname optional if label is unique per test file
+ promise_test(async t => {
+ const expectedLabel = el.getAttribute("data-expectedlabel");
+
+ // ensure ID existence and uniqueness for the webdriver callback
+ if (!el.id) {
+ let labelCount = 1;
+ let elID = `labelTest${labelCount}`;
+ while(document.getElementById(elID)) {
+ labelCount++;
+ elID = `labelTest${labelCount}`;
+ }
+ el.id = elID;
+ }
+
+ let computedLabel = await test_driver.get_computed_label(el);
+
+ // Todo: Remove whitespace normalization after https://github.com/w3c/accname/issues/192 is addressed. Change prior line back to `const`, too.
+ computedLabel = computedLabel.trim()
+
+ assert_equals(computedLabel, expectedLabel, el.outerHTML);
+ }, `${testName}`);
+ }
+ },
+
+
+};
+