2022-08-17 14:10:01 +00:00
|
|
|
import { MockedProvider } from '@apollo/react-testing';
|
|
|
|
import { render, screen } from '@testing-library/react';
|
2022-10-11 12:22:55 +00:00
|
|
|
import { AssetStatus } from '@vegaprotocol/types';
|
2022-09-09 15:14:48 +00:00
|
|
|
import { AssetDetailsDialog } from './asset-details-dialog';
|
2022-10-11 12:22:55 +00:00
|
|
|
import { AssetDetail, testId } from './asset-details-table';
|
2022-10-05 10:42:22 +00:00
|
|
|
import { AssetsDocument } from './__generated___/Assets';
|
2022-10-11 12:22:55 +00:00
|
|
|
import { generateBuiltinAsset, generateERC20Asset } from './test-helpers';
|
2022-08-17 14:10:01 +00:00
|
|
|
|
|
|
|
const mockedData = {
|
|
|
|
data: {
|
|
|
|
assetsConnection: {
|
|
|
|
edges: [
|
|
|
|
{
|
2022-10-11 12:22:55 +00:00
|
|
|
node: generateERC20Asset(1, AssetStatus.STATUS_ENABLED),
|
2022-08-17 14:10:01 +00:00
|
|
|
__typename: 'AssetEdge',
|
|
|
|
},
|
|
|
|
{
|
2022-10-11 12:22:55 +00:00
|
|
|
node: generateBuiltinAsset(1, AssetStatus.STATUS_ENABLED),
|
2022-08-17 14:10:01 +00:00
|
|
|
__typename: 'AssetEdge',
|
|
|
|
},
|
|
|
|
{
|
2022-10-11 12:22:55 +00:00
|
|
|
node: generateBuiltinAsset(2, AssetStatus.STATUS_PENDING_LISTING),
|
2022-08-17 14:10:01 +00:00
|
|
|
__typename: 'AssetEdge',
|
|
|
|
},
|
|
|
|
{
|
2022-10-11 12:22:55 +00:00
|
|
|
node: generateBuiltinAsset(3, AssetStatus.STATUS_PROPOSED),
|
2022-08-17 14:10:01 +00:00
|
|
|
__typename: 'AssetEdge',
|
|
|
|
},
|
|
|
|
{
|
2022-10-11 12:22:55 +00:00
|
|
|
node: generateBuiltinAsset(4, AssetStatus.STATUS_REJECTED),
|
2022-08-17 14:10:01 +00:00
|
|
|
__typename: 'AssetEdge',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
__typename: 'AssetsConnection',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
const mocks = [
|
|
|
|
{
|
|
|
|
request: {
|
2022-10-05 10:42:22 +00:00
|
|
|
query: AssetsDocument,
|
2022-08-17 14:10:01 +00:00
|
|
|
variables: {},
|
|
|
|
},
|
|
|
|
result: mockedData,
|
|
|
|
},
|
|
|
|
];
|
|
|
|
|
|
|
|
const WrappedAssetDetailsDialog = ({
|
|
|
|
assetSymbol,
|
|
|
|
}: {
|
|
|
|
assetSymbol: string;
|
|
|
|
}) => (
|
|
|
|
<MockedProvider mocks={mocks}>
|
|
|
|
<AssetDetailsDialog
|
|
|
|
assetSymbol={assetSymbol}
|
|
|
|
open={true}
|
|
|
|
onChange={() => false}
|
|
|
|
></AssetDetailsDialog>
|
|
|
|
</MockedProvider>
|
|
|
|
);
|
|
|
|
|
|
|
|
describe('AssetDetailsDialog', () => {
|
2022-10-11 12:22:55 +00:00
|
|
|
it('should show no data message given unknown asset symbol', async () => {
|
2022-08-17 14:10:01 +00:00
|
|
|
render(<WrappedAssetDetailsDialog assetSymbol={'UNKNOWN_FOR_SURE'} />);
|
2022-10-11 12:22:55 +00:00
|
|
|
expect((await screen.findByTestId('splash')).textContent).toContain(
|
|
|
|
'No data'
|
|
|
|
);
|
2022-08-17 14:10:01 +00:00
|
|
|
});
|
|
|
|
|
2022-10-11 12:22:55 +00:00
|
|
|
const cases: [string, { key: AssetDetail; value: string }[]][] = [
|
|
|
|
[
|
|
|
|
'EA01',
|
|
|
|
[
|
|
|
|
{ key: AssetDetail.ID, value: 'E-01' },
|
|
|
|
{ key: AssetDetail.TYPE, value: 'ERC20' },
|
|
|
|
{ key: AssetDetail.NAME, value: 'ERC20 01' },
|
|
|
|
{ key: AssetDetail.SYMBOL, value: 'EA01' },
|
|
|
|
{ key: AssetDetail.DECIMALS, value: '3' },
|
|
|
|
{ key: AssetDetail.QUANTUM, value: '1' },
|
|
|
|
{ key: AssetDetail.STATUS, value: 'Enabled' },
|
|
|
|
{ key: AssetDetail.CONTRACT_ADDRESS, value: '0x123' },
|
|
|
|
{ key: AssetDetail.WITHDRAWAL_THRESHOLD, value: '0.050' },
|
|
|
|
{ key: AssetDetail.LIFETIME_LIMIT, value: '123,000.000' },
|
|
|
|
{
|
|
|
|
key: AssetDetail.INFRASTRUCTURE_FEE_ACCOUNT_BALANCE,
|
|
|
|
value: '0.001',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
key: AssetDetail.GLOBAL_REWARD_POOL_ACCOUNT_BALANCE,
|
|
|
|
value: '0.002',
|
|
|
|
},
|
|
|
|
{ key: AssetDetail.TAKER_FEE_REWARD_ACCOUNT_BALANCE, value: '0.003' },
|
|
|
|
{ key: AssetDetail.MAKER_FEE_REWARD_ACCOUNT_BALANCE, value: '0.004' },
|
|
|
|
{ key: AssetDetail.LP_FEE_REWARD_ACCOUNT_BALANCE, value: '0.005' },
|
|
|
|
{
|
|
|
|
key: AssetDetail.MARKET_PROPOSER_REWARD_ACCOUNT_BALANCE,
|
|
|
|
value: '0.006',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'BIA01',
|
|
|
|
[
|
|
|
|
{ key: AssetDetail.ID, value: 'B-01' },
|
|
|
|
{ key: AssetDetail.TYPE, value: 'Builtin asset' },
|
|
|
|
{ key: AssetDetail.NAME, value: 'Builtin 01' },
|
|
|
|
{ key: AssetDetail.SYMBOL, value: 'BIA01' },
|
|
|
|
{ key: AssetDetail.DECIMALS, value: '5' },
|
|
|
|
{ key: AssetDetail.QUANTUM, value: '1' },
|
|
|
|
{ key: AssetDetail.STATUS, value: 'Enabled' },
|
|
|
|
{ key: AssetDetail.MAX_FAUCET_AMOUNT_MINT, value: '50,000.00000' },
|
|
|
|
{
|
|
|
|
key: AssetDetail.INFRASTRUCTURE_FEE_ACCOUNT_BALANCE,
|
|
|
|
value: '0.00000',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'BIA02',
|
|
|
|
[
|
|
|
|
{ key: AssetDetail.ID, value: 'B-02' },
|
|
|
|
{ key: AssetDetail.TYPE, value: 'Builtin asset' },
|
|
|
|
{ key: AssetDetail.NAME, value: 'Builtin 02' },
|
|
|
|
{ key: AssetDetail.SYMBOL, value: 'BIA02' },
|
|
|
|
{ key: AssetDetail.DECIMALS, value: '5' },
|
|
|
|
{ key: AssetDetail.QUANTUM, value: '1' },
|
|
|
|
{ key: AssetDetail.STATUS, value: 'Pending listing' },
|
|
|
|
{ key: AssetDetail.MAX_FAUCET_AMOUNT_MINT, value: '50,000.00000' },
|
|
|
|
{
|
|
|
|
key: AssetDetail.INFRASTRUCTURE_FEE_ACCOUNT_BALANCE,
|
|
|
|
value: '0.00000',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'BIA03',
|
|
|
|
[
|
|
|
|
{ key: AssetDetail.ID, value: 'B-03' },
|
|
|
|
{ key: AssetDetail.TYPE, value: 'Builtin asset' },
|
|
|
|
{ key: AssetDetail.NAME, value: 'Builtin 03' },
|
|
|
|
{ key: AssetDetail.SYMBOL, value: 'BIA03' },
|
|
|
|
{ key: AssetDetail.DECIMALS, value: '5' },
|
|
|
|
{ key: AssetDetail.QUANTUM, value: '1' },
|
|
|
|
{ key: AssetDetail.STATUS, value: 'Proposed' },
|
|
|
|
{ key: AssetDetail.MAX_FAUCET_AMOUNT_MINT, value: '50,000.00000' },
|
|
|
|
{
|
|
|
|
key: AssetDetail.INFRASTRUCTURE_FEE_ACCOUNT_BALANCE,
|
|
|
|
value: '0.00000',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'BIA04',
|
|
|
|
[
|
|
|
|
{ key: AssetDetail.ID, value: 'B-04' },
|
|
|
|
{ key: AssetDetail.TYPE, value: 'Builtin asset' },
|
|
|
|
{ key: AssetDetail.NAME, value: 'Builtin 04' },
|
|
|
|
{ key: AssetDetail.SYMBOL, value: 'BIA04' },
|
|
|
|
{ key: AssetDetail.DECIMALS, value: '5' },
|
|
|
|
{ key: AssetDetail.QUANTUM, value: '1' },
|
|
|
|
{ key: AssetDetail.STATUS, value: 'Rejected' },
|
|
|
|
{ key: AssetDetail.MAX_FAUCET_AMOUNT_MINT, value: '50,000.00000' },
|
|
|
|
{
|
|
|
|
key: AssetDetail.INFRASTRUCTURE_FEE_ACCOUNT_BALANCE,
|
|
|
|
value: '0.00000',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
],
|
2022-08-17 14:10:01 +00:00
|
|
|
];
|
|
|
|
it.each(cases)(
|
|
|
|
'should show correct data given %p symbol',
|
2022-10-11 12:22:55 +00:00
|
|
|
async (symbol, details) => {
|
|
|
|
render(<WrappedAssetDetailsDialog assetSymbol={symbol} />);
|
|
|
|
for (const detail of details) {
|
|
|
|
expect(
|
|
|
|
(await screen.findByTestId(testId(detail.key, 'value'))).textContent
|
|
|
|
).toContain(detail.value);
|
|
|
|
}
|
2022-08-17 14:10:01 +00:00
|
|
|
}
|
|
|
|
);
|
|
|
|
});
|