1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-02 14:15:06 +01:00
metamask-extension/ui/components/app/transaction-activity-log/transaction-activity-log.component.test.js

172 lines
4.8 KiB
JavaScript
Raw Normal View History

import React from 'react';
import { shallow } from 'enzyme';
import TransactionActivityLog from './transaction-activity-log.component';
describe('TransactionActivityLog Component', () => {
it('should render properly', () => {
2018-12-09 21:48:06 +01:00
const activities = [
{
eventKey: 'transactionCreated',
2020-11-03 00:41:28 +01:00
hash:
'0xe46c7f9b39af2fbf1c53e66f72f80343ab54c2c6dba902d51fb98ada08fe1a63',
2018-12-09 21:48:06 +01:00
id: 2005383477493174,
timestamp: 1543957986150,
value: '0x2386f26fc10000',
2020-11-03 00:41:28 +01:00
},
{
2018-12-09 21:48:06 +01:00
eventKey: 'transactionSubmitted',
2020-11-03 00:41:28 +01:00
hash:
'0xe46c7f9b39af2fbf1c53e66f72f80343ab54c2c6dba902d51fb98ada08fe1a63',
2018-12-09 21:48:06 +01:00
id: 2005383477493174,
timestamp: 1543957987853,
value: '0x1319718a5000',
2020-11-03 00:41:28 +01:00
},
{
2018-12-09 21:48:06 +01:00
eventKey: 'transactionResubmitted',
2020-11-03 00:41:28 +01:00
hash:
'0x7d09d337fc6f5d6fe2dbf3a6988d69532deb0a82b665f9180b5a20db377eea87',
2018-12-09 21:48:06 +01:00
id: 2005383477493175,
timestamp: 1543957991563,
value: '0x1502634b5800',
2020-11-03 00:41:28 +01:00
},
{
2018-12-09 21:48:06 +01:00
eventKey: 'transactionConfirmed',
2020-11-03 00:41:28 +01:00
hash:
'0x7d09d337fc6f5d6fe2dbf3a6988d69532deb0a82b665f9180b5a20db377eea87',
2018-12-09 21:48:06 +01:00
id: 2005383477493175,
timestamp: 1543958029960,
value: '0x1502634b5800',
},
];
const wrapper = shallow(
<TransactionActivityLog
2018-12-09 21:48:06 +01:00
activities={activities}
className="test-class"
2018-12-09 21:48:06 +01:00
inlineRetryIndex={-1}
inlineCancelIndex={-1}
nativeCurrency="ETH"
onCancel={() => undefined}
onRetry={() => undefined}
2018-12-09 21:48:06 +01:00
primaryTransactionStatus="confirmed"
/>,
{ context: { t: (str1, str2) => (str2 ? str1 + str2 : str1) } },
);
expect(wrapper.hasClass('transaction-activity-log')).toStrictEqual(true);
expect(wrapper.hasClass('test-class')).toStrictEqual(true);
});
2018-12-09 21:48:06 +01:00
it('should render inline retry and cancel buttons for earliest pending transaction', () => {
2018-12-09 21:48:06 +01:00
const activities = [
{
eventKey: 'transactionCreated',
hash: '0xa',
id: 1,
timestamp: 1,
value: '0x1',
2020-11-03 00:41:28 +01:00
},
{
2018-12-09 21:48:06 +01:00
eventKey: 'transactionSubmitted',
hash: '0xa',
id: 1,
timestamp: 2,
value: '0x1',
2020-11-03 00:41:28 +01:00
},
{
2018-12-09 21:48:06 +01:00
eventKey: 'transactionResubmitted',
2020-11-03 00:41:28 +01:00
hash:
'0x7d09d337fc6f5d6fe2dbf3a6988d69532deb0a82b665f9180b5a20db377eea87',
2018-12-09 21:48:06 +01:00
id: 2,
timestamp: 3,
value: '0x1',
2020-11-03 00:41:28 +01:00
},
{
2018-12-09 21:48:06 +01:00
eventKey: 'transactionCancelAttempted',
2020-11-03 00:41:28 +01:00
hash:
'0x7d09d337fc6f5d6fe2dbf3a6988d69532deb0a82b665f9180b5a20db377eea87',
2018-12-09 21:48:06 +01:00
id: 3,
timestamp: 4,
value: '0x1',
},
];
2018-12-09 21:48:06 +01:00
const wrapper = shallow(
<TransactionActivityLog
activities={activities}
className="test-class"
inlineRetryIndex={2}
inlineCancelIndex={3}
nativeCurrency="ETH"
onCancel={() => undefined}
onRetry={() => undefined}
2018-12-09 21:48:06 +01:00
primaryTransactionStatus="pending"
isEarliestNonce
2018-12-09 21:48:06 +01:00
/>,
{ context: { t: (str1, str2) => (str2 ? str1 + str2 : str1) } },
);
2018-12-09 21:48:06 +01:00
expect(wrapper.hasClass('transaction-activity-log')).toStrictEqual(true);
expect(wrapper.hasClass('test-class')).toStrictEqual(true);
expect(wrapper.find('.transaction-activity-log__action-link')).toHaveLength(
2020-11-03 00:41:28 +01:00
2,
);
});
it('should not render inline retry and cancel buttons for newer pending transactions', () => {
const activities = [
{
eventKey: 'transactionCreated',
hash: '0xa',
id: 1,
timestamp: 1,
value: '0x1',
2020-11-03 00:41:28 +01:00
},
{
eventKey: 'transactionSubmitted',
hash: '0xa',
id: 1,
timestamp: 2,
value: '0x1',
2020-11-03 00:41:28 +01:00
},
{
eventKey: 'transactionResubmitted',
2020-11-03 00:41:28 +01:00
hash:
'0x7d09d337fc6f5d6fe2dbf3a6988d69532deb0a82b665f9180b5a20db377eea87',
id: 2,
timestamp: 3,
value: '0x1',
2020-11-03 00:41:28 +01:00
},
{
eventKey: 'transactionCancelAttempted',
2020-11-03 00:41:28 +01:00
hash:
'0x7d09d337fc6f5d6fe2dbf3a6988d69532deb0a82b665f9180b5a20db377eea87',
id: 3,
timestamp: 4,
value: '0x1',
},
];
const wrapper = shallow(
<TransactionActivityLog
activities={activities}
className="test-class"
inlineRetryIndex={2}
inlineCancelIndex={3}
nativeCurrency="ETH"
onCancel={() => undefined}
onRetry={() => undefined}
primaryTransactionStatus="pending"
isEarliestNonce={false}
/>,
{ context: { t: (str1, str2) => (str2 ? str1 + str2 : str1) } },
);
expect(wrapper.hasClass('transaction-activity-log')).toStrictEqual(true);
expect(wrapper.hasClass('test-class')).toStrictEqual(true);
expect(wrapper.find('.transaction-activity-log__action-link')).toHaveLength(
2020-11-03 00:41:28 +01:00
0,
);
});
});