mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
4f66dc948f
The controllers package has been updated to v33. The only breaking change in this release was to rename the term "collectible" to "NFT" wherever it appeared in the API. Changes in this PR have been kept minimal; additional renaming can be done in separate PRs. This PR only updates the controller names, controller state, controller methods, and any direct references to these things. NFTs are still called "collectibles" in most places.
339 lines
12 KiB
JavaScript
339 lines
12 KiB
JavaScript
import React from 'react';
|
|
import { fireEvent, screen } from '@testing-library/react';
|
|
import reactRouterDom from 'react-router-dom';
|
|
import configureStore from '../../../store/store';
|
|
import { renderWithProvider } from '../../../../test/jest/rendering';
|
|
import { EXPERIMENTAL_ROUTE } from '../../../helpers/constants/routes';
|
|
import { setBackgroundConnection } from '../../../../test/jest';
|
|
import CollectiblesTab from '.';
|
|
|
|
const COLLECTIBLES = [
|
|
{
|
|
address: '0x495f947276749Ce646f68AC8c248420045cb7b5e',
|
|
tokenId:
|
|
'58076532811975507823669075598676816378162417803895263482849101575514658701313',
|
|
name: 'Punk #4',
|
|
creator: {
|
|
user: {
|
|
username: null,
|
|
},
|
|
profile_img_url: null,
|
|
address: '0x806627172af48bd5b0765d3449a7def80d6576ff',
|
|
config: '',
|
|
},
|
|
description: 'Red Mohawk bam!',
|
|
image:
|
|
'https://lh3.googleusercontent.com/BdxvLseXcfl57BiuQcQYdJ64v-aI8din7WPk0Pgo3qQFhAUH-B6i-dCqqc_mCkRIzULmwzwecnohLhrcH8A9mpWIZqA7ygc52Sr81hE',
|
|
standard: 'ERC1155',
|
|
},
|
|
{
|
|
address: '0x495f947276749Ce646f68AC8c248420045cb7b5e',
|
|
tokenId:
|
|
'58076532811975507823669075598676816378162417803895263482849101574415147073537',
|
|
name: 'Punk #3',
|
|
creator: {
|
|
user: {
|
|
username: null,
|
|
},
|
|
profile_img_url: null,
|
|
address: '0x806627172af48bd5b0765d3449a7def80d6576ff',
|
|
config: '',
|
|
},
|
|
description: 'Clown PUNK!!!',
|
|
image:
|
|
'https://lh3.googleusercontent.com/H7VrxaalZv4PF1B8U7ADuc8AfuqTVyzmMEDQ5OXKlx0Tqu5XiwsKYj4j_pAF6wUJjLMQbSN_0n3fuj84lNyRhFW9hyrxqDfY1IiQEQ',
|
|
standard: 'ERC1155',
|
|
},
|
|
{
|
|
address: '0x495f947276749Ce646f68AC8c248420045cb7b5e',
|
|
tokenId:
|
|
'58076532811975507823669075598676816378162417803895263482849101573315635445761',
|
|
name: 'Punk #2',
|
|
creator: {
|
|
user: {
|
|
username: null,
|
|
},
|
|
profile_img_url: null,
|
|
address: '0x806627172af48bd5b0765d3449a7def80d6576ff',
|
|
config: '',
|
|
},
|
|
description: 'Got glasses and black hair!',
|
|
image:
|
|
'https://lh3.googleusercontent.com/CHNTSlKB_Gob-iwTq8jcag6XwBkTqBMLt_vEKeBv18Q4AoPFAEPceqK6mRzkad2s5djx6CT5zbGQwDy81WwtNzViK5dQbG60uAWv',
|
|
standard: 'ERC1155',
|
|
},
|
|
{
|
|
address: '0x495f947276749Ce646f68AC8c248420045cb7b5e',
|
|
tokenId:
|
|
'58076532811975507823669075598676816378162417803895263482849101572216123817985',
|
|
name: 'Punk #1',
|
|
creator: {
|
|
user: {
|
|
username: null,
|
|
},
|
|
profile_img_url: null,
|
|
address: '0x806627172af48bd5b0765d3449a7def80d6576ff',
|
|
config: '',
|
|
},
|
|
image:
|
|
'https://lh3.googleusercontent.com/4jfPi-nQNWCUXD5qVNVWX7LX2UufU_elEJcvICFlsTdcBXv70asnDEOlI8oKECZxlXq1wseeIXMwmP5tLyOUxMKk',
|
|
standard: 'ERC1155',
|
|
},
|
|
{
|
|
address: '0x495f947276749Ce646f68AC8c248420045cb7b5e',
|
|
tokenId:
|
|
'58076532811975507823669075598676816378162417803895263482849101571116612190209',
|
|
name: 'Punk #4651',
|
|
creator: {
|
|
user: {
|
|
username: null,
|
|
},
|
|
profile_img_url: null,
|
|
address: '0x806627172af48bd5b0765d3449a7def80d6576ff',
|
|
config: '',
|
|
},
|
|
image:
|
|
'https://lh3.googleusercontent.com/BdxvLseXcfl57BiuQcQYdJ64v-aI8din7WPk0Pgo3qQFhAUH-B6i-dCqqc_mCkRIzULmwzwecnohLhrcH8A9mpWIZqA7ygc52Sr81hE',
|
|
standard: 'ERC1155',
|
|
},
|
|
{
|
|
address: '0xDc7382Eb0Bc9C352A4CbA23c909bDA01e0206414',
|
|
tokenId: '1',
|
|
name: 'MUNK #1',
|
|
description: null,
|
|
image: 'ipfs://QmTSZUNt8AKyDabkyXXXP4oHWDnaVXgNdXoJGEyaYzLbeL',
|
|
standard: 'ERC721',
|
|
},
|
|
{
|
|
address: '0xDc7382Eb0Bc9C352A4CbA23c909bDA01e0206414',
|
|
tokenId: '2',
|
|
name: 'MUNK #2',
|
|
description: null,
|
|
image: 'ipfs://QmTSZUNt8AKyDabkyXXXP4oHWDnaVXgNdXoJGEyaYzLbeL',
|
|
standard: 'ERC721',
|
|
},
|
|
{
|
|
address: '0xDc7382Eb0Bc9C352A4CbA23c909bDA01e0206414',
|
|
tokenId: '3',
|
|
name: 'MUNK #3',
|
|
description: null,
|
|
image: 'ipfs://QmTSZUNt8AKyDabkyXXXP4oHWDnaVXgNdXoJGEyaYzLbeL',
|
|
standard: 'ERC721',
|
|
},
|
|
];
|
|
|
|
const COLLECTIBLES_CONTRACTS = [
|
|
{
|
|
address: '0x495f947276749Ce646f68AC8c248420045cb7b5e',
|
|
name: 'PUNKS',
|
|
symbol: 'PNKS',
|
|
schemaName: 'ERC1155',
|
|
},
|
|
{
|
|
address: '0xDc7382Eb0Bc9C352A4CbA23c909bDA01e0206414',
|
|
name: 'Munks',
|
|
symbol: 'MNKS',
|
|
},
|
|
];
|
|
|
|
const collectiblesDropdownState = {
|
|
'0x495f947276749ce646f68ac8c248420045cb7b5e': true,
|
|
'0xdc7382eb0bc9c352a4cba23c909bda01e0206414': true,
|
|
};
|
|
|
|
const ACCOUNT_1 = '0x123';
|
|
const ACCOUNT_2 = '0x456';
|
|
|
|
const render = ({
|
|
collectibleContracts = [],
|
|
collectibles = [],
|
|
selectedAddress,
|
|
chainId = '0x1',
|
|
collectiblesDetectionNoticeDismissed = false,
|
|
useNftDetection,
|
|
onAddNFT = jest.fn(),
|
|
}) => {
|
|
const store = configureStore({
|
|
metamask: {
|
|
allNfts: {
|
|
[ACCOUNT_1]: {
|
|
[chainId]: collectibles,
|
|
},
|
|
},
|
|
allNftContracts: {
|
|
[ACCOUNT_1]: {
|
|
[chainId]: collectibleContracts,
|
|
},
|
|
},
|
|
provider: { chainId },
|
|
selectedAddress,
|
|
collectiblesDetectionNoticeDismissed,
|
|
useNftDetection,
|
|
collectiblesDropdownState,
|
|
},
|
|
});
|
|
return renderWithProvider(<CollectiblesTab onAddNFT={onAddNFT} />, store);
|
|
};
|
|
|
|
describe('Collectible Items', () => {
|
|
const detectCollectiblesStub = jest.fn();
|
|
const setCollectiblesDetectionNoticeDismissedStub = jest.fn();
|
|
const getStateStub = jest.fn();
|
|
const checkAndUpdateAllCollectiblesOwnershipStatusStub = jest.fn();
|
|
const updateCollectibleDropDownStateStub = jest.fn();
|
|
setBackgroundConnection({
|
|
setCollectiblesDetectionNoticeDismissed:
|
|
setCollectiblesDetectionNoticeDismissedStub,
|
|
detectNfts: detectCollectiblesStub,
|
|
getState: getStateStub,
|
|
checkAndUpdateAllNftsOwnershipStatus:
|
|
checkAndUpdateAllCollectiblesOwnershipStatusStub,
|
|
updateCollectibleDropDownState: updateCollectibleDropDownStateStub,
|
|
});
|
|
const historyPushMock = jest.fn();
|
|
|
|
jest
|
|
.spyOn(reactRouterDom, 'useHistory')
|
|
.mockImplementation()
|
|
.mockReturnValue({ push: historyPushMock });
|
|
|
|
afterEach(() => {
|
|
jest.clearAllMocks();
|
|
});
|
|
|
|
describe('Collectibles Detection Notice', () => {
|
|
it('should render the Collectibles Detection Notice when currently selected network is Mainnet and currently selected account has no collectibles', () => {
|
|
render({
|
|
selectedAddress: ACCOUNT_2,
|
|
collectibles: COLLECTIBLES,
|
|
});
|
|
expect(screen.queryByText('New! NFT detection')).toBeInTheDocument();
|
|
});
|
|
it('should not render the Collectibles Detection Notice when currently selected network is Mainnet and currently selected account has collectibles', () => {
|
|
render({
|
|
selectedAddress: ACCOUNT_1,
|
|
collectibles: COLLECTIBLES,
|
|
});
|
|
expect(screen.queryByText('New! NFT detection')).not.toBeInTheDocument();
|
|
});
|
|
it('should take user to the experimental settings tab in settings when user clicks "Turn on NFT detection in Settings"', () => {
|
|
render({
|
|
selectedAddress: ACCOUNT_2,
|
|
collectibles: COLLECTIBLES,
|
|
});
|
|
fireEvent.click(screen.queryByText('Turn on NFT detection in Settings'));
|
|
expect(historyPushMock).toHaveBeenCalledTimes(1);
|
|
expect(historyPushMock).toHaveBeenCalledWith(
|
|
`${EXPERIMENTAL_ROUTE}#autodetect-nfts`,
|
|
);
|
|
});
|
|
it('should not render the Collectibles Detection Notice when currently selected network is Mainnet and currently selected account has no collectibles but use collectible autodetection preference is set to true', () => {
|
|
render({
|
|
selectedAddress: ACCOUNT_1,
|
|
collectibles: COLLECTIBLES,
|
|
useNftDetection: true,
|
|
});
|
|
expect(screen.queryByText('New! NFT detection')).not.toBeInTheDocument();
|
|
});
|
|
it('should not render the Collectibles Detection Notice when currently selected network is Mainnet and currently selected account has no collectibles but user has dismissed the notice before', () => {
|
|
render({
|
|
selectedAddress: ACCOUNT_1,
|
|
collectibles: COLLECTIBLES,
|
|
collectiblesDetectionNoticeDismissed: true,
|
|
});
|
|
expect(screen.queryByText('New! NFT detection')).not.toBeInTheDocument();
|
|
});
|
|
|
|
it('should call setCollectibesDetectionNoticeDismissed when users clicks "X"', () => {
|
|
render({
|
|
selectedAddress: ACCOUNT_2,
|
|
collectibles: COLLECTIBLES,
|
|
});
|
|
expect(
|
|
setCollectiblesDetectionNoticeDismissedStub,
|
|
).not.toHaveBeenCalled();
|
|
fireEvent.click(
|
|
screen.queryByTestId('collectibles-detection-notice-close'),
|
|
);
|
|
expect(setCollectiblesDetectionNoticeDismissedStub).toHaveBeenCalled();
|
|
});
|
|
});
|
|
|
|
describe('Collections', () => {
|
|
it('should render the name of the collections and number of collectibles in each collection if current account/chainId combination has collectibles', () => {
|
|
render({
|
|
selectedAddress: ACCOUNT_1,
|
|
collectibles: COLLECTIBLES,
|
|
collectibleContracts: COLLECTIBLES_CONTRACTS,
|
|
});
|
|
expect(screen.queryByText('PUNKS (5)')).toBeInTheDocument();
|
|
expect(screen.queryByText('Munks (3)')).toBeInTheDocument();
|
|
});
|
|
it('should not render collections if current account/chainId combination has collectibles', () => {
|
|
render({
|
|
selectedAddress: ACCOUNT_2,
|
|
collectibles: COLLECTIBLES,
|
|
collectibleContracts: COLLECTIBLES_CONTRACTS,
|
|
});
|
|
expect(screen.queryByText('PUNKS (5)')).not.toBeInTheDocument();
|
|
expect(screen.queryByText('Munks (3)')).not.toBeInTheDocument();
|
|
});
|
|
});
|
|
describe('Collectibles options', () => {
|
|
it('should render a link "Refresh list" when some collectibles are present on mainnet and collectible auto-detection preference is set to true, which, when clicked calls methods DetectCollectibles and checkAndUpdateCollectiblesOwnershipStatus', () => {
|
|
render({
|
|
selectedAddress: ACCOUNT_1,
|
|
collectibles: COLLECTIBLES,
|
|
useNftDetection: true,
|
|
});
|
|
expect(detectCollectiblesStub).not.toHaveBeenCalled();
|
|
expect(
|
|
checkAndUpdateAllCollectiblesOwnershipStatusStub,
|
|
).not.toHaveBeenCalled();
|
|
fireEvent.click(screen.queryByText('Refresh list'));
|
|
expect(detectCollectiblesStub).toHaveBeenCalled();
|
|
expect(
|
|
checkAndUpdateAllCollectiblesOwnershipStatusStub,
|
|
).toHaveBeenCalled();
|
|
});
|
|
|
|
it('should render a link "Refresh list" when some collectibles are present on a non-mainnet chain, which, when clicked calls a method checkAndUpdateCollectiblesOwnershipStatus', () => {
|
|
render({
|
|
chainId: '0x5',
|
|
selectedAddress: ACCOUNT_1,
|
|
collectibles: COLLECTIBLES,
|
|
useNftDetection: true,
|
|
});
|
|
expect(
|
|
checkAndUpdateAllCollectiblesOwnershipStatusStub,
|
|
).not.toHaveBeenCalled();
|
|
fireEvent.click(screen.queryByText('Refresh list'));
|
|
expect(
|
|
checkAndUpdateAllCollectiblesOwnershipStatusStub,
|
|
).toHaveBeenCalled();
|
|
});
|
|
|
|
it('should render a link "Enable autodetect" when some collectibles are present and collectible auto-detection preference is set to false, which, when clicked sends user to the experimental tab of settings', () => {
|
|
render({
|
|
selectedAddress: ACCOUNT_1,
|
|
collectibles: COLLECTIBLES,
|
|
});
|
|
expect(historyPushMock).toHaveBeenCalledTimes(0);
|
|
fireEvent.click(screen.queryByText('Enable autodetect'));
|
|
expect(historyPushMock).toHaveBeenCalledTimes(1);
|
|
expect(historyPushMock).toHaveBeenCalledWith(EXPERIMENTAL_ROUTE);
|
|
});
|
|
it('should render a link "Import NFTs" when some collectibles are present, which, when clicked calls the passed in onAddNFT method', () => {
|
|
const onAddNFTStub = jest.fn();
|
|
render({
|
|
selectedAddress: ACCOUNT_1,
|
|
collectibles: COLLECTIBLES,
|
|
onAddNFT: onAddNFTStub,
|
|
});
|
|
expect(onAddNFTStub).toHaveBeenCalledTimes(0);
|
|
fireEvent.click(screen.queryByText('Import NFTs'));
|
|
expect(onAddNFTStub).toHaveBeenCalledTimes(1);
|
|
});
|
|
});
|
|
});
|