1 | import { axe } from 'jest-axe';
|
2 | import React from 'react';
|
3 | import renderer from 'react-test-renderer';
|
4 | import { composeStories } from '@storybook/testing-react';
|
5 | import { screen } from '@testing-library/react';
|
6 | import { defaultContext, TypeaheadContext, } from '../core/Context';
|
7 | export { axe };
|
8 | export * from '@storybook/testing-react';
|
9 | export * from '@testing-library/react';
|
10 | export { default as userEvent } from '@testing-library/user-event';
|
11 | export function noop() { }
|
12 | export function prepareSnapshot(element) {
|
13 | return renderer.create(element).toJSON();
|
14 | }
|
15 | export function generateSnapshots(stories) {
|
16 | const composed = composeStories(stories);
|
17 | Object.entries(composed).forEach(([storyName, Story]) => {
|
18 | if (Story.parameters?.snapshot?.skip)
|
19 | return;
|
20 | test(`${storyName} story renders snapshot`, async () => {
|
21 | expect(prepareSnapshot(React.createElement(Story, null))).toMatchSnapshot();
|
22 | });
|
23 | });
|
24 | }
|
25 | export const HintProvider = ({ children, ...context }) => {
|
26 | return (React.createElement(TypeaheadContext.Provider, { value: {
|
27 | ...defaultContext,
|
28 | ...context,
|
29 | } }, children));
|
30 | };
|
31 | export function getHint(container) {
|
32 | return container.getElementsByClassName('rbt-input-hint')[0];
|
33 | }
|
34 | export async function findInput(multiple = false) {
|
35 | const role = multiple ? 'textbox' : 'combobox';
|
36 | return screen.findByRole(role);
|
37 | }
|
38 | export function getInput() {
|
39 | return screen.queryByRole('combobox') || screen.queryByRole('textbox');
|
40 | }
|
41 | export async function findItems() {
|
42 | return screen.findAllByRole('option');
|
43 | }
|
44 | export function getItems() {
|
45 | return screen.getAllByRole('option');
|
46 | }
|
47 | export async function findMenu() {
|
48 | return screen.findByRole('listbox');
|
49 | }
|
50 | export function getMenu() {
|
51 | return screen.queryByRole('listbox');
|
52 | }
|
53 | export async function findPaginator() {
|
54 | const items = await findItems();
|
55 | return items[items.length - 1];
|
56 | }
|
57 | export function getTokens(container) {
|
58 | return container.getElementsByClassName('rbt-token');
|
59 | }
|
60 | export async function waitForOverlay() {
|
61 | await findMenu();
|
62 | }
|