Fix copyToClipboard tests

Signed-off-by: Tomasz Szuba <tszuba@box.com>
This commit is contained in:
Tomasz Szuba
2024-03-15 15:22:03 +01:00
committed by Tomasz Szuba
parent 4bc4ed123e
commit 48ef68caa8
@@ -18,7 +18,7 @@ import { createTestShadowDom } from '../../test-utils';
import { copyToClipboard } from './copyToClipboard';
import { lightTheme } from '@backstage/theme';
import { act, waitFor } from '@testing-library/react';
import useCopyToClipboard from 'react-use/esm/useCopyToClipboard';
import { default as useCopyToClipboardUnmocked } from 'react-use/esm/useCopyToClipboard';
const clipboardSpy = jest.fn();
Object.defineProperty(window.navigator, 'clipboard', {
@@ -27,20 +27,17 @@ Object.defineProperty(window.navigator, 'clipboard', {
},
});
jest.mock('react-use/lib/useCopyToClipboard', () => {
const original = jest.requireActual('react-use/lib/useCopyToClipboard');
const useCopyToClipboard = jest.mocked(useCopyToClipboardUnmocked);
return {
__esModule: true,
default: jest.fn().mockImplementation(original.default),
};
});
jest.mock('react-use/esm/useCopyToClipboard', () =>
jest.fn().mockImplementation(() => [{ noUserInteraction: false }, jest.fn()]),
);
describe('copyToClipboard', () => {
it('calls navigator.clipboard.writeText when clipboard button has been clicked', async () => {
const spy = useCopyToClipboard as jest.Mock;
const spy = useCopyToClipboard;
const copy = jest.fn();
spy.mockReturnValue([{}, copy]);
spy.mockReturnValue([{ noUserInteraction: false }, copy]);
const expectedClipboard = 'function foo() {return "bar";}';