Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[DRAFT - DO NOT REVIEW YET] WB-1671: Dropdown: use combobox role in all openers #2345

Open
wants to merge 9 commits into
base: main
Choose a base branch
from
5 changes: 5 additions & 0 deletions .changeset/tasty-rockets-mix.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"@khanacademy/wonder-blocks-dropdown": patch
---

Update dropdown openers to use `role="combobox"` instead of `button`.
Original file line number Diff line number Diff line change
Expand Up @@ -77,7 +77,7 @@ describe("MultiSelect", () => {
const {userEvent} = doRender(uncontrolledMultiSelect);

// Act
await userEvent.click(await screen.findByRole("button"));
await userEvent.click(await screen.findByRole("combobox"));

// Assert
expect(
Expand Down Expand Up @@ -109,7 +109,7 @@ describe("MultiSelect", () => {
doRender(uncontrolledMultiSelect);

// Act
const opener = await screen.findByRole("button");
const opener = await screen.findByRole("combobox");

// Assert
// No items are selected, display placeholder because there is one
Expand All @@ -133,7 +133,7 @@ describe("MultiSelect", () => {
);

// Assert
expect(await screen.findByRole("button")).toHaveTextContent(
expect(await screen.findByRole("combobox")).toHaveTextContent(
"item 1",
);
});
Expand All @@ -155,7 +155,7 @@ describe("MultiSelect", () => {
);

// Assert
expect(await screen.findByRole("button")).toHaveTextContent(
expect(await screen.findByRole("combobox")).toHaveTextContent(
"1 student",
);
});
Expand All @@ -177,7 +177,7 @@ describe("MultiSelect", () => {
);

// Assert
expect(await screen.findByRole("button")).toHaveTextContent(
expect(await screen.findByRole("combobox")).toHaveTextContent(
"Choose",
);
});
Expand All @@ -200,7 +200,7 @@ describe("MultiSelect", () => {

// Assert
// More than one item is selected, display n itemTypes
expect(await screen.findByRole("button")).toHaveTextContent(
expect(await screen.findByRole("combobox")).toHaveTextContent(
"2 students",
);
});
Expand All @@ -223,7 +223,7 @@ describe("MultiSelect", () => {

// Assert
// All items are selected
expect(await screen.findByRole("button")).toHaveTextContent(
expect(await screen.findByRole("combobox")).toHaveTextContent(
"All students",
);
});
Expand All @@ -246,7 +246,7 @@ describe("MultiSelect", () => {
);

// Assert
expect(await screen.findByRole("button")).toHaveTextContent(
expect(await screen.findByRole("combobox")).toHaveTextContent(
"All students",
);
});
Expand All @@ -265,7 +265,7 @@ describe("MultiSelect", () => {
);

// Act
const opener = await screen.findByRole("button");
const opener = await screen.findByRole("combobox");

// Assert
expect(opener).toHaveAttribute("data-testid", "some-test-id");
Expand Down Expand Up @@ -552,7 +552,7 @@ describe("MultiSelect", () => {

const {userEvent} = doRender(<ControlledMultiSelect />);

const opener = await screen.findByRole("button");
const opener = await screen.findByRole("combobox");
await userEvent.click(opener);

// Act
Expand Down Expand Up @@ -625,7 +625,7 @@ describe("MultiSelect", () => {
// Arrange
const {userEvent} = doRender(filterableMultiSelect);
// open the dropdown menu
await userEvent.click(await screen.findByRole("button"));
await userEvent.click(await screen.findByRole("combobox"));

// Act
const searchInput = await screen.findByPlaceholderText("Filter");
Expand All @@ -638,7 +638,7 @@ describe("MultiSelect", () => {
// Arrange
const {userEvent} = doRender(filterableMultiSelect);
// open the dropdown menu
await userEvent.click(await screen.findByRole("button"));
await userEvent.click(await screen.findByRole("combobox"));

const searchInput = await screen.findByPlaceholderText("Filter");

Expand All @@ -655,7 +655,7 @@ describe("MultiSelect", () => {
// Arrange
const {userEvent} = doRender(filterableMultiSelect);
// open the dropdown menu
await userEvent.click(await screen.findByRole("button"));
await userEvent.click(await screen.findByRole("combobox"));

const searchInput = await screen.findByPlaceholderText("Filter");

Expand Down Expand Up @@ -686,7 +686,7 @@ describe("MultiSelect", () => {

// Act
// open the dropdown menu
await userEvent.click(await screen.findByRole("button"));
await userEvent.click(await screen.findByRole("combobox"));

// Assert
expect(
Expand All @@ -709,7 +709,7 @@ describe("MultiSelect", () => {
</MultiSelect>,
);
// open the dropdown menu
await userEvent.click(await screen.findByRole("button"));
await userEvent.click(await screen.findByRole("combobox"));

const searchInput = await screen.findByPlaceholderText("Filter");

Expand All @@ -724,7 +724,7 @@ describe("MultiSelect", () => {
// Arrange
const {userEvent} = doRender(filterableMultiSelect);
// open the dropdown menu
await userEvent.click(await screen.findByRole("button"));
await userEvent.click(await screen.findByRole("combobox"));

// Act
const searchInput = await screen.findByPlaceholderText("Filter");
Expand All @@ -751,7 +751,7 @@ describe("MultiSelect", () => {

// Act
// open the dropdown menu
await userEvent.click(await screen.findByRole("button"));
await userEvent.click(await screen.findByRole("combobox"));

// Assert
expect(
Expand All @@ -775,7 +775,7 @@ describe("MultiSelect", () => {
</MultiSelect>,
);

await userEvent.click(await screen.findByRole("button"));
await userEvent.click(await screen.findByRole("combobox"));

const searchInput = await screen.findByPlaceholderText("Filter");
await userEvent.type(searchInput, "Item 2");
Expand Down Expand Up @@ -807,7 +807,7 @@ describe("MultiSelect", () => {
</MultiSelect>,
);
// open the dropdown menu
await userEvent.click(await screen.findByRole("button"));
await userEvent.click(await screen.findByRole("combobox"));

const searchInput = await screen.findByPlaceholderText("Filter");
await userEvent.type(searchInput, "some text");
Expand All @@ -824,7 +824,7 @@ describe("MultiSelect", () => {
// Arrange
const {userEvent} = doRender(filterableMultiSelect);
// open the dropdown menu
await userEvent.click(await screen.findByRole("button"));
await userEvent.click(await screen.findByRole("combobox"));

const searchInput = await screen.findByPlaceholderText("Filter");
await userEvent.type(searchInput, "Should be cleared");
Expand All @@ -842,7 +842,7 @@ describe("MultiSelect", () => {
// Arrange
const {userEvent} = doRender(filterableMultiSelect);
// open the dropdown menu
const opener = await screen.findByRole("button");
const opener = await screen.findByRole("combobox");
await userEvent.click(opener);

const searchInput = await screen.findByPlaceholderText("Filter");
Expand Down Expand Up @@ -1462,7 +1462,7 @@ describe("MultiSelect", () => {
rerender(<TranslatedComponent labels={updatedLabels} />);

// Act
const opener = await screen.findByRole("button");
const opener = await screen.findByRole("combobox");
// open dropdown
await userEvent.click(opener);

Expand Down Expand Up @@ -1682,7 +1682,7 @@ describe("MultiSelect", () => {

// Act
// Press the button
const button = await screen.findByRole("button");
const button = await screen.findByRole("combobox");
// NOTE: we need to use fireEvent here because await userEvent doesn't
// support keyUp/Down events and we use these handlers to override
// the default behavior of the button.
Expand Down Expand Up @@ -1710,7 +1710,7 @@ describe("MultiSelect", () => {

// Act
// Press the button
const button = await screen.findByRole("button");
const button = await screen.findByRole("combobox");
// NOTE: we need to use fireEvent here because await userEvent doesn't
// support keyUp/Down events and we use these handlers to override
// the default behavior of the button.
Expand Down Expand Up @@ -1825,7 +1825,7 @@ describe("MultiSelect", () => {
);

// Act
const opener = await screen.findByRole("button");
const opener = await screen.findByRole("combobox");

// Assert
expect(opener).toHaveAttribute("id", expect.any(String));
Expand All @@ -1842,7 +1842,7 @@ describe("MultiSelect", () => {
);

// Act
const opener = await screen.findByRole("button");
const opener = await screen.findByRole("combobox");

// Assert
expect(opener).toHaveAttribute("id", id);
Expand All @@ -1859,7 +1859,7 @@ describe("MultiSelect", () => {

// Act
// Open the dropdown
const opener = await screen.findByRole("button");
const opener = await screen.findByRole("combobox");
await userEvent.click(opener);

// Assert
Expand All @@ -1880,7 +1880,7 @@ describe("MultiSelect", () => {

// Act
// Open the dropdown
const opener = await screen.findByRole("button");
const opener = await screen.findByRole("combobox");
await userEvent.click(opener);

// Assert
Expand All @@ -1902,7 +1902,7 @@ describe("MultiSelect", () => {
);

// Act
const opener = await screen.findByRole("button");
const opener = await screen.findByRole("combobox");
await userEvent.click(opener);
const dropdown = await screen.findByRole("listbox", {hidden: true});

Expand All @@ -1921,7 +1921,7 @@ describe("MultiSelect", () => {
);

// Act
const opener = await screen.findByRole("button");
const opener = await screen.findByRole("combobox");
await userEvent.click(opener);
const dropdown = await screen.findByRole("listbox", {hidden: true});

Expand Down Expand Up @@ -1992,7 +1992,7 @@ describe("MultiSelect", () => {
);

// Act
const opener = await screen.findByRole("button");
const opener = await screen.findByRole("combobox");

// Assert
expect(opener).toHaveAttribute("aria-haspopup", "listbox");
Expand Down Expand Up @@ -2031,7 +2031,7 @@ describe("MultiSelect", () => {
);

// Act
const opener = await screen.findByRole("button");
const opener = await screen.findByRole("combobox");

// Assert
expect(opener).toHaveAttribute("aria-expanded", "false");
Expand All @@ -2047,7 +2047,7 @@ describe("MultiSelect", () => {
);

// Act
const opener = await screen.findByRole("button");
const opener = await screen.findByRole("combobox");
await userEvent.click(opener);

// Assert
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ describe("SelectOpener", () => {

// Act
// Press the button.
await userEvent.click(await screen.findByRole("button"));
await userEvent.click(await screen.findByRole("combobox"));

// Assert
expect(onOpenMock).toHaveBeenCalledTimes(1);
Expand All @@ -51,7 +51,7 @@ describe("SelectOpener", () => {

// Act
// Press the button.
const button = await screen.findByRole("button");
const button = await screen.findByRole("combobox");
// NOTE: we need to use fireEvent here because await userEvent doesn't
// support keyUp/Down events and we use these handlers to override
// the default behavior of the button.
Expand Down Expand Up @@ -87,7 +87,7 @@ describe("SelectOpener", () => {

// Act
// Press the button.
const button = await screen.findByRole("button");
const button = await screen.findByRole("combobox");
// NOTE: we need to use fireEvent here because await userEvent doesn't
// support keyUp/Down events and we use these handlers to override
// the default behavior of the button.
Expand Down Expand Up @@ -131,7 +131,7 @@ describe("SelectOpener", () => {

// Act
// Press the button.
await userEvent.click(await screen.findByRole("button"));
await userEvent.click(await screen.findByRole("combobox"));

// Assert
expect(onOpenMock).toHaveBeenCalledTimes(0);
Expand All @@ -156,7 +156,7 @@ describe("SelectOpener", () => {

// Act
// Press the button.
const button = await screen.findByRole("button");
const button = await screen.findByRole("combobox");
// NOTE: we need to use fireEvent here because await userEvent doesn't
// support keyUp/Down events and we use these handlers to override
// the default behavior of the button.
Expand Down Expand Up @@ -192,7 +192,7 @@ describe("SelectOpener", () => {

// Act
// Press the button.
const button = await screen.findByRole("button");
const button = await screen.findByRole("combobox");
// NOTE: we need to use fireEvent here because await userEvent doesn't
// support keyUp/Down events and we use these handlers to override
// the default behavior of the button.
Expand Down
Loading
Loading