Skip to content

Commit

Permalink
chore: dashboard local footer test (#10234)
Browse files Browse the repository at this point in the history
  • Loading branch information
shafin-deriv authored Sep 25, 2023
1 parent f8617fb commit 955cc39
Showing 1 changed file with 66 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
import React from 'react';
import { isMobile } from '@deriv/shared';
import { mockStore, StoreProvider } from '@deriv/stores';
// eslint-disable-next-line import/no-extraneous-dependencies
import { render, screen } from '@testing-library/react';
// eslint-disable-next-line import/no-extraneous-dependencies
import userEvent from '@testing-library/user-event';
import { mock_ws } from 'Utils/mock';
import RootStore from 'Stores/root-store';
import { DBotStoreProvider, mockDBotStore } from 'Stores/useDBotStore';
import LocalFooter from '../local-footer';

jest.mock('@deriv/shared', () => ({
...jest.requireActual('@deriv/shared'),
isMobile: jest.fn(),
}));

jest.mock('@deriv/bot-skeleton/src/scratch/blockly', () => jest.fn());
jest.mock('@deriv/bot-skeleton/src/scratch/dbot', () => ({
saveRecentWorkspace: jest.fn(),
unHighlightAllBlocks: jest.fn(),
}));
jest.mock('@deriv/bot-skeleton/src/scratch/hooks/block_svg', () => jest.fn());

describe('LocalFooter', () => {
let wrapper: ({ children }: { children: JSX.Element }) => JSX.Element, mock_DBot_store: RootStore | undefined;

beforeAll(() => {
const mock_store = mockStore({});
mock_DBot_store = mockDBotStore(mock_store, mock_ws);

wrapper = ({ children }: { children: JSX.Element }) => (
<StoreProvider store={mock_store}>
<DBotStoreProvider ws={mock_ws} mock={mock_DBot_store}>
{children}
</DBotStoreProvider>
</StoreProvider>
);
});

it('should render LocalFooter', () => {
const { container } = render(<LocalFooter />, { wrapper });
expect(container).toBeInTheDocument();
});

it('should open modal on click open button', async () => {
render(<LocalFooter />, { wrapper });
const open_button = screen.getByText('Open');
await userEvent.click(open_button);
expect(mock_DBot_store?.load_modal?.is_load_modal_open).toBeTruthy();
});

it('should render cancel button on mobile', () => {
(isMobile as jest.Mock).mockReturnValueOnce(true);
render(<LocalFooter />, { wrapper });
expect(screen.getByText('Cancel')).toBeInTheDocument();
});

it('should reset local file on cancel button click', async () => {
(isMobile as jest.Mock).mockReturnValueOnce(true);
render(<LocalFooter />, { wrapper });
const cancel_button = screen.getByText('Cancel');
await userEvent.click(cancel_button);
expect(mock_DBot_store?.load_modal?.loaded_local_file).toBeNull();
});
});

0 comments on commit 955cc39

Please sign in to comment.