2022-03-29 15:26:09 +00:00
|
|
|
import { act, render, screen } from '@testing-library/react';
|
2022-03-25 12:32:14 +00:00
|
|
|
import PositionsTable from './positions-table';
|
2022-03-29 15:26:09 +00:00
|
|
|
import { positions_party_positions } from '@vegaprotocol/graphql';
|
2022-03-25 12:32:14 +00:00
|
|
|
|
2022-03-29 15:26:09 +00:00
|
|
|
const singleRow: positions_party_positions = {
|
|
|
|
realisedPNL: '5',
|
|
|
|
openVolume: '100',
|
|
|
|
unrealisedPNL: '895000',
|
|
|
|
averageEntryPrice: '1129935',
|
|
|
|
market: {
|
|
|
|
id: 'b7010da9dbe7fbab2b74d9d5642fc4a8a0ca93ef803d21fa60c2cacd0416bba0',
|
|
|
|
name: 'UNIDAI Monthly (30 Jun 2022)',
|
|
|
|
data: { markPrice: '1138885', __typename: 'MarketData' },
|
|
|
|
decimalPlaces: 5,
|
|
|
|
tradableInstrument: {
|
|
|
|
instrument: {
|
|
|
|
id: '',
|
|
|
|
name: 'UNIDAI Monthly (30 Jun 2022)',
|
|
|
|
metadata: {
|
|
|
|
tags: [
|
|
|
|
'formerly:3C58ED2A4A6C5D7E',
|
|
|
|
'base:UNI',
|
|
|
|
'quote:DAI',
|
|
|
|
'class:fx/crypto',
|
|
|
|
'monthly',
|
|
|
|
'sector:defi',
|
|
|
|
],
|
|
|
|
__typename: 'InstrumentMetadata',
|
|
|
|
},
|
|
|
|
code: 'UNIDAI.MF21',
|
|
|
|
product: {
|
|
|
|
settlementAsset: {
|
|
|
|
id: '6d9d35f657589e40ddfb448b7ad4a7463b66efb307527fedd2aa7df1bbd5ea61',
|
|
|
|
symbol: 'tDAI',
|
|
|
|
name: 'tDAI TEST',
|
|
|
|
decimals: 5,
|
|
|
|
__typename: 'Asset',
|
|
|
|
},
|
|
|
|
quoteName: 'DAI',
|
|
|
|
__typename: 'Future',
|
|
|
|
},
|
|
|
|
__typename: 'Instrument',
|
|
|
|
},
|
|
|
|
__typename: 'TradableInstrument',
|
|
|
|
},
|
|
|
|
__typename: 'Market',
|
|
|
|
},
|
|
|
|
__typename: 'Position',
|
|
|
|
};
|
|
|
|
const singleRowData = [singleRow];
|
|
|
|
const onRowClicked = (marketId: string) => {
|
|
|
|
console.log(marketId);
|
|
|
|
};
|
|
|
|
|
|
|
|
test('should render successfully', async () => {
|
|
|
|
await act(async () => {
|
|
|
|
const { baseElement } = render(
|
|
|
|
<PositionsTable data={[]} onRowClicked={onRowClicked} />
|
|
|
|
);
|
|
|
|
expect(baseElement).toBeTruthy();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
test('Render correct columns', async () => {
|
|
|
|
await act(async () => {
|
|
|
|
render(<PositionsTable data={singleRowData} onRowClicked={onRowClicked} />);
|
|
|
|
});
|
|
|
|
|
|
|
|
const headers = screen.getAllByRole('columnheader');
|
|
|
|
expect(headers).toHaveLength(5);
|
|
|
|
expect(headers.map((h) => h.textContent?.trim())).toEqual([
|
|
|
|
'Market',
|
|
|
|
'Amount',
|
|
|
|
'Average Entry Price',
|
|
|
|
'Mark Price',
|
|
|
|
'Realised PNL',
|
|
|
|
]);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('Correct formatting applied', async () => {
|
|
|
|
await act(async () => {
|
|
|
|
render(<PositionsTable data={singleRowData} onRowClicked={onRowClicked} />);
|
|
|
|
});
|
|
|
|
const cells = screen.getAllByRole('gridcell');
|
|
|
|
const expectedValues = [
|
|
|
|
singleRow.market.tradableInstrument.instrument.code,
|
|
|
|
'+100',
|
|
|
|
'11.29935',
|
|
|
|
'11.38885',
|
|
|
|
'+5',
|
|
|
|
];
|
|
|
|
cells.forEach((cell, i) => {
|
|
|
|
expect(cell).toHaveTextContent(expectedValues[i]);
|
2022-03-25 12:32:14 +00:00
|
|
|
});
|
2022-03-29 15:26:09 +00:00
|
|
|
expect(cells[cells.length - 1]).toHaveClass('color-vega-green');
|
2022-03-25 12:32:14 +00:00
|
|
|
});
|