2022-03-11 00:11:56 +00:00
|
|
|
import '@testing-library/jest-dom';
|
2022-03-14 13:18:11 +00:00
|
|
|
import { act, fireEvent, render, screen } from '@testing-library/react';
|
2022-03-20 01:31:44 +00:00
|
|
|
import { VegaKey } from '@vegaprotocol/vegawallet-service-api-client';
|
2022-03-11 00:11:56 +00:00
|
|
|
import { RestConnector } from './connectors';
|
|
|
|
import { useVegaWallet } from './hooks';
|
|
|
|
import { VegaWalletProvider } from './provider';
|
|
|
|
|
|
|
|
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' }];
|
|
|
|
jest
|
|
|
|
.spyOn(restConnector, 'connect')
|
2022-03-20 01:31:44 +00:00
|
|
|
.mockImplementation(() => Promise.resolve(mockKeypairs as VegaKey[]));
|
2022-03-11 00:11:56 +00:00
|
|
|
|
|
|
|
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();
|
|
|
|
});
|