Skip to content

Commit

Permalink
Add more tests for directionality of <bdi> element.
Browse files Browse the repository at this point in the history
This adds tests related to whatwg/html#10005
  • Loading branch information
dbaron committed Jan 9, 2024
1 parent 2fcb60d commit 05d2a06
Showing 1 changed file with 32 additions and 0 deletions.
32 changes: 32 additions & 0 deletions html/dom/elements/global-attributes/dir-assorted.window.js
Original file line number Diff line number Diff line change
Expand Up @@ -80,3 +80,35 @@ test(() => {
assert_false(e1.matches(":dir(ltr)"), "parent is RTL after changing text in child");
assert_false(e2.matches(":dir(ltr)"), "child is RTL after changing text in child");
}, "text changes apply to dir=auto on further ancestor after removing dir=auto from closer ancestor");

for const bdi_test of [
{ markup: "<bdi dir=ltr>A</bdi>", expected: "ltr", desc: "dir=ltr with LTR contents" },
{ markup: "<bdi dir=ltr>\u05d0</bdi>", expected: "ltr", desc: "dir=ltr with RTL contents" },
{ markup: "<bdi dir=ltr></bdi>", expected: "ltr", desc: "dir=ltr empty" },
{ markup: "<bdi dir=rtl>A</bdi>", expected: "rtl", desc: "dir=rtl with LTR contents" },
{ markup: "<bdi dir=rtl>\u05d0</bdi>", expected: "rtl", desc: "dir=rtl with RTL contents" },
{ markup: "<bdi dir=rtl></bdi>", expected: "rtl", desc: "dir=rtl empty" },
{ markup: "<bdi dir=auto>A</bdi>", expected: "ltr", desc: "dir=auto with LTR contents" },
{ markup: "<bdi dir=auto>\u05d0</bdi>", expected: "rtl", desc: "dir=auto with RTL contents" },
{ markup: "<bdi dir=auto></bdi>", expected: "parent", desc: "dir=auto empty" },
{ markup: "<bdi>A</bdi>", expected: "ltr", desc: "no dir attribute with LTR contents" },
{ markup: "<bdi>\u05d0</bdi>", expected: "rtl", desc: "no dir attribute with RTL contents" },
{ markup: "<bdi></bdi>", expected: "parent", desc: "no dir attribute empty" },
]) {
for const parent_dir of [ "ltr", "rtl" ] {
test(() => {
const parent_element = document.createElement("div");
document.body.appendChild(parent_element);
parent_element.innerHTML = bdi_test.markup;
const bdi_element = parent_element.querySelector("bdi");
let expected = bdi_test.expected;
if (expected == "parent") {
expected = parent_dir;
}
const not_expected = (expected == "ltr") ? "rtl" : "ltr";
assert_true(bdi_element.matches(`:dir(${expected})`));
assert_false(bdi_element.matches(`:dir(${not_expected})`));
parent_element.remove();
, `directionality of bdi elements: ${bdi_test.desc} in ${parent_dir} parent`);
}
}

0 comments on commit 05d2a06

Please sign in to comment.