import '@testing-library/jest-dom'; import { act, fireEvent, render, screen, waitFor, } from '@testing-library/react'; import { RestConnector } from './connectors'; import { useVegaWallet } from './hooks'; import { VegaWalletProvider } from './provider'; import { WALLET_KEY } from './storage-keys'; const restConnector = new RestConnector(); afterAll(() => { localStorage.clear(); }); const TestComponent = () => { const { connect, disconnect, keypairs, keypair, selectPublicKey } = useVegaWallet(); return (

{keypair?.pub}

{keypairs?.length ? ( ) : null}
); }; const generateJSX = () => ( ); test('Renders children', async () => { const mockKeypairs = [{ pub: 'public key 1' }, { pub: 'public key 2' }]; localStorage.setItem(WALLET_KEY, mockKeypairs[0].pub); jest .spyOn(restConnector, 'connect') // @ts-ignore just using pub to assert state logic .mockImplementation(() => Promise.resolve(mockKeypairs)); jest .spyOn(restConnector, 'disconnect') .mockImplementation(() => Promise.resolve()); const { unmount } = render(generateJSX()); expect(screen.getByTestId('children')).toBeInTheDocument(); await act(async () => { fireEvent.click(screen.getByText('Connect')); }); expect(screen.getByTestId('keypair-list').children).toHaveLength( mockKeypairs.length ); expect(screen.getByTestId('current-keypair')).toHaveTextContent( mockKeypairs[0].pub ); // Change current keypair fireEvent.click(screen.getByTestId('keypair-list').children[1]); expect(screen.getByTestId('current-keypair')).toHaveTextContent( mockKeypairs[1].pub ); // Current keypair should persist unmount(); render(generateJSX()); await act(async () => { fireEvent.click(screen.getByText('Connect')); }); expect(screen.getByTestId('current-keypair')).toHaveTextContent( mockKeypairs[1].pub ); await act(async () => { fireEvent.click(screen.getByText('Disconnect')); }); expect(screen.getByTestId('current-keypair')).toBeEmptyDOMElement(); expect(screen.queryByTestId('keypairs-list')).not.toBeInTheDocument(); });