element-web/test/unit-tests/components/views/dialogs/IntegrationsDisabledDialog-test.tsx
Will Hunt 4d48d1b2f2
Open the proper integration settings on integrations disabled error (#30538)
* Open the proper integration settings on integrations disabled error.

* Convert to functional component.

* Add test

* update snap
2025-09-01 07:30:49 +00:00

47 lines
1.7 KiB
TypeScript

/*
* Copyright 2025 New Vector Ltd.
*
* SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only OR LicenseRef-Element-Commercial
* Please see LICENSE files in the repository root for full details.
*/
import React from "react";
import { fireEvent, render } from "jest-matrix-react";
import { IntegrationsDisabledDialog } from "../../../../../src/components/views/dialogs/IntegrationsDisabledDialog.tsx";
import defaultDispatcher from "../../../../../src/dispatcher/dispatcher.ts";
import { Action } from "../../../../../src/dispatcher/actions.ts";
import { UserTab } from "../../../../../src/components/views/dialogs/UserTab.ts";
describe("<IntegrationsDisabledDialog />", () => {
const onFinished = jest.fn();
afterEach(() => {
jest.restoreAllMocks();
});
function renderComponent() {
return render(<IntegrationsDisabledDialog onFinished={onFinished} />);
}
it("should render as expected", () => {
const { asFragment } = renderComponent();
expect(asFragment()).toMatchSnapshot();
});
it("should do nothing on clicking OK", () => {
const { getByText } = renderComponent();
fireEvent.click(getByText("OK"));
expect(onFinished).toHaveBeenCalled();
});
it("should open the correct user settings tab on clicking Settings", () => {
jest.spyOn(defaultDispatcher, "dispatch").mockImplementation(() => {});
const { getByText } = renderComponent();
fireEvent.click(getByText("Settings"));
expect(onFinished).toHaveBeenCalled();
expect(defaultDispatcher.dispatch).toHaveBeenCalledWith({
action: Action.ViewUserSettings,
initialTabId: UserTab.Security,
});
});
});