2023-02-13 14:48:44 +00:00
|
|
|
import {
|
|
|
|
act,
|
|
|
|
getAllByRole,
|
|
|
|
render,
|
|
|
|
screen,
|
|
|
|
waitFor,
|
|
|
|
} from '@testing-library/react';
|
2022-11-07 12:14:21 +00:00
|
|
|
import * as helpers from '@vegaprotocol/react-helpers';
|
2022-12-02 12:32:54 +00:00
|
|
|
import { AccountManager } from './accounts-manager';
|
2022-10-18 10:40:26 +00:00
|
|
|
|
2023-02-13 14:48:44 +00:00
|
|
|
const mockedUseDataProvider = jest.fn();
|
2022-10-18 10:40:26 +00:00
|
|
|
jest.mock('@vegaprotocol/react-helpers', () => ({
|
|
|
|
...jest.requireActual('@vegaprotocol/react-helpers'),
|
2023-02-13 14:48:44 +00:00
|
|
|
useDataProvider: jest.fn(() => mockedUseDataProvider()),
|
2022-10-18 10:40:26 +00:00
|
|
|
}));
|
|
|
|
|
|
|
|
describe('AccountManager', () => {
|
2023-02-13 14:48:44 +00:00
|
|
|
beforeEach(() => {
|
|
|
|
mockedUseDataProvider
|
|
|
|
.mockImplementationOnce((args) => {
|
|
|
|
return {
|
|
|
|
data: [],
|
|
|
|
};
|
|
|
|
})
|
|
|
|
.mockImplementationOnce((args) => {
|
|
|
|
return {
|
|
|
|
data: [
|
|
|
|
{ asset: { id: 'a1' }, party: { id: 't1' } },
|
|
|
|
{ asset: { id: 'a2' }, party: { id: 't2' } },
|
|
|
|
],
|
|
|
|
};
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2022-10-18 10:40:26 +00:00
|
|
|
it('change partyId should reload data provider', async () => {
|
|
|
|
const { rerender } = render(
|
2023-01-31 16:04:52 +00:00
|
|
|
<AccountManager
|
|
|
|
partyId="partyOne"
|
|
|
|
onClickAsset={jest.fn}
|
|
|
|
isReadOnly={false}
|
|
|
|
/>
|
2022-10-18 10:40:26 +00:00
|
|
|
);
|
2022-11-07 12:14:21 +00:00
|
|
|
expect(
|
|
|
|
(helpers.useDataProvider as jest.Mock).mock.calls[0][0].variables.partyId
|
|
|
|
).toEqual('partyOne');
|
2022-10-18 10:40:26 +00:00
|
|
|
await act(() => {
|
2023-01-31 16:04:52 +00:00
|
|
|
rerender(
|
|
|
|
<AccountManager
|
|
|
|
partyId="partyTwo"
|
|
|
|
onClickAsset={jest.fn}
|
|
|
|
isReadOnly={false}
|
|
|
|
/>
|
|
|
|
);
|
2022-10-18 10:40:26 +00:00
|
|
|
});
|
2022-11-07 12:14:21 +00:00
|
|
|
expect(
|
|
|
|
(helpers.useDataProvider as jest.Mock).mock.calls[1][0].variables.partyId
|
|
|
|
).toEqual('partyTwo');
|
2022-10-18 10:40:26 +00:00
|
|
|
});
|
2022-12-02 12:32:54 +00:00
|
|
|
|
|
|
|
it('update method should return proper result', async () => {
|
2023-02-13 14:48:44 +00:00
|
|
|
let rerenderer: (ui: React.ReactElement) => void;
|
2022-12-02 12:32:54 +00:00
|
|
|
await act(() => {
|
2023-02-13 14:48:44 +00:00
|
|
|
const { rerender } = render(
|
2023-01-31 16:04:52 +00:00
|
|
|
<AccountManager
|
|
|
|
partyId="partyOne"
|
|
|
|
onClickAsset={jest.fn}
|
|
|
|
isReadOnly={false}
|
|
|
|
/>
|
|
|
|
);
|
2023-02-13 14:48:44 +00:00
|
|
|
rerenderer = rerender;
|
2022-12-02 12:32:54 +00:00
|
|
|
});
|
|
|
|
await waitFor(() => {
|
|
|
|
expect(screen.getByText('No accounts')).toBeInTheDocument();
|
|
|
|
});
|
2023-02-01 15:58:47 +00:00
|
|
|
await act(() => {
|
2023-02-13 14:48:44 +00:00
|
|
|
rerenderer(
|
|
|
|
<AccountManager
|
|
|
|
partyId="partyOne"
|
|
|
|
onClickAsset={jest.fn}
|
|
|
|
isReadOnly={false}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
});
|
2023-02-01 15:58:47 +00:00
|
|
|
|
2023-02-13 14:48:44 +00:00
|
|
|
const container = document.querySelector('.ag-center-cols-container');
|
|
|
|
await waitFor(() => {
|
|
|
|
expect(container).toBeInTheDocument();
|
2023-02-01 15:58:47 +00:00
|
|
|
});
|
2023-02-13 14:48:44 +00:00
|
|
|
expect(getAllByRole(container as HTMLDivElement, 'row')).toHaveLength(2);
|
2022-12-02 12:32:54 +00:00
|
|
|
});
|
2022-10-18 10:40:26 +00:00
|
|
|
});
|