4ed623c84c
* feat: update connect dialog to handle api v2 * feat: better error handling * feat: update to only use strings for pubkey, add json rpc connector * feat: make json connector follow same patterns as rest connector * feat: add ability to change wallet location * feat: add chain id fetch * feat: improve types * feat: adjust send tx types * chore: remove dialog title and chain check temporarily * feat: additional UI and error handling * feat: rename keypair and keypairs to pubKey and pubKeys * feat: make rest and json rpc connectors return consistent data * feat: rename derived ids more clearly * feat: update send_transaction response type * chore: fix tests after context name change * feat: add utils for wallet, add encode tx func * feat: return null if tx is rejected * feat: fix up styles for connect buttons * feat: handle wallet version check * feat: add chain id check * chore: rename select pub key function to match, fix tests * fix: tests for rest connector form * feat: add tests for json rpc flow * feat: connect dialog changes * chore: change status to enum to avoid magic strings * feat: add custom icons and handle provided key name * chore: update global wallet connection e2d tests * chore: change zod validation to only expected required values * chore: ignore new generated code files * chore: fix typos and add translations * chore: set hosted wallet via env var and only show if not mainnet * feat: add functionality for try again button * test: fix failing tests * chore: fix lint and test * chore: remove double import * chore: make console-lite-e2e strict so json connector compiles correctly * chore: make token e2e tsconfig strict * chore: make stats-e2e tsconfig strict * feat: update json rpc request namespace * feat: simplify connector setup, support try again * chore: remove comment * fix: build errors * chore: make chainId check optional based on presence of appChainId, mock request for tests * chore: mock chain id request for all apps on all pages * fix: footer border on small screens * fix: use beforeEach for chainId query mock * chore: remove optional chain check, prevent rendering until fetch is complete * chore: update NX_VEGA_WALLET_URLs as the application now appends the base path, adjust token tests * fix: token e2e test that checks for pubkey name * chore: remove duplicated test, update wallet title assertion * fix: token tests * fix: token e2e assertions * fix: withdraw test * feat: enable json RPC for token * fix: sendTx command now accpets pubkey as separate arg * fix: test to use gui option temporarily Co-authored-by: Dexter <dexter.edwards93@gmail.com>
96 lines
2.9 KiB
TypeScript
96 lines
2.9 KiB
TypeScript
import { act, renderHook } from '@testing-library/react';
|
|
import type { Transaction } from './connectors';
|
|
import { RestConnector } from './connectors';
|
|
import { useVegaWallet } from './use-vega-wallet';
|
|
import { VegaWalletProvider } from './provider';
|
|
import { LocalStorage } from '@vegaprotocol/react-helpers';
|
|
import type { ReactNode } from 'react';
|
|
import { WALLET_KEY } from './storage';
|
|
|
|
const restConnector = new RestConnector();
|
|
|
|
const setup = () => {
|
|
const wrapper = ({ children }: { children: ReactNode }) => (
|
|
<VegaWalletProvider>{children}</VegaWalletProvider>
|
|
);
|
|
return renderHook(() => useVegaWallet(), { wrapper });
|
|
};
|
|
|
|
describe('VegaWalletProvider', () => {
|
|
afterAll(() => {
|
|
localStorage.clear();
|
|
});
|
|
|
|
const mockPubKeys = [
|
|
{ publicKey: '111', name: 'public key 1' },
|
|
{ publicKey: '222', name: 'public key 2' },
|
|
];
|
|
const spyOnConnect = jest
|
|
.spyOn(restConnector, 'connect')
|
|
.mockImplementation(() => Promise.resolve(mockPubKeys));
|
|
const spyOnSend = jest
|
|
.spyOn(restConnector, 'sendTx')
|
|
.mockImplementation(() => Promise.resolve(null));
|
|
const storageSpy = jest.spyOn(LocalStorage, 'setItem');
|
|
const spyOnDisconnect = jest
|
|
.spyOn(restConnector, 'disconnect')
|
|
.mockImplementation(() => Promise.resolve());
|
|
|
|
it('connects, disconnects and retrieve keypairs', async () => {
|
|
const { result } = setup();
|
|
|
|
// Default state
|
|
expect(result.current).toEqual({
|
|
pubKey: null,
|
|
pubKeys: null,
|
|
selectPubKey: expect.any(Function),
|
|
connect: expect.any(Function),
|
|
disconnect: expect.any(Function),
|
|
sendTx: expect.any(Function),
|
|
});
|
|
|
|
// Connect
|
|
await act(async () => {
|
|
result.current.connect(restConnector);
|
|
});
|
|
expect(spyOnConnect).toHaveBeenCalled();
|
|
expect(result.current.pubKeys).toHaveLength(mockPubKeys.length);
|
|
expect(result.current.pubKey).toBe(mockPubKeys[0].publicKey);
|
|
|
|
// Change current pubkey
|
|
await act(async () => {
|
|
result.current.selectPubKey(mockPubKeys[1].publicKey);
|
|
});
|
|
expect(result.current.pubKey).toBe(mockPubKeys[1].publicKey);
|
|
expect(storageSpy).toHaveBeenCalledWith(
|
|
WALLET_KEY,
|
|
mockPubKeys[1].publicKey
|
|
);
|
|
|
|
// Send tx
|
|
await act(async () => {
|
|
result.current.sendTx(mockPubKeys[1].publicKey, {} as Transaction);
|
|
});
|
|
expect(spyOnSend).toHaveBeenCalledWith(mockPubKeys[1].publicKey, {});
|
|
});
|
|
|
|
it('persists selected pubkey and disconnects', async () => {
|
|
const { result } = setup();
|
|
expect(result.current.pubKey).toBe(null);
|
|
|
|
await act(async () => {
|
|
result.current.connect(restConnector);
|
|
});
|
|
expect(result.current.pubKey).toBe(mockPubKeys[1].publicKey);
|
|
|
|
// Disconnect
|
|
await act(async () => {
|
|
result.current.disconnect();
|
|
});
|
|
expect(result.current.pubKey).toBe(null);
|
|
expect(result.current.pubKeys).toBe(null);
|
|
expect(spyOnDisconnect).toHaveBeenCalled();
|
|
expect(localStorage.getItem(WALLET_KEY)).toBe(null);
|
|
});
|
|
});
|