import { renderHook } from '@testing-library/react-hooks'; import * as reactRedux from 'react-redux'; import sinon from 'sinon'; import { getCurrentCurrency } from '../selectors'; import { getConversionRate, getNativeCurrency, } from '../ducks/metamask/metamask'; import { useCurrencyDisplay } from './useCurrencyDisplay'; const tests = [ { input: { value: '0x2386f26fc10000', numberOfDecimals: 2, currency: 'usd', }, result: { value: '$2.80', suffix: 'USD', displayValue: '$2.80 USD', }, }, { input: { value: '0x2386f26fc10000', currency: 'usd', }, result: { value: '$2.80', suffix: 'USD', displayValue: '$2.80 USD', }, }, { input: { value: '0x1193461d01595930', currency: 'ETH', numberOfDecimals: 3, }, result: { value: '1.266', suffix: 'ETH', displayValue: '1.266 ETH', }, }, { input: { value: '0x1193461d01595930', currency: 'ETH', numberOfDecimals: 3, hideLabel: true, }, result: { value: '1.266', suffix: undefined, displayValue: '1.266', }, }, { input: { value: '0x3b9aca00', currency: 'ETH', denomination: 'GWEI', hideLabel: true, }, result: { value: '1', suffix: undefined, displayValue: '1', }, }, { input: { value: '0x3b9aca00', currency: 'ETH', denomination: 'WEI', hideLabel: true, }, result: { value: '1000000000', suffix: undefined, displayValue: '1000000000', }, }, { input: { value: '0x3b9aca00', currency: 'ETH', numberOfDecimals: 100, hideLabel: true, }, result: { value: '0.000000001', suffix: undefined, displayValue: '0.000000001', }, }, ]; describe('useCurrencyDisplay', () => { tests.forEach(({ input: { value, ...restProps }, result }) => { describe(`when input is { value: ${value}, decimals: ${restProps.numberOfDecimals}, denomation: ${restProps.denomination} }`, () => { const stub = sinon.stub(reactRedux, 'useSelector'); stub.callsFake((selector) => { if (selector === getCurrentCurrency) { return 'usd'; } else if (selector === getNativeCurrency) { return 'ETH'; } else if (selector === getConversionRate) { return 280.45; } return undefined; }); const hookReturn = renderHook(() => useCurrencyDisplay(value, restProps)); const [displayValue, parts] = hookReturn.result.current; stub.restore(); it(`should return ${result.displayValue} as displayValue`, () => { expect(displayValue).toStrictEqual(result.displayValue); }); it(`should return ${result.value} as value`, () => { expect(parts.value).toStrictEqual(result.value); }); it(`should return ${result.suffix} as suffix`, () => { expect(parts.suffix).toStrictEqual(result.suffix); }); }); }); });