mirror of
https://github.com/elastic/kibana.git
synced 2025-04-24 01:38:56 -04:00
[jest] fix errors and warnings (#85291)
* replace deprecated 'wait' with 'waitFor' * add required 'initialPageSize' field * fix '.getContext() is not implemented' error * wrapping code with act * replace deprecated 'wait' with 'waitFor' * fix 'state update on an unmounted component' warning
This commit is contained in:
parent
92db24e00c
commit
0d682a95bd
12 changed files with 68 additions and 48 deletions
|
@ -492,6 +492,7 @@ exports[`renders empty page in before initial fetch to avoid flickering 1`] = `
|
|||
findItems={[Function]}
|
||||
headingId="dashboardListingHeading"
|
||||
initialFilter=""
|
||||
initialPageSize={10}
|
||||
listingLimit={1000}
|
||||
noItemsFragment={
|
||||
<div>
|
||||
|
|
|
@ -62,6 +62,7 @@ test('renders empty page in before initial fetch to avoid flickering', () => {
|
|||
getViewUrl={() => {}}
|
||||
listingLimit={1000}
|
||||
hideWriteControls={false}
|
||||
initialPageSize={10}
|
||||
core={{ notifications: { toasts: {} }, uiSettings: { get: jest.fn(() => 10) } }}
|
||||
/>
|
||||
);
|
||||
|
|
|
@ -18,7 +18,7 @@
|
|||
*/
|
||||
|
||||
import React from 'react';
|
||||
import { wait } from '@testing-library/dom';
|
||||
import { waitFor } from '@testing-library/dom';
|
||||
import { render } from '@testing-library/react';
|
||||
import {
|
||||
HelloWorldEmbeddable,
|
||||
|
@ -47,7 +47,7 @@ describe('<EmbeddableRenderer/>', () => {
|
|||
<EmbeddableRenderer factory={getFactory()} input={{ id: 'hello' }} />
|
||||
);
|
||||
expect(getByTestId('embedSpinner')).toBeInTheDocument();
|
||||
await wait(() => !queryByTestId('embedSpinner')); // wait until spinner disappears
|
||||
await waitFor(() => !queryByTestId('embedSpinner')); // wait until spinner disappears
|
||||
expect(getByTestId('helloWorldEmbeddable')).toBeInTheDocument();
|
||||
});
|
||||
});
|
||||
|
|
|
@ -17,7 +17,7 @@
|
|||
* under the License.
|
||||
*/
|
||||
import React from 'react';
|
||||
import { wait, render } from '@testing-library/react';
|
||||
import { waitFor, render } from '@testing-library/react';
|
||||
import { ErrorEmbeddable } from './error_embeddable';
|
||||
import { EmbeddableRoot } from './embeddable_root';
|
||||
|
||||
|
@ -26,7 +26,7 @@ test('ErrorEmbeddable renders an embeddable', async () => {
|
|||
const { getByTestId, getByText } = render(<EmbeddableRoot embeddable={embeddable} />);
|
||||
|
||||
expect(getByTestId('embeddableStackError')).toBeVisible();
|
||||
await wait(() => getByTestId('errorMessageMarkdown')); // wait for lazy markdown component
|
||||
await waitFor(() => getByTestId('errorMessageMarkdown')); // wait for lazy markdown component
|
||||
expect(getByText(/some error occurred/i)).toBeVisible();
|
||||
});
|
||||
|
||||
|
@ -36,7 +36,7 @@ test('ErrorEmbeddable renders an embeddable with markdown message', async () =>
|
|||
const { getByTestId, getByText } = render(<EmbeddableRoot embeddable={embeddable} />);
|
||||
|
||||
expect(getByTestId('embeddableStackError')).toBeVisible();
|
||||
await wait(() => getByTestId('errorMessageMarkdown')); // wait for lazy markdown component
|
||||
await waitFor(() => getByTestId('errorMessageMarkdown')); // wait for lazy markdown component
|
||||
expect(getByText(/some link/i)).toMatchInlineSnapshot(`
|
||||
<a
|
||||
href="http://localhost:5601/takeMeThere"
|
||||
|
|
|
@ -101,8 +101,9 @@ describe('useRequest hook', () => {
|
|||
const { setupSuccessRequest, completeRequest, hookResult } = helpers;
|
||||
setupSuccessRequest();
|
||||
expect(hookResult.isInitialRequest).toBe(true);
|
||||
|
||||
hookResult.resendRequest();
|
||||
act(() => {
|
||||
hookResult.resendRequest();
|
||||
});
|
||||
await completeRequest();
|
||||
expect(hookResult.isInitialRequest).toBe(false);
|
||||
});
|
||||
|
|
|
@ -49,6 +49,8 @@ interface State {
|
|||
* React component for displaying the example data associated with the Telemetry opt-in banner.
|
||||
*/
|
||||
export class OptInExampleFlyout extends React.PureComponent<Props, State> {
|
||||
_isMounted = false;
|
||||
|
||||
public readonly state: State = {
|
||||
data: null,
|
||||
isLoading: true,
|
||||
|
@ -56,14 +58,18 @@ export class OptInExampleFlyout extends React.PureComponent<Props, State> {
|
|||
};
|
||||
|
||||
async componentDidMount() {
|
||||
this._isMounted = true;
|
||||
|
||||
try {
|
||||
const { fetchExample } = this.props;
|
||||
const clusters = await fetchExample();
|
||||
this.setState({
|
||||
data: Array.isArray(clusters) ? clusters : null,
|
||||
isLoading: false,
|
||||
hasPrivilegeToRead: true,
|
||||
});
|
||||
if (this._isMounted) {
|
||||
this.setState({
|
||||
data: Array.isArray(clusters) ? clusters : null,
|
||||
isLoading: false,
|
||||
hasPrivilegeToRead: true,
|
||||
});
|
||||
}
|
||||
} catch (err) {
|
||||
this.setState({
|
||||
isLoading: false,
|
||||
|
@ -72,6 +78,10 @@ export class OptInExampleFlyout extends React.PureComponent<Props, State> {
|
|||
}
|
||||
}
|
||||
|
||||
componentWillUnmount() {
|
||||
this._isMounted = false;
|
||||
}
|
||||
|
||||
renderBody({ data, isLoading, hasPrivilegeToRead }: State) {
|
||||
if (isLoading) {
|
||||
return loadingSpinner;
|
||||
|
|
|
@ -18,7 +18,7 @@
|
|||
*/
|
||||
|
||||
import React from 'react';
|
||||
import { wait, render } from '@testing-library/react';
|
||||
import { waitFor, render } from '@testing-library/react';
|
||||
import MarkdownVisComponent from './markdown_vis_controller';
|
||||
|
||||
describe('markdown vis controller', () => {
|
||||
|
@ -36,7 +36,7 @@ describe('markdown vis controller', () => {
|
|||
<MarkdownVisComponent {...vis.params} renderComplete={jest.fn()} />
|
||||
);
|
||||
|
||||
await wait(() => getByTestId('markdownBody'));
|
||||
await waitFor(() => getByTestId('markdownBody'));
|
||||
|
||||
expect(getByText('markdown')).toMatchInlineSnapshot(`
|
||||
<a
|
||||
|
@ -60,7 +60,7 @@ describe('markdown vis controller', () => {
|
|||
<MarkdownVisComponent {...vis.params} renderComplete={jest.fn()} />
|
||||
);
|
||||
|
||||
await wait(() => getByTestId('markdownBody'));
|
||||
await waitFor(() => getByTestId('markdownBody'));
|
||||
|
||||
expect(getByText(/testing/i)).toMatchInlineSnapshot(`
|
||||
<p>
|
||||
|
@ -82,7 +82,7 @@ describe('markdown vis controller', () => {
|
|||
<MarkdownVisComponent {...vis.params} renderComplete={jest.fn()} />
|
||||
);
|
||||
|
||||
await wait(() => getByTestId('markdownBody'));
|
||||
await waitFor(() => getByTestId('markdownBody'));
|
||||
|
||||
expect(getByText(/initial/i)).toBeInTheDocument();
|
||||
|
||||
|
@ -112,7 +112,7 @@ describe('markdown vis controller', () => {
|
|||
<MarkdownVisComponent {...vis.params} renderComplete={renderComplete} />
|
||||
);
|
||||
|
||||
await wait(() => getByTestId('markdownBody'));
|
||||
await waitFor(() => getByTestId('markdownBody'));
|
||||
|
||||
expect(renderComplete).toHaveBeenCalledTimes(1);
|
||||
});
|
||||
|
@ -122,7 +122,7 @@ describe('markdown vis controller', () => {
|
|||
<MarkdownVisComponent {...vis.params} renderComplete={renderComplete} />
|
||||
);
|
||||
|
||||
await wait(() => getByTestId('markdownBody'));
|
||||
await waitFor(() => getByTestId('markdownBody'));
|
||||
|
||||
expect(renderComplete).toHaveBeenCalledTimes(1);
|
||||
|
||||
|
@ -139,7 +139,7 @@ describe('markdown vis controller', () => {
|
|||
<MarkdownVisComponent {...vis.params} renderComplete={renderComplete} />
|
||||
);
|
||||
|
||||
await wait(() => getByTestId('markdownBody'));
|
||||
await waitFor(() => getByTestId('markdownBody'));
|
||||
|
||||
expect(renderComplete).toHaveBeenCalledTimes(1);
|
||||
|
||||
|
|
|
@ -17,6 +17,8 @@
|
|||
* under the License.
|
||||
*/
|
||||
|
||||
import 'jest-canvas-mock';
|
||||
|
||||
import $ from 'jquery';
|
||||
|
||||
import 'leaflet/dist/leaflet.js';
|
||||
|
|
|
@ -25,6 +25,7 @@ import { EuiButtonGroup } from '@elastic/eui';
|
|||
|
||||
import { VisLegend, VisLegendProps } from './legend';
|
||||
import { legendColors } from './models';
|
||||
import { act } from '@testing-library/react';
|
||||
|
||||
jest.mock('@elastic/eui', () => {
|
||||
const original = jest.requireActual('@elastic/eui');
|
||||
|
@ -206,7 +207,9 @@ describe('VisLegend Component', () => {
|
|||
const first = getLegendItems(wrapper).first();
|
||||
first.simulate('click');
|
||||
const filterGroup = wrapper.find(EuiButtonGroup).first();
|
||||
filterGroup.getElement().props.onChange('filterIn');
|
||||
act(() => {
|
||||
filterGroup.getElement().props.onChange('filterIn');
|
||||
});
|
||||
|
||||
expect(fireEvent).toHaveBeenCalledWith({
|
||||
name: 'filterBucket',
|
||||
|
@ -219,7 +222,9 @@ describe('VisLegend Component', () => {
|
|||
const first = getLegendItems(wrapper).first();
|
||||
first.simulate('click');
|
||||
const filterGroup = wrapper.find(EuiButtonGroup).first();
|
||||
filterGroup.getElement().props.onChange('filterOut');
|
||||
act(() => {
|
||||
filterGroup.getElement().props.onChange('filterOut');
|
||||
});
|
||||
|
||||
expect(fireEvent).toHaveBeenCalledWith({
|
||||
name: 'filterBucket',
|
||||
|
|
|
@ -7,7 +7,7 @@
|
|||
import { EuiButton, EuiCheckboxProps } from '@elastic/eui';
|
||||
import { ReactWrapper } from 'enzyme';
|
||||
import React from 'react';
|
||||
import { wait } from '@testing-library/react';
|
||||
import { waitFor } from '@testing-library/react';
|
||||
|
||||
import { mountWithIntl } from '@kbn/test/jest';
|
||||
import { ConfirmAlterActiveSpaceModal } from './confirm_alter_active_space_modal';
|
||||
|
@ -70,7 +70,7 @@ describe('ManageSpacePage', () => {
|
|||
/>
|
||||
);
|
||||
|
||||
await wait(() => {
|
||||
await waitFor(() => {
|
||||
wrapper.update();
|
||||
expect(wrapper.find('input[name="name"]')).toHaveLength(1);
|
||||
});
|
||||
|
@ -132,7 +132,7 @@ describe('ManageSpacePage', () => {
|
|||
/>
|
||||
);
|
||||
|
||||
await wait(() => {
|
||||
await waitFor(() => {
|
||||
wrapper.update();
|
||||
expect(spacesManager.getSpace).toHaveBeenCalledWith('existing-space');
|
||||
});
|
||||
|
@ -185,7 +185,7 @@ describe('ManageSpacePage', () => {
|
|||
/>
|
||||
);
|
||||
|
||||
await wait(() => {
|
||||
await waitFor(() => {
|
||||
wrapper.update();
|
||||
expect(notifications.toasts.addError).toHaveBeenCalledWith(error, {
|
||||
title: 'Error loading available features',
|
||||
|
@ -223,7 +223,7 @@ describe('ManageSpacePage', () => {
|
|||
/>
|
||||
);
|
||||
|
||||
await wait(() => {
|
||||
await waitFor(() => {
|
||||
wrapper.update();
|
||||
expect(spacesManager.getSpace).toHaveBeenCalledWith('my-space');
|
||||
});
|
||||
|
@ -285,7 +285,7 @@ describe('ManageSpacePage', () => {
|
|||
/>
|
||||
);
|
||||
|
||||
await wait(() => {
|
||||
await waitFor(() => {
|
||||
wrapper.update();
|
||||
expect(spacesManager.getSpace).toHaveBeenCalledWith('my-space');
|
||||
});
|
||||
|
|
|
@ -13,7 +13,7 @@ import { SpacesManager } from '../spaces_manager';
|
|||
import { NavControlPopover } from './nav_control_popover';
|
||||
import { EuiHeaderSectionItemButton } from '@elastic/eui';
|
||||
import { mountWithIntl } from '@kbn/test/jest';
|
||||
import { wait } from '@testing-library/react';
|
||||
import { waitFor } from '@testing-library/react';
|
||||
|
||||
describe('NavControlPopover', () => {
|
||||
it('renders without crashing', () => {
|
||||
|
@ -65,7 +65,7 @@ describe('NavControlPopover', () => {
|
|||
wrapper.find(EuiHeaderSectionItemButton).simulate('click');
|
||||
|
||||
// Wait for `getSpaces` promise to resolve
|
||||
await wait(() => {
|
||||
await waitFor(() => {
|
||||
wrapper.update();
|
||||
expect(wrapper.find(SpaceAvatar)).toHaveLength(3);
|
||||
});
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
*/
|
||||
|
||||
import React from 'react';
|
||||
import { fireEvent, render, wait, cleanup } from '@testing-library/react';
|
||||
import { fireEvent, render, waitFor, cleanup } from '@testing-library/react';
|
||||
import { createFlyoutManageDrilldowns } from './connected_flyout_manage_drilldowns';
|
||||
import {
|
||||
mockGetTriggerInfo,
|
||||
|
@ -50,7 +50,7 @@ test('Allows to manage drilldowns', async () => {
|
|||
);
|
||||
|
||||
// wait for initial render. It is async because resolving compatible action factories is async
|
||||
await wait(() => expect(screen.getByText(/Manage Drilldowns/i)).toBeVisible());
|
||||
await waitFor(() => expect(screen.getByText(/Manage Drilldowns/i)).toBeVisible());
|
||||
|
||||
// no drilldowns in the list
|
||||
expect(screen.queryAllByTestId(TEST_SUBJ_DRILLDOWN_ITEM)).toHaveLength(0);
|
||||
|
@ -87,7 +87,7 @@ test('Allows to manage drilldowns', async () => {
|
|||
|
||||
expect(screen.getByText(/Manage Drilldowns/i)).toBeVisible();
|
||||
|
||||
await wait(() => expect(screen.queryAllByTestId(TEST_SUBJ_DRILLDOWN_ITEM)).toHaveLength(1));
|
||||
await waitFor(() => expect(screen.queryAllByTestId(TEST_SUBJ_DRILLDOWN_ITEM)).toHaveLength(1));
|
||||
expect(screen.getByText(name)).toBeVisible();
|
||||
const editButton = screen.getByText(/edit/i);
|
||||
fireEvent.click(editButton);
|
||||
|
@ -105,14 +105,14 @@ test('Allows to manage drilldowns', async () => {
|
|||
fireEvent.click(screen.getByText(/save/i));
|
||||
|
||||
expect(screen.getByText(/Manage Drilldowns/i)).toBeVisible();
|
||||
await wait(() => screen.getByText(newName));
|
||||
await waitFor(() => screen.getByText(newName));
|
||||
|
||||
// delete drilldown from edit view
|
||||
fireEvent.click(screen.getByText(/edit/i));
|
||||
fireEvent.click(screen.getByText(/delete/i));
|
||||
|
||||
expect(screen.getByText(/Manage Drilldowns/i)).toBeVisible();
|
||||
await wait(() => expect(screen.queryAllByTestId(TEST_SUBJ_DRILLDOWN_ITEM)).toHaveLength(0));
|
||||
await waitFor(() => expect(screen.queryAllByTestId(TEST_SUBJ_DRILLDOWN_ITEM)).toHaveLength(0));
|
||||
});
|
||||
|
||||
test('Can delete multiple drilldowns', async () => {
|
||||
|
@ -123,7 +123,7 @@ test('Can delete multiple drilldowns', async () => {
|
|||
/>
|
||||
);
|
||||
// wait for initial render. It is async because resolving compatible action factories is async
|
||||
await wait(() => expect(screen.getByText(/Manage Drilldowns/i)).toBeVisible());
|
||||
await waitFor(() => expect(screen.getByText(/Manage Drilldowns/i)).toBeVisible());
|
||||
|
||||
const createDrilldown = async () => {
|
||||
const oldCount = screen.queryAllByTestId(TEST_SUBJ_DRILLDOWN_ITEM).length;
|
||||
|
@ -136,7 +136,7 @@ test('Can delete multiple drilldowns', async () => {
|
|||
target: { value: 'https://elastic.co' },
|
||||
});
|
||||
fireEvent.click(screen.getAllByText(/Create Drilldown/i)[1]);
|
||||
await wait(() =>
|
||||
await waitFor(() =>
|
||||
expect(screen.queryAllByTestId(TEST_SUBJ_DRILLDOWN_ITEM)).toHaveLength(oldCount + 1)
|
||||
);
|
||||
};
|
||||
|
@ -151,7 +151,7 @@ test('Can delete multiple drilldowns', async () => {
|
|||
expect(screen.queryByText(/Create/i)).not.toBeInTheDocument();
|
||||
fireEvent.click(screen.getByText(/Delete \(3\)/i));
|
||||
|
||||
await wait(() => expect(screen.queryAllByTestId(TEST_SUBJ_DRILLDOWN_ITEM)).toHaveLength(0));
|
||||
await waitFor(() => expect(screen.queryAllByTestId(TEST_SUBJ_DRILLDOWN_ITEM)).toHaveLength(0));
|
||||
});
|
||||
|
||||
test('Create only mode', async () => {
|
||||
|
@ -165,7 +165,7 @@ test('Create only mode', async () => {
|
|||
/>
|
||||
);
|
||||
// wait for initial render. It is async because resolving compatible action factories is async
|
||||
await wait(() => expect(screen.getAllByText(/Create/i).length).toBeGreaterThan(0));
|
||||
await waitFor(() => expect(screen.getAllByText(/Create/i).length).toBeGreaterThan(0));
|
||||
fireEvent.change(screen.getByLabelText(/name/i), {
|
||||
target: { value: 'test' },
|
||||
});
|
||||
|
@ -175,7 +175,7 @@ test('Create only mode', async () => {
|
|||
});
|
||||
fireEvent.click(screen.getAllByText(/Create Drilldown/i)[1]);
|
||||
|
||||
await wait(() => expect(toasts.addSuccess).toBeCalled());
|
||||
await waitFor(() => expect(toasts.addSuccess).toBeCalled());
|
||||
expect(onClose).toBeCalled();
|
||||
expect(await mockDynamicActionManager.state.get().events.length).toBe(1);
|
||||
});
|
||||
|
@ -189,7 +189,7 @@ test('After switching between action factories state is restored', async () => {
|
|||
/>
|
||||
);
|
||||
// wait for initial render. It is async because resolving compatible action factories is async
|
||||
await wait(() => expect(screen.getAllByText(/Create/i).length).toBeGreaterThan(0));
|
||||
await waitFor(() => expect(screen.getAllByText(/Create/i).length).toBeGreaterThan(0));
|
||||
fireEvent.change(screen.getByLabelText(/name/i), {
|
||||
target: { value: 'test' },
|
||||
});
|
||||
|
@ -210,7 +210,7 @@ test('After switching between action factories state is restored', async () => {
|
|||
expect(screen.getByLabelText(/name/i)).toHaveValue('test');
|
||||
|
||||
fireEvent.click(screen.getAllByText(/Create Drilldown/i)[1]);
|
||||
await wait(() => expect(toasts.addSuccess).toBeCalled());
|
||||
await waitFor(() => expect(toasts.addSuccess).toBeCalled());
|
||||
expect(await (mockDynamicActionManager.state.get().events[0].action.config as any).url).toBe(
|
||||
'https://elastic.co'
|
||||
);
|
||||
|
@ -230,7 +230,7 @@ test("Error when can't save drilldown changes", async () => {
|
|||
/>
|
||||
);
|
||||
// wait for initial render. It is async because resolving compatible action factories is async
|
||||
await wait(() => expect(screen.getByText(/Manage Drilldowns/i)).toBeVisible());
|
||||
await waitFor(() => expect(screen.getByText(/Manage Drilldowns/i)).toBeVisible());
|
||||
fireEvent.click(screen.getByText(/Create new/i));
|
||||
fireEvent.change(screen.getByLabelText(/name/i), {
|
||||
target: { value: 'test' },
|
||||
|
@ -240,7 +240,7 @@ test("Error when can't save drilldown changes", async () => {
|
|||
target: { value: 'https://elastic.co' },
|
||||
});
|
||||
fireEvent.click(screen.getAllByText(/Create Drilldown/i)[1]);
|
||||
await wait(() =>
|
||||
await waitFor(() =>
|
||||
expect(toasts.addError).toBeCalledWith(error, { title: toastDrilldownsCRUDError })
|
||||
);
|
||||
});
|
||||
|
@ -254,7 +254,7 @@ test('Should show drilldown welcome message. Should be able to dismiss it', asyn
|
|||
);
|
||||
|
||||
// wait for initial render. It is async because resolving compatible action factories is async
|
||||
await wait(() => expect(screen.getByText(/Manage Drilldowns/i)).toBeVisible());
|
||||
await waitFor(() => expect(screen.getByText(/Manage Drilldowns/i)).toBeVisible());
|
||||
|
||||
expect(screen.getByTestId(WELCOME_MESSAGE_TEST_SUBJ)).toBeVisible();
|
||||
fireEvent.click(screen.getByText(/hide/i));
|
||||
|
@ -268,7 +268,7 @@ test('Should show drilldown welcome message. Should be able to dismiss it', asyn
|
|||
/>
|
||||
);
|
||||
// wait for initial render. It is async because resolving compatible action factories is async
|
||||
await wait(() => expect(screen.getByText(/Manage Drilldowns/i)).toBeVisible());
|
||||
await waitFor(() => expect(screen.getByText(/Manage Drilldowns/i)).toBeVisible());
|
||||
expect(screen.queryByTestId(WELCOME_MESSAGE_TEST_SUBJ)).toBeNull();
|
||||
});
|
||||
|
||||
|
@ -281,7 +281,7 @@ test('Drilldown type is not shown if no supported trigger', async () => {
|
|||
/>
|
||||
);
|
||||
// wait for initial render. It is async because resolving compatible action factories is async
|
||||
await wait(() => expect(screen.getAllByText(/Create/i).length).toBeGreaterThan(0));
|
||||
await waitFor(() => expect(screen.getAllByText(/Create/i).length).toBeGreaterThan(0));
|
||||
expect(screen.queryByText(/Go to Dashboard/i)).not.toBeInTheDocument(); // dashboard action is not visible, because APPLY_FILTER_TRIGGER not supported
|
||||
expect(screen.getByTestId('selectedActionFactory-Url')).toBeInTheDocument();
|
||||
});
|
||||
|
@ -295,7 +295,7 @@ test('Can pick a trigger', async () => {
|
|||
/>
|
||||
);
|
||||
// wait for initial render. It is async because resolving compatible action factories is async
|
||||
await wait(() => expect(screen.getAllByText(/Create/i).length).toBeGreaterThan(0));
|
||||
await waitFor(() => expect(screen.getAllByText(/Create/i).length).toBeGreaterThan(0));
|
||||
|
||||
// input drilldown name
|
||||
const name = 'Test name';
|
||||
|
@ -318,6 +318,6 @@ test('Can pick a trigger', async () => {
|
|||
|
||||
expect(createButton).toBeEnabled();
|
||||
fireEvent.click(createButton);
|
||||
await wait(() => expect(toasts.addSuccess).toBeCalled());
|
||||
await waitFor(() => expect(toasts.addSuccess).toBeCalled());
|
||||
expect(mockDynamicActionManager.state.get().events[0].triggers).toEqual(['SELECT_RANGE_TRIGGER']);
|
||||
});
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue