2022-06-11 19:55:35 +02:00
|
|
|
import React from 'react';
|
|
|
|
import { Provider } from 'react-redux';
|
|
|
|
import { renderHook } from '@testing-library/react-hooks';
|
|
|
|
|
|
|
|
import configureStore from '../store/store';
|
2022-07-23 16:37:31 +02:00
|
|
|
import * as Actions from '../store/actions';
|
2023-01-18 15:47:29 +01:00
|
|
|
import { TokenStandard } from '../../shared/constants/transaction';
|
2022-06-11 19:55:35 +02:00
|
|
|
import { useAssetDetails } from './useAssetDetails';
|
|
|
|
|
|
|
|
const renderUseAssetDetails = ({
|
|
|
|
tokenAddress,
|
|
|
|
userAddress,
|
|
|
|
transactionData,
|
|
|
|
}) => {
|
|
|
|
const mockState = {
|
|
|
|
metamask: {
|
|
|
|
provider: {
|
|
|
|
type: 'test',
|
2022-09-29 05:26:01 +02:00
|
|
|
chainId: '0x5',
|
2022-06-11 19:55:35 +02:00
|
|
|
},
|
|
|
|
tokenList: {},
|
2022-12-20 13:54:28 +01:00
|
|
|
tokens: [],
|
2022-06-11 19:55:35 +02:00
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
const wrapper = ({ children }) => (
|
|
|
|
<Provider store={configureStore(mockState)}>{children}</Provider>
|
|
|
|
);
|
|
|
|
|
|
|
|
return renderHook(
|
|
|
|
() => useAssetDetails(tokenAddress, userAddress, transactionData),
|
|
|
|
{ wrapper },
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
describe('useAssetDetails', () => {
|
2022-07-23 16:37:31 +02:00
|
|
|
let getTokenStandardAndDetailsStub;
|
|
|
|
|
2022-06-11 19:55:35 +02:00
|
|
|
beforeEach(() => {
|
2023-04-19 19:20:18 +02:00
|
|
|
getTokenStandardAndDetailsStub = jest.spyOn(
|
|
|
|
Actions,
|
|
|
|
'getTokenStandardAndDetails',
|
|
|
|
);
|
2022-06-11 19:55:35 +02:00
|
|
|
});
|
2022-07-23 16:37:31 +02:00
|
|
|
|
|
|
|
it('should return object with tokenSymbol set to an empty string, when getAssetDetails returns and empty object', async () => {
|
2023-04-19 19:20:18 +02:00
|
|
|
getTokenStandardAndDetailsStub.mockImplementation(() =>
|
|
|
|
Promise.resolve({}),
|
|
|
|
);
|
2022-06-11 19:55:35 +02:00
|
|
|
const toAddress = '000000000000000000000000000000000000dead';
|
|
|
|
const tokenAddress = '0x1';
|
|
|
|
|
|
|
|
const transactionData = `0xa9059cbb000000000000000000000000${toAddress}000000000000000000000000000000000000000000000000016345785d8a0000`;
|
|
|
|
|
|
|
|
const { result, waitForNextUpdate } = renderUseAssetDetails({
|
|
|
|
tokenAddress,
|
|
|
|
userAddress: '0x111',
|
|
|
|
transactionData,
|
|
|
|
});
|
|
|
|
|
|
|
|
await waitForNextUpdate();
|
|
|
|
|
2022-07-23 16:37:31 +02:00
|
|
|
expect(result.current).toStrictEqual(
|
|
|
|
expect.objectContaining({
|
|
|
|
assetAddress: tokenAddress,
|
|
|
|
tokenSymbol: '',
|
|
|
|
}),
|
|
|
|
);
|
2022-06-11 19:55:35 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should return object with correct tokenValues for an ERC20 token', async () => {
|
|
|
|
const userAddress = '0xf04a5cc80b1e94c69b48f5ee68a08cd2f09a7c3e';
|
|
|
|
const tokenAddress = '0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2';
|
|
|
|
const toAddress = '000000000000000000000000000000000000dead';
|
|
|
|
const transactionData = `0xa9059cbb000000000000000000000000${toAddress}00000000000000000000000000000000000000000000000000000000000001f4`;
|
|
|
|
|
2023-01-18 15:47:29 +01:00
|
|
|
const standard = TokenStandard.ERC20;
|
2022-06-11 19:55:35 +02:00
|
|
|
const symbol = 'WETH';
|
|
|
|
const balance = '1';
|
|
|
|
const decimals = 18;
|
|
|
|
|
2022-07-23 16:37:31 +02:00
|
|
|
getTokenStandardAndDetailsStub.mockImplementation(() =>
|
2022-06-11 19:55:35 +02:00
|
|
|
Promise.resolve({
|
|
|
|
standard,
|
|
|
|
balance,
|
2022-07-23 16:37:31 +02:00
|
|
|
symbol,
|
2022-06-11 19:55:35 +02:00
|
|
|
decimals,
|
|
|
|
}),
|
|
|
|
);
|
|
|
|
|
|
|
|
const { result, waitForNextUpdate } = renderUseAssetDetails({
|
|
|
|
tokenAddress,
|
|
|
|
userAddress,
|
|
|
|
transactionData,
|
|
|
|
});
|
|
|
|
|
|
|
|
await waitForNextUpdate();
|
|
|
|
|
|
|
|
expect(result.current).toStrictEqual({
|
|
|
|
assetAddress: tokenAddress,
|
|
|
|
assetName: undefined,
|
|
|
|
assetStandard: standard,
|
|
|
|
decimals,
|
|
|
|
toAddress: `0x${toAddress}`,
|
|
|
|
tokenAmount: '0.0000000000000005',
|
|
|
|
tokenId: undefined,
|
|
|
|
tokenImage: undefined,
|
|
|
|
tokenSymbol: symbol,
|
|
|
|
userBalance: balance,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2023-04-19 19:20:18 +02:00
|
|
|
it('should return object with correct tokenValues for an ERC20 token with no decimals', async () => {
|
|
|
|
const userAddress = '0xf04a5cc80b1e94c69b48f5ee68a08cd2f09a7c3e';
|
|
|
|
const tokenAddress = '0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2';
|
|
|
|
const toAddress = '000000000000000000000000000000000000dead';
|
|
|
|
const transactionData = `0xa9059cbb000000000000000000000000${toAddress}00000000000000000000000000000000000000000000000000000000000001f4`;
|
|
|
|
|
|
|
|
const standard = TokenStandard.ERC20;
|
|
|
|
const symbol = 'WETH';
|
|
|
|
const balance = '1';
|
|
|
|
|
|
|
|
getTokenStandardAndDetailsStub.mockImplementation(() =>
|
|
|
|
Promise.resolve({
|
|
|
|
standard,
|
|
|
|
balance,
|
|
|
|
symbol,
|
|
|
|
}),
|
|
|
|
);
|
|
|
|
|
|
|
|
const { result, waitForNextUpdate } = renderUseAssetDetails({
|
|
|
|
tokenAddress,
|
|
|
|
userAddress,
|
|
|
|
transactionData,
|
|
|
|
});
|
|
|
|
|
|
|
|
await waitForNextUpdate();
|
|
|
|
|
|
|
|
expect(result.current).toStrictEqual({
|
|
|
|
assetAddress: tokenAddress,
|
|
|
|
assetName: undefined,
|
|
|
|
assetStandard: standard,
|
|
|
|
toAddress: `0x${toAddress}`,
|
|
|
|
tokenAmount: undefined,
|
|
|
|
tokenId: undefined,
|
|
|
|
tokenImage: undefined,
|
|
|
|
tokenSymbol: symbol,
|
|
|
|
userBalance: balance,
|
|
|
|
decimals: undefined,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2022-06-11 19:55:35 +02:00
|
|
|
it('should return object with correct tokenValues for an ERC721 token', async () => {
|
|
|
|
const tokenAddress = '0xBC4CA0EdA7647A8aB7C2061c2E118A18a936f13D';
|
|
|
|
const toAddress = '000000000000000000000000000000000000dead';
|
2022-07-23 16:37:31 +02:00
|
|
|
const tokenId = '12';
|
|
|
|
const transactionData = `0x23b872dd000000000000000000000000a544eebe103733f22ef62af556023bc918b73d36000000000000000000000000${toAddress}000000000000000000000000000000000000000000000000000000000000000${Number(
|
|
|
|
tokenId,
|
|
|
|
).toString(16)}`;
|
2022-06-11 19:55:35 +02:00
|
|
|
|
|
|
|
const symbol = 'BAYC';
|
|
|
|
const name = 'BoredApeYachtClub';
|
|
|
|
const image =
|
|
|
|
'https://bafybeihw3gvmthmvrenfmcvagtais5tv7r4nmiezgsv7nyknjubxw4lite.ipfs.dweb.link';
|
2023-01-18 15:47:29 +01:00
|
|
|
const standard = TokenStandard.ERC721;
|
2022-06-11 19:55:35 +02:00
|
|
|
|
2022-07-23 16:37:31 +02:00
|
|
|
getTokenStandardAndDetailsStub.mockImplementation(() =>
|
2022-06-11 19:55:35 +02:00
|
|
|
Promise.resolve({
|
|
|
|
standard,
|
|
|
|
symbol,
|
|
|
|
name,
|
|
|
|
image,
|
|
|
|
}),
|
|
|
|
);
|
|
|
|
|
|
|
|
const { result, waitForNextUpdate } = renderUseAssetDetails({
|
|
|
|
tokenAddress,
|
|
|
|
transactionData,
|
|
|
|
});
|
|
|
|
|
|
|
|
await waitForNextUpdate();
|
|
|
|
|
|
|
|
expect(result.current).toStrictEqual({
|
|
|
|
assetAddress: tokenAddress,
|
|
|
|
assetName: name,
|
|
|
|
assetStandard: standard,
|
|
|
|
decimals: undefined,
|
|
|
|
toAddress: `0x${toAddress}`,
|
|
|
|
tokenId,
|
|
|
|
tokenImage: image,
|
|
|
|
tokenSymbol: symbol,
|
|
|
|
userBalance: undefined,
|
|
|
|
tokenAmount: undefined,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should return object with correct tokenValues for an ERC1155 token', async () => {
|
|
|
|
const tokenAddress = '0x76BE3b62873462d2142405439777e971754E8E77';
|
|
|
|
const toAddress = '000000000000000000000000000000000000dead';
|
2022-07-23 16:37:31 +02:00
|
|
|
const tokenId = '802';
|
|
|
|
const transactionData = `0xf242432a000000000000000000000000a544eebe103733f22ef62af556023bc918b73d36000000000000000000000000000000000000000000000000000000000000dead0000000000000000000000000000000000000000000000000000000000000${Number(
|
|
|
|
tokenId,
|
|
|
|
).toString(
|
|
|
|
16,
|
|
|
|
)}000000000000000000000000000000000000000000000000000000000000009c00000000000000000000000000000000000000000000000000000000000000a000000000000000000000000000000000000000000000000000000000000000040000000000000000000000000000000000000000000000000000000000000000`;
|
2022-06-11 19:55:35 +02:00
|
|
|
|
|
|
|
const image =
|
|
|
|
'https://bafybeihw3gvmthmvrenfmcvagtais5tv7r4nmiezgsv7nyknjubxw4lite.ipfs.dweb.link';
|
2023-01-18 15:47:29 +01:00
|
|
|
const standard = TokenStandard.ERC1155;
|
2022-06-11 19:55:35 +02:00
|
|
|
|
2022-07-23 16:37:31 +02:00
|
|
|
getTokenStandardAndDetailsStub.mockImplementation(() =>
|
2022-06-11 19:55:35 +02:00
|
|
|
Promise.resolve({
|
|
|
|
standard,
|
|
|
|
image,
|
|
|
|
}),
|
|
|
|
);
|
|
|
|
|
|
|
|
const { result, waitForNextUpdate } = renderUseAssetDetails({
|
|
|
|
tokenAddress,
|
|
|
|
transactionData,
|
|
|
|
});
|
|
|
|
|
|
|
|
await waitForNextUpdate();
|
|
|
|
|
|
|
|
expect(result.current).toStrictEqual({
|
|
|
|
assetAddress: tokenAddress,
|
|
|
|
assetName: undefined,
|
|
|
|
assetStandard: standard,
|
|
|
|
decimals: undefined,
|
|
|
|
toAddress: `0x${toAddress}`,
|
2022-07-23 16:37:31 +02:00
|
|
|
tokenId,
|
2022-06-11 19:55:35 +02:00
|
|
|
tokenImage: image,
|
|
|
|
tokenSymbol: '',
|
|
|
|
userBalance: undefined,
|
|
|
|
tokenAmount: undefined,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|