Skip to content

Commit

Permalink
#4 - test: reduce flakyness of tests
Browse files Browse the repository at this point in the history
  • Loading branch information
svenvandescheur committed Jan 15, 2024
1 parent a444195 commit f82fdb3
Show file tree
Hide file tree
Showing 4 changed files with 55 additions and 25 deletions.
27 changes: 27 additions & 0 deletions .storybook/test-runner.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
const { getStoryContext } = require("@storybook/test-runner");
const { MINIMAL_VIEWPORTS } = require("@storybook/addon-viewport");

const DEFAULT_VP_SIZE = { width: 1280, height: 720 };

module.exports = {
/**
* This makes sure the test runner respects the viewport.
* @see {@link https://github.com/storybookjs/test-runner/issues/85#issuecomment-1576465128|[Bug] Tests always run in the default viewport}
* @param page
* @param story
*/
async preRender(page, story) {
const context = await getStoryContext(page, story);
const vpName =
context.parameters?.viewport?.defaultViewport ?? "responsive";
const vpParams = MINIMAL_VIEWPORTS[vpName];

if (vpParams) {
const width = parseInt(vpParams.styles.width);
const height = parseInt(vpParams.styles.height);
page.setViewportSize({ width, height });
} else {
page.setViewportSize(DEFAULT_VP_SIZE);
}
},
};
35 changes: 19 additions & 16 deletions src/components/dropdown/dropdown.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import type { Meta, StoryObj } from "@storybook/react";
import { expect, userEvent, within } from "@storybook/test";
import { expect, userEvent, waitFor, within } from "@storybook/test";
import React from "react";

import { Button, ButtonLink } from "../button";
Expand All @@ -19,19 +19,20 @@ const meta = {

// Click opens, escape closes.
await userEvent.click(button, { delay: 10 });
expect(await canvas.findByRole("dialog")).toBeVisible();
await expect(canvas.getByRole("dialog")).toBeVisible();
userEvent.keyboard("{Escape}");
expect(await canvas.findByRole("dialog")).not.toBeVisible();
await waitFor(() => expect(canvas.queryByRole("dialog")).toBeNull());
await userEvent.click(button, { delay: 10 });
expect(await canvas.findByRole("dialog")).toBeVisible();
await expect(canvas.getByRole("dialog")).toBeVisible();

// Tab focuses items.
await userEvent.tab({ delay: 10 });
await userEvent.tab({ delay: 10 });
await userEvent.tab({ delay: 10 });

const buttons = await canvas.findAllByRole("button");
expect(buttons[buttons.length - 1]).toBe(document.activeElement);
expect(canvas.getAllByRole("dialog").findLast((v) => v)).toContainElement(
document.activeElement as HTMLElement,
);
},
} satisfies Meta<typeof Dropdown>;

Expand Down Expand Up @@ -102,19 +103,20 @@ export const ActivateOnHover: Story = {

// Click opens, escape closes.
await userEvent.hover(button, { delay: 10 });
expect(await canvas.findByRole("dialog")).toBeVisible();
await expect(canvas.getByRole("dialog")).toBeVisible();
userEvent.keyboard("{Escape}");
expect(await canvas.findByRole("dialog")).not.toBeVisible();
await waitFor(() => expect(canvas.queryByRole("dialog")).toBeNull());
await userEvent.hover(button, { delay: 10 });
expect(await canvas.findByRole("dialog")).toBeVisible();
await expect(canvas.getByRole("dialog")).toBeVisible();

// Tab focuses items.
await userEvent.tab({ delay: 10 });
await userEvent.tab({ delay: 10 });
await userEvent.tab({ delay: 10 });

const buttons = await canvas.findAllByRole("button");
expect(buttons[buttons.length - 1]).toBe(document.activeElement);
expect(canvas.getByRole("dialog")).toContainElement(
document.activeElement as HTMLElement,
);
},
};

Expand All @@ -125,20 +127,21 @@ export const ActivateOnFocus: Story = {

// Click opens, escape closes.
await userEvent.tab({ delay: 10 });
expect(await canvas.findByRole("dialog")).toBeVisible();
await expect(canvas.getByRole("dialog")).toBeVisible();
userEvent.keyboard("{Escape}");
expect(await canvas.findByRole("dialog")).not.toBeVisible();
await waitFor(() => expect(canvas.queryByRole("dialog")).toBeNull());
await userEvent.tab({ shift: true, delay: 10 });
await userEvent.tab({ delay: 10 });
expect(await canvas.findByRole("dialog")).toBeVisible();
await expect(canvas.getByRole("dialog")).toBeVisible();

// Tab focuses items.
await userEvent.tab({ delay: 10 });
await userEvent.tab({ delay: 10 });
await userEvent.tab({ delay: 10 });

const buttons = await canvas.findAllByRole("button");
expect(buttons[buttons.length - 1]).toBe(document.activeElement);
expect(canvas.getByRole("dialog")).toContainElement(
document.activeElement as HTMLElement,
);
},
};

Expand Down
15 changes: 8 additions & 7 deletions src/components/navbar/navbar.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import type { Meta, StoryObj } from "@storybook/react";
import { expect, userEvent, within } from "@storybook/test";
import { expect, userEvent, waitFor, within } from "@storybook/test";
import React from "react";

import { Button, ButtonLink } from "../button";
Expand Down Expand Up @@ -57,18 +57,19 @@ export const NavbarOnMobile: Story = {

// Click opens, escape closes.
await userEvent.click(button, { delay: 10 });
expect(await canvas.findByRole("dialog")).toBeVisible();
userEvent.keyboard("{Escape}");
expect(await canvas.findByRole("dialog")).not.toBeVisible();
await expect(canvas.getByRole("dialog")).toBeVisible();
userEvent.keyboard("{Escape}", { delay: 10 });
await waitFor(() => expect(canvas.queryByRole("dialog")).toBeNull());
await userEvent.click(button, { delay: 10 });
expect(await canvas.findByRole("dialog")).toBeVisible();
await expect(canvas.getByRole("dialog")).toBeVisible();

// Tab focuses items.
await userEvent.tab({ delay: 10 });
await userEvent.tab({ delay: 10 });
await userEvent.tab({ delay: 10 });

const buttons = await canvas.findAllByRole("button");
expect(buttons[buttons.length - 1]).toBe(document.activeElement);
expect(canvas.getByRole("dialog")).toContainElement(
document.activeElement as HTMLElement,
);
},
};
3 changes: 1 addition & 2 deletions src/components/navbar/navbar.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,9 +15,8 @@ export type NavbarProps = ToolbarProps;
*/
export const Navbar: React.FC<NavbarProps> = ({ children, ...props }) => {
const [isMobile, setIsMobile] = useState(
window?.matchMedia("(max-width: 767px)").matches,
window?.matchMedia("(max-width: 767px)").matches ?? true,
);

/**
* Updates `isMobile` on resize.
*/
Expand Down

0 comments on commit f82fdb3

Please sign in to comment.