Skip to content

Commit

Permalink
chore(themed): fix issue where class-based matching would not work du…
Browse files Browse the repository at this point in the history
…e to resolved class value (#11203)

**Related Issue:** N/A

## Summary

This fixes an issue in the `themed` test util where elements with
multiple classes weren’t matched using strict equality.

**Note**: this also simplifies shadow DOM querying logic
  • Loading branch information
jcfranco authored Jan 7, 2025
1 parent 2e8ed8a commit 04875f7
Showing 1 changed file with 18 additions and 17 deletions.
35 changes: 18 additions & 17 deletions packages/calcite-components/src/tests/commonTests/themed.ts
Original file line number Diff line number Diff line change
Expand Up @@ -275,29 +275,29 @@ async function assertThemedProps(page: E2EPage, options: TestTarget): Promise<vo
if (contextSelector) {
const rect = (await page.evaluate((context: TestTarget["contextSelector"]) => {
const searchInShadowDom = (node: Node): HTMLElement | SVGElement | Node | undefined => {
const { attribute, value } = context as {
const { attribute, value: valueToMatch } = context as {
attribute: string;
value: string;
};
if (node.nodeType === 1) {
const attr = (node as Element).getAttribute(attribute);
if (typeof value === "string" && attr === value) {
return node;
}
if (attr === value) {
return node;
}

if ((node as Element) && !attribute && !value) {
return node;
if (node.nodeType === 1) {
const el = node as Element;
const attrValue = el.getAttribute(attribute);

if (
(attribute === "class" && el.classList.contains(valueToMatch)) ||
(attrValue === valueToMatch) ||
(!attribute && !valueToMatch)
) {
return el;
}
}

if (node.nodeType === 1 && (node as Element).shadowRoot) {
for (const child of (node as Element).shadowRoot.children) {
const result = searchInShadowDom(child);
if (result) {
return result;
if (el.shadowRoot) {
for (const child of el.shadowRoot.children) {
const result = searchInShadowDom(child);
if (result) {
return result;
}
}
}
}
Expand All @@ -309,6 +309,7 @@ async function assertThemedProps(page: E2EPage, options: TestTarget): Promise<vo
}
}
};

return new Promise<{ width: number; height: number; left: number; top: number } | undefined>((resolve) => {
requestAnimationFrame(() => {
const foundNode =
Expand Down

0 comments on commit 04875f7

Please sign in to comment.