You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Tag:
Branch:
Tree:
c30e41b9ce
develop
feature/default_network_editable
v10.22.3
${ noResults }
96 lines
2.2 KiB
96 lines
2.2 KiB
import React from 'react';
|
|||
import thunk from 'redux-thunk';
|
|||
import { Provider } from 'react-redux';
|
|||
import configureMockStore from 'redux-mock-store';
|
|||
import { mount } from 'enzyme';
|
|||
import sinon from 'sinon';
|
|||
import { MemoryRouter } from 'react-router-dom';
|
|||
|
|
||
import Identicon from '../../ui/identicon';
|
|||
import TokenCell from '.';
|
|||
|
|
||
describe('Token Cell', () => {
|
|||
let wrapper;
|
|||
|
|
||
const state = {
|
|||
metamask: {
|
|||
currentCurrency: 'usd',
|
|||
selectedAddress: '0xAddress',
|
|||
contractExchangeRates: {
|
|||
'0xAnotherToken': 0.015,
|
|||
},
|
|||
|
conversionRate: 7.0,
|
||
preferences: {},
|
|||
provider: {
|
|||
chainId: '0x1',
|
|||
ticker: 'ETH',
|
|||
type: 'mainnet',
|
|||
},
|
|||
|
},
|
||
appState: {
|
|||
sidebar: {
|
|||
isOpen: true,
|
|||
},
|
|||
},
|
|||
};
|
|||
|
|
||
const middlewares = [thunk];
|
|||
const mockStore = configureMockStore(middlewares);
|
|||
const store = mockStore(state);
|
|||
|
|
||
let onClick;
|
|||
|
|||
beforeEach(() => {
|
|||
onClick = sinon.stub();
|
|||
|
wrapper = mount(
|
||
<Provider store={store}>
|
|||
<MemoryRouter>
|
|||
<TokenCell
|
|||
address="0xAnotherToken"
|
|||
symbol="TEST"
|
|||
string="5.000"
|
|||
currentCurrency="usd"
|
|||
image="./test-image"
|
|||
onClick={onClick}
|
|||
/>
|
|||
</MemoryRouter>
|
|||
</Provider>,
|
|||
);
|
|||
});
|
|||
|
|
||
afterEach(() => {
|
|||
sinon.restore();
|
|||
});
|
|||
|
|||
it('renders Identicon with props from token cell', () => {
|
|||
expect(wrapper.find(Identicon).prop('address')).toStrictEqual(
|
|||
|
'0xAnotherToken',
|
||
);
|
|||
expect(wrapper.find(Identicon).prop('image')).toStrictEqual('./test-image');
|
|||
});
|
|||
|
|
||
it('renders token balance', () => {
|
|||
expect(wrapper.find('.asset-list-item__token-value').text()).toStrictEqual(
|
|||
|
'5.000',
|
||
);
|
|||
});
|
|||
|
|||
it('renders token symbol', () => {
|
|||
expect(wrapper.find('.asset-list-item__token-symbol').text()).toStrictEqual(
|
|||
|
'TEST',
|
||
);
|
|||
});
|
|||
|
|
||
it('renders converted fiat amount', () => {
|
|||
expect(wrapper.find('.list-item__subheading').text()).toStrictEqual(
|
|||
|
'$0.52 USD',
|
||
);
|
|||
});
|
|||
|
|
||
it('calls onClick when clicked', () => {
|
|||
expect(!onClick.called).toStrictEqual(true);
|
|||
wrapper.simulate('click');
|
|||
expect(onClick.called).toStrictEqual(true);
|
|||
});
|
|||
});
|