Skip to content

Commit

Permalink
test: added test for BasePicker (#83)
Browse files Browse the repository at this point in the history
  • Loading branch information
anuraghazra authored Oct 9, 2020
1 parent 7295695 commit 02f7d87
Show file tree
Hide file tree
Showing 2 changed files with 136 additions and 0 deletions.
109 changes: 109 additions & 0 deletions src/picker-base/__tests__/BasePicker.tests.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,109 @@
import * as React from "react";
import { axe, render, press, fireEvent } from "reakit-test-utils";

import {
PickerBase,
PickerBaseContent,
PickerBaseTrigger,
usePickerBaseState,
PickerBaseInitialState,
} from "..";

const PickerBaseComp: React.FC<PickerBaseInitialState> = props => {
const state = usePickerBaseState({
...props,
pickerId: "picker-1",
dialogId: "dialog-1",
baseId: "picker-test",
});

return (
<>
<PickerBase aria-label="picker base" {...state}>
<PickerBaseTrigger {...state}>open</PickerBaseTrigger>
</PickerBase>
<PickerBaseContent data-testid="picker-content" {...state}>
Content
</PickerBaseContent>
</>
);
};

describe("PickerBase", () => {
test("should render correctly", () => {
const { getByText: text, baseElement } = render(
<PickerBaseComp visible={true} />,
);

expect(baseElement).toMatchInlineSnapshot(`
<body
style="padding-right: 1024px; overflow: hidden;"
>
<div>
<div
aria-expanded="true"
aria-haspopup="dialog"
aria-label="picker base"
aria-owns="dialog-1"
id="picker-1"
role="button"
>
<div
aria-controls="picker-test"
aria-expanded="true"
aria-haspopup="dialog"
role="button"
tabindex="-1"
>
open
</div>
</div>
</div>
<div
aria-hidden="true"
class="__reakit-focus-trap"
style="position: fixed;"
tabindex="0"
/>
<div
class="__reakit-portal"
>
<div
aria-modal="true"
data-dialog="true"
data-testid="picker-content"
id="dialog-1"
role="dialog"
tabindex="-1"
>
Content
</div>
</div>
<div
aria-hidden="true"
class="__reakit-focus-trap"
style="position: fixed;"
tabindex="0"
/>
</body>
`);
});

it("should open/close properly", () => {
const { getByText: text, getByTestId: testId } = render(<PickerBaseComp />);

expect(testId("picker-content")).not.toBeVisible();
fireEvent.click(text("open"));
expect(testId("picker-content")).toBeVisible();

press.Escape();
expect(testId("picker-content")).not.toBeVisible();
});

test("PickerBase renders with no a11y violations", async () => {
const { container } = render(<PickerBaseComp />);
const results = await axe(container);

expect(results).toHaveNoViolations();
});
});
27 changes: 27 additions & 0 deletions src/picker-base/stories/BasePicker.stories.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
import * as React from "react";
import { Meta } from "@storybook/react";

import { PickerBase, PickerBaseContent, PickerBaseTrigger } from "../index";
import { PickerBaseInitialState, usePickerBaseState } from "../PickerBaseState";

export default {
title: "Component/PickerBase",
} as Meta;

const PickerBaseComp: React.FC<PickerBaseInitialState> = props => {
const state = usePickerBaseState({
...props,
});

return (
<>
<PickerBase {...state}>
<PickerBaseTrigger {...state}>open</PickerBaseTrigger>
</PickerBase>
<PickerBaseContent {...state}>Content</PickerBaseContent>
</>
);
};

export const Default = () => <PickerBaseComp />;
export const Visible = () => <PickerBaseComp visible={true} />;

0 comments on commit 02f7d87

Please sign in to comment.