vega-frontend-monorepo/libs/wallet/src/provider.test.tsx

99 lines
2.7 KiB
TypeScript
Raw Normal View History

2022-03-11 00:11:56 +00:00
import '@testing-library/jest-dom';
import { act, fireEvent, render, screen } from '@testing-library/react';
2022-03-11 00:11:56 +00:00
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 (
<div data-testid="children">
<button
onClick={() => {
connect(restConnector);
}}
>
Connect
</button>
<button
onClick={() => {
disconnect();
}}
>
Disconnect
</button>
<p data-testid="current-keypair">{keypair?.pub}</p>
{keypairs?.length ? (
<ul data-testid="keypair-list">
{keypairs.map((kp) => (
<li key={kp.pub} onClick={() => selectPublicKey(kp.pub)}>
{kp.pub}
</li>
))}
</ul>
) : null}
</div>
);
};
const generateJSX = () => (
<VegaWalletProvider>
<TestComponent />
</VegaWalletProvider>
);
Feat/63 Deal ticket (#82) * scaffold dealticket package, remove trading views from react-helpers * add deal ticket component, add intent utils, expand dialog and form group styles * add splash component, show market not found message if market doesnt exist * tidy up error handling * add handleError method for vega tx hook * add better testname for provider test, flesh out tests a bit more for deal ticket * Add unit tests for useVegaTransaction and useOrderSubmit hooks * add wrapper component for order dialog styles * add vega styled loader to ui toolkit and use in order dialog * add title prop to order dialog * split limit and market tickets into own files * add button radio component * revert dialog styles * move splash component to ui-toolkit, add story * convert intent to enum * Make button always type=button unless type prop is passed * inline filter logic for tif selector * add date-fns, add datetime to helpers * add order types to wallet package, make price undefined if order type is market * use enums in deal ticket logic * tidy up order state by moving submit and transaction hooks out of deal ticket * add comment for dialog styles * remove decimal from price input * add types package, delete old generated types from trading project * rename types package to graphql * update generate command to point to correct locations * fix use order submit test * use intent shadow helper * remove date-fns and format manually, update submit button error to use input-error * remove stray console.log
2022-03-17 19:35:46 +00:00
test('Can connect, disconnect and retrieve keypairs', async () => {
2022-03-11 00:11:56 +00:00
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();
});